Salome HOME
Simplified calculation of fly out distance and creation of constraints limited only...
[modules/shaper.git] / src / SketchPlugin / SketchPlugin_Arc.h
1 // Copyright (C) 2014-20xx CEA/DEN, EDF R&D -->
2
3 // File:        SketchPlugin_Arc.h
4 // Created:     26 May 2014
5 // Author:      Artem ZHIDKOV
6
7 #ifndef SketchPlugin_Arc_H_
8 #define SketchPlugin_Arc_H_
9
10 #include "SketchPlugin.h"
11 #include <SketchPlugin_SketchEntity.h>
12 #include <SketchPlugin_Sketch.h>
13 #include <GeomAPI_IPresentable.h>
14
15 /**\class SketchPlugin_Arc
16  * \ingroup Plugins
17  * \brief Feature for creation of the new arc of circle in PartSet.
18  * The visualization of this object is separated in two parts. The first one is an AIS object
19  * calculated when there is non-initialized attributes of the arc. The second is a result and
20  * it is calculated if all attributes are initialized.
21  */
22 class SketchPlugin_Arc : public SketchPlugin_SketchEntity, public GeomAPI_IPresentable
23 {
24   /// to avoid cyclic dependencies in automatic updates: they mean that 
25   /// update is performed right now and automatic updates are not needed
26   bool myStartUpdate, myEndUpdate;
27   /// to avoid (if possible) additional modification of changed coordinate (issue #855)
28   double myXEndBefore, myYEndBefore;
29
30   /// to define in which direction draw arc
31   bool myForwardDirection;
32   double myParamBefore;
33
34  public:
35   /// Arc feature kind
36   inline static const std::string& ID()
37   {
38     static const std::string MY_SKETCH_ARC_ID("SketchArc");
39     return MY_SKETCH_ARC_ID;
40   }
41
42   /// Central 2D point of the circle which contains the arc
43   inline static const std::string& CENTER_ID()
44   {
45     static const std::string MY_CENTER_ID = "ArcCenter";
46     return MY_CENTER_ID;
47   }
48   /// Start 2D point of the arc
49   inline static const std::string& START_ID()
50   {
51     static const std::string MY_START_ID = "ArcStartPoint";
52     return MY_START_ID;
53   }
54   /// End 2D point of the arc
55   inline static const std::string& END_ID()
56   {
57     static const std::string MY_END_ID = "ArcEndPoint";
58     return MY_END_ID;
59   }
60
61   /// Returns the kind of a feature
62   SKETCHPLUGIN_EXPORT virtual const std::string& getKind()
63   {
64     static std::string MY_KIND = SketchPlugin_Arc::ID();
65     return MY_KIND;
66   }
67
68   /// Returns true is sketch element is under the rigid constraint
69   SKETCHPLUGIN_EXPORT virtual bool isFixed();
70
71   /// Creates an arc-shape
72   SKETCHPLUGIN_EXPORT virtual void execute();
73
74   /// Request for initialization of data model of the feature: adding all attributes
75   SKETCHPLUGIN_EXPORT virtual void initAttributes();
76
77   /// Called on change of any argument-attribute of this object
78   /// \param theID identifier of changed attribute
79   SKETCHPLUGIN_EXPORT virtual void attributeChanged(const std::string& theID);
80
81   /// Returns the AIS preview
82   virtual AISObjectPtr getAISObject(AISObjectPtr thePrevious);
83
84   /// Moves the feature
85   /// \param theDeltaX the delta for X coordinate is moved
86   /// \param theDeltaY the delta for Y coordinate is moved
87   SKETCHPLUGIN_EXPORT virtual void move(const double theDeltaX, const double theDeltaY);
88
89   /// Use plugin manager for features creation
90   SketchPlugin_Arc();
91
92 private:
93   /// Returns true if all obligatory attributes are initialized
94   bool isFeatureValid();
95 };
96
97 #endif