#include "HYDROGUI_PrsImage.h"
#include "HYDROGUI_Tool.h"
+#include "HYDROGUI_Module.h"
#include <HYDROData_Lambert93.h>
#include <HYDROData_Image.h>
+#include <LightApp_Application.h>
#include <SUIT_FileDlg.h>
#include <SUIT_ResourceMgr.h>
+#include <SUIT_Desktop.h>
+#include <SUIT_MessageBox.h>
#include <SUIT_Session.h>
#include <QtxDoubleSpinBox.h>
aTransformLayout->addWidget( aLambertLabel, 2, 3, 1, 6 );
aTransformLayout->addWidget( aRefImageLabel, 2, 3, 1, 6 );
- connect( aManualCartesianBtn, SIGNAL( toggled( bool ) ), aGeodesicLabel, SLOT( setVisible ( bool ) ) );
- connect( aManualCartesianBtn, SIGNAL( toggled( bool ) ), aLambertLabel, SLOT( setHidden ( bool ) ) );
+ connect( aManualCartesianBtn, SIGNAL( toggled( bool ) ), aLambertLabel, SLOT( setVisible ( bool ) ) );
+ connect( aManualCartesianBtn, SIGNAL( toggled( bool ) ), aGeodesicLabel, SLOT( setHidden ( bool ) ) );
connect( aManualCartesianBtn, SIGNAL( toggled( bool ) ), aRefImageLabel, SLOT( setHidden ( bool ) ) );
- connect( aManualGeodesicBtn, SIGNAL( toggled( bool ) ), aLambertLabel, SLOT( setVisible ( bool ) ) );
- connect( aManualGeodesicBtn, SIGNAL( toggled( bool ) ), aGeodesicLabel, SLOT( setHidden ( bool ) ) );
+ connect( aManualGeodesicBtn, SIGNAL( toggled( bool ) ), aGeodesicLabel, SLOT( setVisible ( bool ) ) );
+ connect( aManualGeodesicBtn, SIGNAL( toggled( bool ) ), aLambertLabel, SLOT( setHidden ( bool ) ) );
connect( aManualGeodesicBtn, SIGNAL( toggled( bool ) ), aRefImageLabel, SLOT( setHidden ( bool ) ) );
connect( aRefImageBtn, SIGNAL( toggled( bool ) ), aRefImageLabel, SLOT( setVisible ( bool ) ) );
connect( aRefImageBtn, SIGNAL( toggled( bool ) ), aGeodesicLabel, SLOT( setHidden ( bool ) ) );
QLabel* aPointYMinLabel = new QLabel( "'", myTransformGroup );
QLabel* aPointXSecLabel = new QLabel( "\"", myTransformGroup );
QLabel* aPointYSecLabel = new QLabel( "\"", myTransformGroup );
+ QLabel* aPointLatLabel = new QLabel( tr( "POINT_LATITUDE" ), myTransformGroup );
+ QLabel* aPointLonLabel = new QLabel( tr( "POINT_LONGITUDE" ), myTransformGroup );
myGeodesicLabels << aPointXDegLabel << aPointYDegLabel
<< aPointXMinLabel << aPointYMinLabel
- << aPointXSecLabel << aPointYSecLabel;
+ << aPointXSecLabel << aPointYSecLabel
+ << aPointLonLabel << aPointLatLabel;
- QtxIntSpinBox* aPointXDeg = new QtxIntSpinBox( -180, 180, 1, myTransformGroup );
- QtxIntSpinBox* aPointYDeg = new QtxIntSpinBox( -90, 90, 1, myTransformGroup );
+ QtxIntSpinBox* aPointXDeg = new QtxIntSpinBox( -179, 179, 1, myTransformGroup );
+ QtxIntSpinBox* aPointYDeg = new QtxIntSpinBox( 0, 89, 1, myTransformGroup );
QtxIntSpinBox* aPointXMin = new QtxIntSpinBox( 0, 59, 1, myTransformGroup );
QtxIntSpinBox* aPointYMin = new QtxIntSpinBox( 0, 59, 1, myTransformGroup );
QtxDoubleSpinBox* aPointXSec = new QtxDoubleSpinBox( 0, 59.9999, 1, 4, 4, myTransformGroup );
{
myPointCEnabler = new QCheckBox( myTransformGroup );
aTransformLayout->addWidget( myPointCEnabler, aRow, 0, 1, 2, Qt::AlignHCenter );
- aTransformLayout->addWidget( aPointBtn, aRow, 2, 1, 7 );
+ aTransformLayout->addWidget( aPointBtn, aRow, 2, 1, 8 );
}
else
{
- aTransformLayout->addWidget( aPointBtn, aRow, 0, 1, 9 );
+ aTransformLayout->addWidget( aPointBtn, aRow, 0, 1, 10 );
}
aTransformLayout->addWidget( aPointXLabel, aRow + 1, 0 );
aTransformLayout->addWidget( aPointXMinLabel, aRow + 1, 6 );
aTransformLayout->addWidget( aPointXSec, aRow + 1, 7 );
aTransformLayout->addWidget( aPointXSecLabel, aRow + 1, 8 );
+ aTransformLayout->addWidget( aPointLonLabel, aRow + 1, 9 );
aTransformLayout->addWidget( aCartPointX, aRow + 1, 3, 1, 6 );
aTransformLayout->addWidget( aRefPointX, aRow + 1, 3, 1, 6 );
aTransformLayout->addWidget( aPointYMinLabel, aRow + 2, 6 );
aTransformLayout->addWidget( aPointYSec, aRow + 2, 7 );
aTransformLayout->addWidget( aPointYSecLabel, aRow + 2, 8 );
+ aTransformLayout->addWidget( aPointLatLabel, aRow + 2, 9 );
aTransformLayout->addWidget( aCartPointY, aRow + 2, 3, 1, 6 );
aTransformLayout->addWidget( aRefPointY, aRow + 2, 3, 1, 6 );
QFrame* aLine = new QFrame( myTransformGroup );
aLine->setFrameShape( QFrame::HLine );
aLine->setFrameShadow( QFrame::Sunken );
- aTransformLayout->addWidget( aLine, aRow + 3, 0, 1, 9 );
+ aTransformLayout->addWidget( aLine, aRow + 3, 0, 1, 10 );
}
myPointBtnMap[ aPointType ] = aPointBtn;
connect( myPointCEnabler, SIGNAL( toggled( bool ) ), myRefPointXMap[ HYDROGUI_PrsImage::PointC ], SLOT( setEnabled( bool ) ) );
connect( myPointCEnabler, SIGNAL( toggled( bool ) ), myRefPointYMap[ HYDROGUI_PrsImage::PointC ], SLOT( setEnabled( bool ) ) );
+ connect( myPointCEnabler, SIGNAL( toggled( bool ) ), SLOT( onSetCIsUsed( bool ) ) );
+
aTransformLayout->setColumnStretch( 1, 1 ); // double
aTransformLayout->setColumnStretch( 3, 1 ); // degrees
aTransformLayout->setColumnStretch( 5, 1 ); // minutes
connect( myRefImage, SIGNAL( activated( const QString& ) ),
this, SLOT( onRefImageActivated( const QString& ) ) );
- setTransformationMode( HYDROData_Image::ManualGeodesic );
+ //setTransformationMode( HYDROData_Image::ManualCartesian );
setMinimumWidth( 350 );
}
{
}
+void HYDROGUI_ImportImageDlg::onSetCIsUsed( bool theCIsUsed )
+{
+ if ( !theCIsUsed && myPointBtnMap[ HYDROGUI_PrsImage::PointC ]->isChecked() )
+ {
+ // Turn on point A selection if point C selection has been activated and we disable point C.
+ myPointBtnMap[ HYDROGUI_PrsImage::PointA ]->toggle();
+ }
+ emit setCIsUsed( theCIsUsed );
+}
+
void HYDROGUI_ImportImageDlg::setIsEdit( const bool theIsEdit )
{
myFileNameGroup->setVisible( !theIsEdit );
myCartPointXMap[ aPointType ]->clear();
myCartPointYMap[ aPointType ]->clear();
}
- myPointCEnabler->setChecked( true );
- myPointCEnabler->toggle();
+
+ // Emulate turning off C point usage
+ myPointCEnabler->blockSignals( true );
+
+ myPointCEnabler->setChecked( false );
+ myPointBtnMap[ HYDROGUI_PrsImage::PointC ]->setEnabled( false );
+ myPointXMap[ HYDROGUI_PrsImage::PointC ]->setEnabled( false );
+ myPointYMap[ HYDROGUI_PrsImage::PointC ]->setEnabled( false );
+ myPointXDegMap[ HYDROGUI_PrsImage::PointC ]->setEnabled( false );
+ myPointYDegMap[ HYDROGUI_PrsImage::PointC ]->setEnabled( false );
+ myPointXMinMap[ HYDROGUI_PrsImage::PointC ]->setEnabled( false );
+ myPointYMinMap[ HYDROGUI_PrsImage::PointC ]->setEnabled( false );
+ myPointXSecMap[ HYDROGUI_PrsImage::PointC ]->setEnabled( false );
+ myPointYSecMap[ HYDROGUI_PrsImage::PointC ]->setEnabled( false );
+ myCartPointXMap[ HYDROGUI_PrsImage::PointC ]->setEnabled( false );
+ myCartPointYMap[ HYDROGUI_PrsImage::PointC ]->setEnabled( false );
+ myRefPointXMap[ HYDROGUI_PrsImage::PointC ]->setEnabled( false );
+ myRefPointYMap[ HYDROGUI_PrsImage::PointC ]->setEnabled( false );
+ onSetCIsUsed( false );
+
+ myPointCEnabler->blockSignals( false );
+
myTransformGroup->setEnabled( false );
myRefImage->clear();
- setTransformationMode( HYDROData_Image::ManualGeodesic );
+ setTransformationMode( HYDROData_Image::ManualCartesian );
myPrsPointDataList.clear();
int aXDeg = 0, aYDeg = 0;
int aXMin = 0, aYMin = 0;
double aXSec = 0, aYSec = 0;
- HYDROData_Lambert93::secToDMS( aLPoint.x(), aXDeg, aXMin, aXSec );
- HYDROData_Lambert93::secToDMS( aLPoint.y(), aYDeg, aYMin, aYSec );
+ HYDROData_Lambert93::degToDMS( aLPoint.x(), aXDeg, aXMin, aXSec );
+ HYDROData_Lambert93::degToDMS( aLPoint.y(), aYDeg, aYMin, aYSec );
myPointXDegMap[ aPointType ]->setValue( aXDeg );
myPointYDegMap[ aPointType ]->setValue( aYDeg );
return false;
double aX2 = 0, aY2 = 0;
- HYDROData_Lambert93::DMSToSec( aXDeg, aXMin, aXSec, aX2 );
- HYDROData_Lambert93::DMSToSec( aYDeg, aYMin, aYSec, aY2 );
+ HYDROData_Lambert93::DMSToDeg( aXDeg, aXMin, aXSec, aX2 );
+ HYDROData_Lambert93::DMSToDeg( aYDeg, aYMin, aYSec, aY2 );
TransformationData aData( QPoint( aX1, aY1 ), QPointF( aX2, aY2 ), QPointF( aXCart, aYCart ) );
theMap[ aPointType ] = aData;
myPointBtnMap[ HYDROGUI_PrsImage::PointA ]->setChecked( true );
- // ouv: tmp
- /*
- blockSignalsGeodesic( true );
-
- myPointXDegMap[ HYDROGUI_PrsImage::PointA ]->setValue( 50 );
- myPointXMinMap[ HYDROGUI_PrsImage::PointA ]->setValue( 0 );
- myPointXSecMap[ HYDROGUI_PrsImage::PointA ]->setValue( 0 );
- myPointYDegMap[ HYDROGUI_PrsImage::PointA ]->setValue( 50 );
- myPointYMinMap[ HYDROGUI_PrsImage::PointA ]->setValue( 0 );
- myPointYSecMap[ HYDROGUI_PrsImage::PointA ]->setValue( 0 );
-
- myPointXDegMap[ HYDROGUI_PrsImage::PointB ]->setValue( 50 );
- myPointXMinMap[ HYDROGUI_PrsImage::PointB ]->setValue( 1 );
- myPointXSecMap[ HYDROGUI_PrsImage::PointB ]->setValue( 0 );
- myPointYDegMap[ HYDROGUI_PrsImage::PointB ]->setValue( 50 );
- myPointYMinMap[ HYDROGUI_PrsImage::PointB ]->setValue( 0 );
- myPointYSecMap[ HYDROGUI_PrsImage::PointB ]->setValue( 0 );
-
- myPointXDegMap[ HYDROGUI_PrsImage::PointC ]->setValue( 50 );
- myPointXMinMap[ HYDROGUI_PrsImage::PointC ]->setValue( 0 );
- myPointXSecMap[ HYDROGUI_PrsImage::PointC ]->setValue( 0 );
- myPointYDegMap[ HYDROGUI_PrsImage::PointC ]->setValue( 50 );
- myPointYMinMap[ HYDROGUI_PrsImage::PointC ]->setValue( 1 );
- myPointYSecMap[ HYDROGUI_PrsImage::PointC ]->setValue( 0 );
-
- for( int aPointType = HYDROGUI_PrsImage::PointA;
- aPointType <= HYDROGUI_PrsImage::PointC; aPointType++ )
- onGeodesicCoordChanged( aPointType );
-
- blockSignalsGeodesic( false );
- */
-
- //double aCartX0 = 600000;
- //double aCartY0 = 6800000;
- double aCartX0 = 0;
- double aCartY0 = 0;
+ double aCartX0 = LAMBERT_X0;
+ double aCartY0 = LAMBERT_Y0;
blockSignalsCartesian( true );
myCartPointXMap[ HYDROGUI_PrsImage::PointA ]->setValue( aCartX0 );
- myCartPointYMap[ HYDROGUI_PrsImage::PointA ]->setValue( aCartY0 + 500 );
+ myCartPointYMap[ HYDROGUI_PrsImage::PointA ]->setValue( aCartY0 + IMG_DELTA );
- myCartPointXMap[ HYDROGUI_PrsImage::PointB ]->setValue( aCartX0 + 500 );
- myCartPointYMap[ HYDROGUI_PrsImage::PointB ]->setValue( aCartY0 + 500 );
+ myCartPointXMap[ HYDROGUI_PrsImage::PointB ]->setValue( aCartX0 + IMG_DELTA );
+ myCartPointYMap[ HYDROGUI_PrsImage::PointB ]->setValue( aCartY0 + IMG_DELTA );
myCartPointXMap[ HYDROGUI_PrsImage::PointC ]->setValue( aCartX0 );
myCartPointYMap[ HYDROGUI_PrsImage::PointC ]->setValue( aCartY0 );
{
// Geodesic to Cartesian
double aXCart = 0, aYCart = 0;
- HYDROData_Lambert93::toXY( arx, ary, aXCart, aYCart );
+ // Interpreting arY as attitude and arX as longitude
+ HYDROData_Lambert93::toXY( ary, arx, aXCart, aYCart );
aResTrsfData.GeodesicPoint = theGlobalPoint;
aResTrsfData.CartesianPoint = QPointF( aXCart, aYCart );
if( !aFileName.isEmpty() )
{
QImage anImage( aFileName );
- if( !anImage.isNull() )
+ if( anImage.isNull() )
+ {
+ QString aTitle = QObject::tr( "INPUT_VALID_DATA" );
+ QString aMessage = QObject::tr( "FILE_CAN_NOT_BE_IMPORTED" ).
+ arg( aFileName ).arg( QFileInfo( aFileName ).suffix() );
+ SUIT_MessageBox::warning( module()->getApp()->desktop(), aTitle, aMessage );
+ }
+ else
{
myFileName->setText( aFileName );
emit createPreview( anImage );