Salome HOME
Image positioning by two points.
[modules/hydro.git] / src / HYDROGUI / HYDROGUI_ImportImageDlg.h
index e69de29bb2d1d6434b8b29ae775ad8c2e48c5391..3473fdfb89352a94fb21dcf89266895067b08430 100644 (file)
@@ -0,0 +1,173 @@
+// Copyright (C) 2007-2013  CEA/DEN, EDF R&D, OPEN CASCADE
+//
+// Copyright (C) 2003-2007  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
+// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
+//
+// This library is free software; you can redistribute it and/or
+// modify it under the terms of the GNU Lesser General Public
+// License as published by the Free Software Foundation; either
+// version 2.1 of the License.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+// Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public
+// License along with this library; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
+//
+// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
+//
+
+#ifndef HYDROGUI_IMPORTIMAGEDLG_H
+#define HYDROGUI_IMPORTIMAGEDLG_H
+
+#include "HYDROGUI_InputPanel.h"
+
+#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:
+  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                       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();
+
+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( 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*                 myImageNameGroup;
+  QLineEdit*                 myImageName;
+
+  QGroupBox*                 myTransformGroup;
+
+  QButtonGroup*              myModeGroup;
+  QComboBox*                 myRefImage;
+
+  QList<QLabel*>             myLambertLabels;
+
+  QMap<int, QPushButton*>    myPointBtnMap;
+  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