]> SALOME platform Git repositories - modules/shaper.git/blob - src/PartSet/PartSet_OperationSketchLine.h
Salome HOME
refs #30 - Sketch base GUI: create, draw lines
[modules/shaper.git] / src / PartSet / PartSet_OperationSketchLine.h
1 // File:        PartSet_OperationSketchLine.h
2 // Created:     20 Apr 2014
3 // Author:      Natalia ERMOLAEVA
4
5 #ifndef PartSet_OperationSketchLine_H
6 #define PartSet_OperationSketchLine_H
7
8 #include "PartSet.h"
9
10 #include <PartSet_OperationSketchBase.h>
11 #include <QObject>
12
13 class GeomDataAPI_Point2D;
14 class QMouseEvent;
15
16 /*!
17  \class PartSet_OperationSketchLine
18  * \brief The operation for the sketch feature creation
19 */
20 class PARTSET_EXPORT PartSet_OperationSketchLine : public PartSet_OperationSketchBase
21 {
22   Q_OBJECT
23
24 public:
25   /// Returns the operation type key
26   static std::string Type() { return "SketchLine"; }
27
28 public:
29   /// Constructor
30   /// \param theId the feature identifier
31   /// \param theParent the operation parent
32   /// \param theFeature the parent feature
33   PartSet_OperationSketchLine(const QString& theId, QObject* theParent,
34                               boost::shared_ptr<ModelAPI_Feature> theSketchFeature);
35   /// Destructor
36   virtual ~PartSet_OperationSketchLine();
37
38    /// Returns that this operator can be started above already running one.
39    /// The runned operation should be the sketch feature modified operation
40   /// \param theOperation the previous running operation
41   virtual bool isGranted(ModuleBase_IOperation* theOperation) const;
42
43   /// Returns the operation local selection mode
44   /// \param theFeature the feature object to get the selection mode
45   /// \return the selection mode
46   virtual std::list<int> getSelectionModes(boost::shared_ptr<ModelAPI_Feature> theFeature) const;
47
48   /// Initializes some fields accorging to the feature
49   /// \param theSelected the list of selected presentations
50   /// \param theHighlighted the list of highlighted presentations
51   virtual void init(boost::shared_ptr<ModelAPI_Feature> theFeature,
52                     const std::list<XGUI_ViewerPrs>& theSelected,
53                     const std::list<XGUI_ViewerPrs>& theHighlighted);
54
55   /// Returns the operation sketch feature
56   /// \returns the sketch instance
57   virtual boost::shared_ptr<ModelAPI_Feature> sketch() const;
58
59   /// Gives the current selected objects to be processed by the operation
60   /// \param theEvent the mouse event
61   /// \param theView a viewer to have the viewer the eye position
62   /// \param theSelected the list of selected presentations
63   /// \param theHighlighted the list of highlighted presentations
64  virtual void mouseReleased(QMouseEvent* theEvent, Handle_V3d_View theView,
65                             const std::list<XGUI_ViewerPrs>& theSelected,
66                             const std::list<XGUI_ViewerPrs>& theHighlighted);
67   /// Gives the current mouse point in the viewer
68   /// \param thePoint a point clicked in the viewer
69   /// \param theEvent the mouse event
70   virtual void mouseMoved(QMouseEvent* theEvent, Handle_V3d_View theView);
71   /// Processes the key pressed in the view
72   /// \param theKey a key value
73   virtual void keyReleased(const int theKey);
74
75 protected:
76   /// \brief Virtual method called when operation is started
77   /// Virtual method called when operation started (see start() method for more description)
78   /// After the parent operation body perform, set sketch feature to the created line feature
79   virtual void startOperation();
80
81   /// Virtual method called when operation aborted (see abort() method for more description)
82   /// Before the feature is aborted, it should be hidden from the viewer
83   virtual void abortOperation();
84
85   /// Virtual method called when operation stopped - committed or aborted.
86   /// Restore the multi selection state
87   virtual void stopOperation();
88
89   /// Creates an operation new feature
90   /// In addition to the default realization it appends the created line feature to
91   /// the sketch feature
92   /// \returns the created feature
93   virtual boost::shared_ptr<ModelAPI_Feature> createFeature();
94
95   /// Creates a constraint on two points
96   /// \param thePoint1 the first point
97   /// \param thePoint1 the second point
98   void createConstraint(boost::shared_ptr<GeomDataAPI_Point2D> thePoint1,
99                         boost::shared_ptr<GeomDataAPI_Point2D> thePoint2);
100
101   /// Creates constrains of the current 
102   /// \param theX the horizontal coordnate of the point
103   /// \param theY the vertical coordnate of the point
104   void setConstraints(double theX, double theY);
105 protected:
106   /// \brief Get the line point 2d coordinates.
107   /// \param theFeature the line feature
108   /// \param theAttribute the start or end attribute of the line
109   /// \param theX the horizontal coordinate
110   /// \param theY the vertical coordinate
111   void getLinePoint(boost::shared_ptr<ModelAPI_Feature> theFeature, const std::string& theAttribute,
112                     double& theX, double& theY);
113   /// Find a point in the line with given coordinates
114   /// \param theFeature the line feature
115   /// \param theX the horizontal point coordinate
116   /// \param theY the vertical point coordinate
117   boost::shared_ptr<GeomDataAPI_Point2D> findLinePoint(boost::shared_ptr<ModelAPI_Feature> theFeature,
118                                                        double theX, double theY);
119
120   /// \brief Save the point to the line.
121   /// \param theFeature the line feature
122   /// \param theX the horizontal coordinate
123   /// \param theY the vertical coordinate
124   /// \param theAttribute the start or end attribute of the line
125   void setLinePoint(boost::shared_ptr<ModelAPI_Feature>, double theX, double theY,
126                     const std::string& theAttribute);
127   /// \brief Save the point to the line.
128   /// \param thePoint the 3D point in the viewer
129   /// \param theAttribute the start or end attribute of the line
130   void setLinePoint(const gp_Pnt& thePoint, Handle(V3d_View) theView, const std::string& theAttribute);
131
132 protected:
133   ///< Structure to lists the possible types of point selection modes
134   enum PointSelectionMode {SM_FirstPoint, SM_SecondPoint, SM_DonePoint};
135
136 private:
137   boost::shared_ptr<ModelAPI_Feature> mySketch; ///< the sketch feature
138   boost::shared_ptr<GeomDataAPI_Point2D> myInitPoint; ///< the first line point
139   PointSelectionMode myPointSelectionMode; ///< point selection mode
140 };
141
142 #endif