Salome HOME
Merge branch 'master' of newgeom:newgeom
[modules/shaper.git] / src / SketchPlugin / SketchPlugin_Line.h
1 // File:        SketchPlugin_Line.h
2 // Created:     24 Apr 2014
3 // Author:      Mikhail PONIKAROV
4
5 #ifndef SketchPlugin_Line_HeaderFile
6 #define SketchPlugin_Line_HeaderFile
7
8 #include "SketchPlugin.h"
9 #include <SketchPlugin_Feature.h>
10 #include <SketchPlugin_Sketch.h>
11 #include <list>
12
13 /**\class SketchPlugin_Line
14  * \ingroup DataModel
15  * \brief Feature for creation of the new part in PartSet.
16  */
17 class SketchPlugin_Line: public SketchPlugin_Feature
18 {
19 public:
20   /// Arc feature kind
21   inline static const std::string& ID()
22   {
23     static const std::string SKETCH_LINE_ID("SketchLine");
24     return SKETCH_LINE_ID;
25   }
26   /// Start 2D point of the line
27   inline static const std::string& START_ID()
28   {
29     static const std::string MY_START_ID("StartPoint");
30     return MY_START_ID;
31   }
32     /// End 2D point of the line
33   inline static const std::string& END_ID()
34   {
35     static const std::string MY_END_ID("EndPoint");
36     return MY_END_ID;
37   }
38
39   /// Returns the kind of a feature
40   SKETCHPLUGIN_EXPORT virtual const std::string& getKind() 
41   {static std::string MY_KIND = SketchPlugin_Line::ID(); return MY_KIND;}
42
43   /// Creates a new part document if needed
44   SKETCHPLUGIN_EXPORT virtual void execute();
45
46   /// Request for initialization of data model of the feature: adding all attributes
47   SKETCHPLUGIN_EXPORT virtual void initAttributes();
48
49   /// Returns the AIS preview
50   SKETCHPLUGIN_EXPORT virtual boost::shared_ptr<GeomAPI_AISObject> getAISObject(
51                                 boost::shared_ptr<GeomAPI_AISObject> thePrevious)
52   {return simpleAISObject(firstResult(), thePrevious);}
53
54   /// Moves the feature
55   /// \param theDeltaX the delta for X coordinate is moved
56   /// \param theDeltaY the delta for Y coordinate is moved
57   SKETCHPLUGIN_EXPORT virtual void move(const double theDeltaX, const double theDeltaY);
58
59   /// Return the distance between the feature and the point
60   /// \param thePoint the point
61   virtual double distanceToPoint(const boost::shared_ptr<GeomAPI_Pnt2d>& thePoint);
62
63   /// Use plugin manager for features creation
64   SketchPlugin_Line();
65 };
66
67 #endif