X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FSketchPlugin%2FSketchPlugin_Arc.h;h=df87c1e3c2b616895a1ddcdaaa9acda36ba5fad4;hb=7ffe38811ecbbe6c270f2153c1825fe9c510d69f;hp=b40024b8bad181b235bb3e15a30c9c38b7c6903d;hpb=59b3db4a19c10138bf23f01f0c5ca7a28a3b8949;p=modules%2Fshaper.git diff --git a/src/SketchPlugin/SketchPlugin_Arc.h b/src/SketchPlugin/SketchPlugin_Arc.h index b40024b8b..df87c1e3c 100644 --- a/src/SketchPlugin/SketchPlugin_Arc.h +++ b/src/SketchPlugin/SketchPlugin_Arc.h @@ -9,16 +9,6 @@ #include #include -/// Arc feature kind -const std::string SKETCH_ARC_KIND("SketchArc"); - -/// Central 2D point of the circle which contains the arc -const std::string ARC_ATTR_CENTER("ArcCenter"); -/// Start 2D point of the arc -const std::string ARC_ATTR_START("ArcStartPoint"); -/// End 2D point of the arc -const std::string ARC_ATTR_END("ArcEndPoint"); - /**\class SketchPlugin_Arc * \ingroup DataModel * \brief Feature for creation of the new arc of circle in PartSet. @@ -26,27 +16,46 @@ const std::string ARC_ATTR_END("ArcEndPoint"); class SketchPlugin_Arc: public SketchPlugin_Feature { public: + /// Arc feature kind + inline static const std::string& ID() + { + static const std::string MY_SKETCH_ARC_ID("SketchArc"); + return MY_SKETCH_ARC_ID; + } + + /// Central 2D point of the circle which contains the arc + inline static const std::string& CENTER_ID() + { + static const std::string MY_CENTER_ID = "ArcCenter"; + return MY_CENTER_ID; + } + /// Start 2D point of the arc + inline static const std::string& START_ID() + { + static const std::string MY_START_ID = "ArcStartPoint"; + return MY_START_ID; + } + /// End 2D point of the arc + inline static const std::string& END_ID() + { + static const std::string MY_END_ID = "ArcEndPoint"; + return MY_END_ID; + } + /// Returns the kind of a feature SKETCHPLUGIN_EXPORT virtual const std::string& getKind() - {static std::string MY_KIND = SKETCH_ARC_KIND; return MY_KIND;} - - /// Returns to which group in the document must be added feature - SKETCHPLUGIN_EXPORT virtual const std::string& getGroup() - {static std::string MY_GROUP = SKETCH_KIND; return MY_GROUP;} + {static std::string MY_KIND = SketchPlugin_Arc::ID(); return MY_KIND;} - /// Creates a new part document if needed + /// Creates an arc-shape SKETCHPLUGIN_EXPORT virtual void execute(); /// Request for initialization of data model of the feature: adding all attributes SKETCHPLUGIN_EXPORT virtual void initAttributes(); - /// Returns the sketch preview - SKETCHPLUGIN_EXPORT virtual const boost::shared_ptr& preview(); - - /// Adds sub-feature of the higher level feature (sub-element of the sketch) - /// \param theFeature sub-feature - SKETCHPLUGIN_EXPORT virtual const void addSub( - const FeaturePtr& theFeature) {}; + /// Returns the AIS preview + virtual boost::shared_ptr getAISObject( + boost::shared_ptr thePrevious) + {return simpleAISObject(firstResult(), thePrevious);} /// Moves the feature /// \param theDeltaX the delta for X coordinate is moved