#include <QMap>
+class QButtonGroup;
+class QComboBox;
class QGroupBox;
+class QLabel;
class QLineEdit;
+class QCheckBox;
+
+class QtxDoubleSpinBox;
+class QtxIntSpinBox;
class HYDROGUI_ImportImageDlg : public HYDROGUI_InputPanel
{
Q_OBJECT
public:
- typedef QPair< QPoint, QPointF > TransformationData;
+ struct TransformationData
+ {
+ QPoint ImagePoint;
+ QPointF LambertPoint;
+ QPointF CartesianPoint;
+
+ TransformationData() {}
+
+ TransformationData( const QPoint& theImagePoint ) :
+ ImagePoint( theImagePoint ) {}
+
+ TransformationData( const QPoint& theImagePoint,
+ const QPointF& theLambertPoint,
+ const QPointF& theCartesianPoint ) :
+ ImagePoint( theImagePoint ),
+ LambertPoint( theLambertPoint ),
+ CartesianPoint( theCartesianPoint ) {}
+ };
typedef QMap< int, TransformationData > TransformationDataMap;
+ typedef QPair< QString, TransformationDataMap > PrsPointData;
+ typedef QList< PrsPointData > PrsPointDataList;
+ typedef QListIterator< PrsPointData > PrsPointDataListIterator;
+
public:
HYDROGUI_ImportImageDlg( HYDROGUI_Module* theModule, const QString& theTitle );
virtual ~HYDROGUI_ImportImageDlg();
+ void setIsEdit( const bool theIsEdit );
void reset();
- void setTransformationDataMap( const TransformationDataMap& theMap );
- bool getTransformationDataMap( TransformationDataMap& theMap ) const;
+ void setImageName( const QString& theName );
+ QString getImageName() const;
+
+ void setRefImageName( const QString& theName );
+ QString getRefImageName() const;
+
+ QString getFileName() const;
+
+ void setImageSize( const QSize& theSize,
+ const bool theIsRefImage = false );
+
+ void setTransformationMode( const int theMode );
+ int getTransformationMode() const;
+
+ void setByTwoPoints( const bool theIsByTwoPoints );
+ bool isByTwoPoints() const;
+
+ void setTransformationDataMap( const TransformationDataMap& theMap,
+ const bool theIsOnlyInput = false,
+ const bool theIsRefImage = false );
+ bool getTransformationDataMap( TransformationDataMap& theMap,
+ const bool theIsRefImage = false ) const;
+
+ void setPrsPointDataList( const PrsPointDataList& theList );
void initializePointSelection();
- void synchronizeTransformedPoints();
+
+public:
+
+ static TransformationData ComputeTrsfData( const int theMode,
+ const QPoint& theLocalPoint,
+ const QPointF& theGlobalPoint );
protected slots:
void onBrowse();
+ void onModeActivated( int );
+ void onRefImageActivated( const QString& );
void onPointBtnToggled( bool );
+ void onPointCoordChanged( int );
+
+ void onLambertCoordChanged();
+ void onLambertCoordChanged( const int thePointType );
+
+ void onCartesianCoordChanged();
+ void onCartesianCoordChanged( const int thePointType );
+
+private:
+ void blockSignalsLambert( const bool theState );
+ void blockSignalsCartesian( const bool theState );
signals:
- void createPreview( QString );
+ void createPreview( QImage );
void activatePointSelection( int );
+ void pointCoordChanged( bool theIsRef,
+ int thePointType,
+ bool theIsY,
+ int theValue );
+ void modeActivated( int );
+ void refImageActivated( const QString& );
private:
+ QGroupBox* myFileNameGroup;
QLineEdit* myFileName;
- QGroupBox* myMappingGroup;
+ QGroupBox* myImageNameGroup;
+ QLineEdit* myImageName;
+
+ QGroupBox* myTransformGroup;
+
+ QButtonGroup* myModeGroup;
+ QComboBox* myRefImage;
+
+ QList<QLabel*> myLambertLabels;
+
QMap<int, QPushButton*> myPointBtnMap;
- QMap<int, QLineEdit*> myPointX1Map;
- QMap<int, QLineEdit*> myPointY1Map;
- QMap<int, QLineEdit*> myPointX2Map;
- QMap<int, QLineEdit*> myPointY2Map;
+ QMap<int, QtxIntSpinBox*> myPointXMap;
+ QMap<int, QtxIntSpinBox*> myPointYMap;
+ QMap<int, QtxIntSpinBox*> myPointXDegMap;
+ QMap<int, QtxIntSpinBox*> myPointYDegMap;
+ QMap<int, QtxIntSpinBox*> myPointXMinMap;
+ QMap<int, QtxIntSpinBox*> myPointYMinMap;
+ QMap<int, QtxDoubleSpinBox*> myPointXSecMap;
+ QMap<int, QtxDoubleSpinBox*> myPointYSecMap;
+
+ QMap<int, QtxDoubleSpinBox*> myCartPointXMap;
+ QMap<int, QtxDoubleSpinBox*> myCartPointYMap;
+
+ QMap<int, QtxIntSpinBox*> myRefPointXMap;
+ QMap<int, QtxIntSpinBox*> myRefPointYMap;
+
+ QCheckBox* myPointCEnabler;
+
+ PrsPointDataList myPrsPointDataList;
+
+ bool myIsInitialized;
};
#endif