X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSet%2FPartSet_Module.h;h=a3a188ad0347ff9a10f376b7bc06d3f382f84928;hb=d22fc665c79c31c9eea0625e04c2e941adfdf7be;hp=0c39e68f814f91d7d946742f634daca3fd106c78;hpb=5d0a4d3dd908602b7673680523dfaad1962932e5;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_Module.h b/src/PartSet/PartSet_Module.h index 0c39e68f8..a3a188ad0 100644 --- a/src/PartSet/PartSet_Module.h +++ b/src/PartSet/PartSet_Module.h @@ -5,9 +5,10 @@ #include #include +#include #include -#include #include +#include #include #include @@ -16,8 +17,6 @@ #include -class QMouseEvent; -class QKeyEvent; class PartSet_Listener; class ModelAPI_Feature; class XGUI_ViewerPrs; @@ -45,11 +44,6 @@ Q_OBJECT /// \param theCmdId the operation name //virtual void launchOperation(const QString& theCmdId); - /// Activates the feature in the displayer - /// \param theFeature the feature instance to be displayed - /// \param isUpdateViewer the flag whether the viewer should be updated - void activateFeature(ObjectPtr theFeature, const bool isUpdateViewer); - /// Updates current operation preview, if it has it. /// \param theCmdId the operation name void updateCurrentPreview(const std::string& theCmdId); @@ -61,6 +55,10 @@ Q_OBJECT XGUI_Workshop* xWorkshop() const; + + /// Returns list of selection modes for the given object for sketch operation + static QIntList sketchSelectionModes(ObjectPtr theFeature); + public slots: void onFeatureTriggered(); /// SLOT, that is called after the operation is started. Connect on the focus activated signal @@ -70,26 +68,6 @@ Q_OBJECT void onOperationStopped(ModuleBase_Operation* theOperation); /// SLOT, that is called afetr the popup menu action clicked. void onContextMenuCommand(const QString& theId, bool isChecked); - /// SLOT, that is called by mouse press in the viewer. - /// The mouse released point is sent to the current operation to be processed. - /// \param theEvent the mouse event - void onMousePressed(QMouseEvent* theEvent); - /// SLOT, that is called by mouse release in the viewer. - /// The mouse released point is sent to the current operation to be processed. - /// \param theEvent the mouse event - void onMouseReleased(QMouseEvent* theEvent); - /// SLOT, that is called by mouse move in the viewer. - /// The mouse moved point is sent to the current operation to be processed. - /// \param theEvent the mouse event - void onMouseMoved(QMouseEvent* theEvent); - - /// SLOT, that is called by the key in the viewer is clicked. - /// \param theEvent the mouse event - void onKeyRelease(QKeyEvent* theEvent); - - /// SLOT, that is called by the mouse double click in the viewer. - /// \param theEvent the mouse event - void onMouseDoubleClick(QMouseEvent* theEvent); /// SLOT, to apply to the current viewer the operation /// \param theX the X projection value @@ -115,8 +93,9 @@ Q_OBJECT /// \param theFeatures a list of features to be selected void onSetSelection(const QList& theFeatures); - /// SLOT, to close the viewer local context - void onCloseLocalContext(); + /// SLOT, Defines Sketch editing mode + /// \param thePln - plane of current sketch + void setSketchingMode(const gp_Pln& thePln); /// SLOT, to visualize the feature in another local context mode /// \param theFeature the feature to be put in another local context mode @@ -128,6 +107,36 @@ Q_OBJECT /// \param the attribute of the feature void onStorePoint2D(ObjectPtr theFeature, const std::string& theAttribute); + /// Called when sketch is launched + void onSketchLaunched(); + +protected slots: + /// Called on selection changed event + virtual void onSelectionChanged(); + + /// SLOT, that is called by mouse press in the viewer. + /// The mouse released point is sent to the current operation to be processed. + /// \param theEvent the mouse event + virtual void onMousePressed(QMouseEvent* theEvent); + + /// SLOT, that is called by mouse release in the viewer. + /// The mouse released point is sent to the current operation to be processed. + /// \param theEvent the mouse event + virtual void onMouseReleased(QMouseEvent* theEvent); + + /// SLOT, that is called by mouse move in the viewer. + /// The mouse moved point is sent to the current operation to be processed. + /// \param theEvent the mouse event + virtual void onMouseMoved(QMouseEvent* theEvent); + + /// SLOT, that is called by the mouse double click in the viewer. + /// \param theEvent the mouse event + virtual void onMouseDoubleClick(QMouseEvent* theEvent); + + /// SLOT, that is called by the key in the viewer is clicked. + /// \param theEvent the mouse event + virtual void onKeyRelease(QKeyEvent* theEvent); + protected: /// Creates a new operation /// \param theCmdId the operation name @@ -140,14 +149,16 @@ Q_OBJECT //! Edits the feature void editFeature(FeaturePtr theFeature); + gp_Pln getSketchPlane(FeaturePtr theSketch) const; + private: //XGUI_Workshop* myWorkshop; PartSet_Listener* myListener; std::map myFeaturesInFiles; - /// A filter which provides selection within a current document or whole PartSet - Handle(XGUI_ShapeDocumentFilter) myDocumentShapeFilter; + Handle(StdSelect_FaceFilter) myPlaneFilter; + Handle(ModuleBase_ShapeInPlaneFilter) mySketchFilter; }; #endif