X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSet%2FPartSet_OperationSketch.h;h=d3ede8b3d0aec290ccf814e72e9da2674092557c;hb=29083ee3765ce3f564eb4fa6c93620084acfb067;hp=27c0d8641db489ef85cde4dce263e84cc9f3386b;hpb=f92ef94e9723207fc5b8421f4644e281c5e69d42;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_OperationSketch.h b/src/PartSet/PartSet_OperationSketch.h index 27c0d8641..d3ede8b3d 100644 --- a/src/PartSet/PartSet_OperationSketch.h +++ b/src/PartSet/PartSet_OperationSketch.h @@ -18,15 +18,18 @@ class Handle_AIS_InteractiveObject; /*! \class PartSet_OperationSketch * \brief The operation for the sketch feature creation -*/ + */ class PARTSET_EXPORT PartSet_OperationSketch : public PartSet_OperationSketchBase { - Q_OBJECT -public: +Q_OBJECT + public: /// Returns the operation type key - static std::string Type() { return SKETCH_KIND; } + static std::string Type() + { + return SketchPlugin_Sketch::ID(); + } -public: + public: /// Constructor /// \param theId the feature identifier /// \param theParent the operation parent @@ -34,21 +37,13 @@ public: /// Destructor virtual ~PartSet_OperationSketch(); - /// Returns the operation local selection mode - /// \param theFeature the feature object to get the selection mode - /// \return the selection mode - virtual std::list getSelectionModes(FeaturePtr theFeature) const; + /// Returns True if the given operation is a Sketcher operation + virtual bool isGranted(ModuleBase_Operation* theOperation) const; - /// Initializes some fields accorging to the feature - /// \param theSelected the list of selected presentations - /// \param theHighlighted the list of highlighted presentations - virtual void init(FeaturePtr theFeature, - const std::list& theSelected, - const std::list& theHighlighted); /// Returns the operation sketch feature /// \returns the sketch instance - virtual FeaturePtr sketch() const; + virtual CompositeFeaturePtr sketch() const; /// Processes the mouse pressed in the point /// \param theEvent the mouse event @@ -56,26 +51,25 @@ public: /// \param theSelected the list of selected presentations /// \param theHighlighted the list of highlighted presentations virtual void mousePressed(QMouseEvent* theEvent, Handle_V3d_View theView, - const std::list& theSelected, - const std::list& theHighlighted); + const std::list& theSelected, + const std::list& theHighlighted); /// Processes the mouse release in the point /// \param theEvent the mouse event /// \param theView a viewer to have the viewer the eye position /// \param theSelected the list of selected presentations /// \param theHighlighted the list of highlighted presentations virtual void mouseReleased(QMouseEvent* theEvent, Handle_V3d_View theView, - const std::list& theSelected, - const std::list& theHighlighted); + const std::list& theSelected, + const std::list& theHighlighted); /// Gives the current mouse point in the viewer /// \param thePoint a point clicked in the viewer /// \param theEvent the mouse event virtual void mouseMoved(QMouseEvent* theEvent, Handle_V3d_View theView); - /// Returns the map of the operation previews including the nested feature previews - /// \return the map of feature to the feature preview - virtual std::map > - subPreview() const; + /// Returns the list of the nested features + /// \return the list of subfeatures + virtual std::list subFeatures() const; /// Virtual method called when operation stopped - committed or aborted. /// Emits a signal to hide the preview of the operation @@ -87,6 +81,18 @@ public: /// \return enabled state virtual bool isNestedOperationsEnabled() const; + /// Returns whether the sketch plane is set + /// \return the boolean value whether the sketch is set + bool hasSketchPlane() const; + + /// Set the plane to the current sketch + /// \param theShape the shape + void setSketchPlane(const TopoDS_Shape& theShape); + + /// If operation needs to redisplay its result during operation + /// then this method has to return True + virtual bool hasPreview() const { return false; } + signals: /// signal about the sketch plane is selected /// \param theX the value in the X direction of the plane @@ -96,21 +102,16 @@ signals: // signal about the viewer fit all perform void fitAllView(); -protected: + protected: /// Virtual method called when operation started (see start() method for more description) /// Default impl calls corresponding slot and commits immediately. virtual void startOperation(); - /// Returns whether the sketch plane is set - /// \return the boolean value whether the sketch is set - bool hasSketchPlane() const; - - /// Set the plane to the current sketch - /// \param theShape the shape - void setSketchPlane(const TopoDS_Shape& theShape); + /// Virtual method called after operation committed (see commit() method for more description) + virtual void afterCommitOperation(); -private: - std::list myFeatures; ///< the features to apply the edit operation + private: + std::list myFeatures; ///< the features to apply the edit operation }; #endif