X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FSketchPlugin%2FSketchPlugin_Feature.h;h=b8437dcbcaf7c3674d2399bc47ac87a5d4171668;hb=2e9c8b6bbbc29447cd5c68e9ca9f341d022bdd1b;hp=093bf025856dc9c656f6107eb5cc1517fd56f26c;hpb=96ff1d1fb2acb842cee193f15492de81060a1d58;p=modules%2Fshaper.git diff --git a/src/SketchPlugin/SketchPlugin_Feature.h b/src/SketchPlugin/SketchPlugin_Feature.h index 093bf0258..b8437dcbc 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,34 +8,38 @@ #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 +class SketchPlugin_Feature : public ModelAPI_Feature { -public: - /// Simple creation of interactive object by the result of the object - static boost::shared_ptr simpleAISObject( - boost::shared_ptr theRes, boost::shared_ptr 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) {}; - + public: /// Returns true if this feature must be displayed in the history (top level of Part tree) - SKETCHPLUGIN_EXPORT virtual bool isInHistory() {return false;} + SKETCHPLUGIN_EXPORT virtual bool isInHistory() + { + return false; + } + + /// 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; + } /// Moves the feature /// \param theDeltaX the delta for X coordinate is moved @@ -42,21 +48,30 @@ public: /// Return the distance between the feature and the point /// \param thePoint the point - virtual double distanceToPoint(const boost::shared_ptr& thePoint) = 0; + virtual double distanceToPoint(const std::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;} -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(); +protected: + /// Sets the higher-level feature for the sub-feature (sketch for line) + void setSketch(SketchPlugin_Sketch* theSketch) + { + mySketch = theSketch; + } /// initializes mySketch SketchPlugin_Feature(); friend class SketchPlugin_Sketch; -private: - boost::shared_ptr myPreview; ///< the preview shape - SketchPlugin_Sketch* mySketch; /// sketch that contains this feature + private: + std::shared_ptr myPreview; ///< the preview shape + SketchPlugin_Sketch* mySketch; /// sketch that contains this feature }; #endif