X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FSketchPlugin%2FSketchPlugin_Feature.h;h=2f386d18d4e63e8275bd0f32c7a897f3987b21b8;hb=20d233731eaae06b9a75280a2ca675bc9a11cc72;hp=d51301880a14e01c6c9d345275f577a13dbbd88e;hpb=af168c107750e3c62fc487ae55b3ac9a1ab67435;p=modules%2Fshaper.git diff --git a/src/SketchPlugin/SketchPlugin_Feature.h b/src/SketchPlugin/SketchPlugin_Feature.h index d51301880..2f386d18d 100644 --- a/src/SketchPlugin/SketchPlugin_Feature.h +++ b/src/SketchPlugin/SketchPlugin_Feature.h @@ -1,3 +1,5 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D --> + // File: SketchPlugin_Feature.h // Created: 27 Mar 2014 // Author: Mikhail PONIKAROV @@ -6,36 +8,34 @@ #define SketchPlugin_Feature_H_ #include "SketchPlugin.h" -#include +#include #include #include #include +#include +#include + +#include class SketchPlugin_Sketch; -class GeomAPI_Pnt2d; class Handle_AIS_InteractiveObject; /**\class SketchPlugin_Feature - * \ingroup DataModel + * \ingroup Plugins * \brief Feature for creation of the new feature in PartSet. This is an abstract class to give * an interface to create the sketch feature preview. */ class SketchPlugin_Feature : public ModelAPI_Feature { public: - /// Simple creation of interactive object by the result of the object - static AISObjectPtr simpleAISObject(boost::shared_ptr theRes, - AISObjectPtr thePrevious); - - /// 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 true if this feature must be displayed in the history (top level of Part tree) + SKETCHPLUGIN_EXPORT virtual bool isInHistory() { + return false; } - ; - /// Returns true if this feature must be displayed in the history (top level of Part tree) - SKETCHPLUGIN_EXPORT virtual bool isInHistory() + /// Returns true of the feature is created basing on the external shape of not-this-sketch object + SKETCHPLUGIN_EXPORT virtual bool isExternal() const { return false; } @@ -45,28 +45,27 @@ class SketchPlugin_Feature : public ModelAPI_Feature /// \param theDeltaY the delta for Y coordinate is moved SKETCHPLUGIN_EXPORT virtual void move(const double theDeltaX, const double theDeltaY) = 0; - /// Return the distance between the feature and the point - /// \param thePoint the point - virtual double distanceToPoint(const boost::shared_ptr& thePoint) = 0; - /// Construction result is allways recomuted on the fly SKETCHPLUGIN_EXPORT virtual bool isPersistentResult() {return false;} + /// Returns true is sketch element is under the rigid constraint + SKETCHPLUGIN_EXPORT virtual bool isFixed() {return false;} + + /// Returns the sketch of this feature + SketchPlugin_Sketch* sketch(); protected: /// Sets the higher-level feature for the sub-feature (sketch for line) void setSketch(SketchPlugin_Sketch* theSketch) { mySketch = theSketch; } - /// Returns the sketch of this feature - SketchPlugin_Sketch* sketch(); /// initializes mySketch SketchPlugin_Feature(); friend class SketchPlugin_Sketch; private: - boost::shared_ptr myPreview; ///< the preview shape + std::shared_ptr myPreview; ///< the preview shape SketchPlugin_Sketch* mySketch; /// sketch that contains this feature };