/*!
\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
/// Destructor
virtual ~PartSet_OperationSketch();
+ /// Returns True if the given operation is a Sketcher operation
+ virtual bool isValid(ModuleBase_IOperation* theOperation) const;
+
+
/// Returns the operation local selection mode
/// \param theFeature the feature object to get the selection mode
/// \return the selection mode
- virtual std::list<int> getSelectionModes(FeaturePtr theFeature) const;
+ virtual std::list<int> getSelectionModes(ObjectPtr theFeature) const;
/// Initializes the operation with previously created feature. It is used in sequental operations
virtual void initFeature(FeaturePtr theFeature);
/// \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<XGUI_ViewerPrs>& theSelected,
- const std::list<XGUI_ViewerPrs>& theHighlighted);
+ const std::list<ModuleBase_ViewerPrs>& theSelected,
+ const std::list<ModuleBase_ViewerPrs>& 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<XGUI_ViewerPrs>& theSelected,
- const std::list<XGUI_ViewerPrs>& theHighlighted);
+ const std::list<ModuleBase_ViewerPrs>& theSelected,
+ const std::list<ModuleBase_ViewerPrs>& 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<FeaturePtr, boost::shared_ptr<GeomAPI_Shape> >
- subPreview() const;
+ /// Returns the list of the nested features
+ /// \return the list of subfeatures
+ virtual std::list<FeaturePtr> subFeatures() const;
/// Virtual method called when operation stopped - committed or aborted.
/// Emits a signal to hide the preview of the operation
/// \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);
+
signals:
/// signal about the sketch plane is selected
/// \param theX the value in the X direction of the plane
// 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);
-
-private:
- std::list<XGUI_ViewerPrs> myFeatures; ///< the features to apply the edit operation
+ private:
+ std::list<ModuleBase_ViewerPrs> myFeatures; ///< the features to apply the edit operation
};
#endif