X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSet%2FPartSet_Module.h;h=8fa932b39f21b9d24a6fd77d9e6d04a65b448ae0;hb=9cea92b08d17ed1cb784b7ed774b947d03a348e1;hp=42619830db193a82ed69f8d5d594378e6e89e354;hpb=5e72a47b0d409d94c2dceeb559a46f8bcfb4b170;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_Module.h b/src/PartSet/PartSet_Module.h index 42619830d..8fa932b39 100644 --- a/src/PartSet/PartSet_Module.h +++ b/src/PartSet/PartSet_Module.h @@ -1,17 +1,19 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D + #ifndef PartSet_Module_H #define PartSet_Module_H #include "PartSet.h" -#include +#include "PartSet_Filters.h" +#include "PartSet_SketcherMgr.h" #include #include -#include #include #include #include -#include +//#include #include #include @@ -48,7 +50,26 @@ public: /// Call back forlast tuning of property panel before operation performance virtual void propertyPanelDefined(ModuleBase_Operation* theOperation); - QStringList sketchOperationIdList() const; + + /// Realizes some functionality by an operation start + /// Displays all sketcher sub-Objects, hides sketcher result, appends selection filters + /// \param theOperation a started operation + virtual void operationStarted(ModuleBase_Operation* theOperation); + + /// Realizes some functionality by an operation commit + /// Restarts sketcher operation automatically of it is necessary + /// \param theOperation a committed operation + virtual void operationCommitted(ModuleBase_Operation* theOperation); + + /// Realizes some functionality by an operation abort + /// Hides all sketcher sub-Objects, displays sketcher result and removes selection filters + /// \param theOperation an aborted operation + virtual void operationAborted(ModuleBase_Operation* theOperation); + + /// Realizes some functionality by an operation stop + /// Hides all sketcher sub-Objects, displays sketcher result and removes selection filters + /// \param theOperation a stopped operation + virtual void operationStopped(ModuleBase_Operation* theOperation); public slots: /// SLOT, that is called by no more widget signal emitted by property panel @@ -56,32 +77,28 @@ public slots: void onNoMoreWidgets(); protected slots: - /// Called when previous operation is finished - virtual void onOperationComitted(ModuleBase_Operation* theOperation); - - virtual void onOperationAborted(ModuleBase_Operation* theOperation); - - virtual void onOperationStarted(ModuleBase_Operation* theOperation); - - virtual void onOperationStopped(ModuleBase_Operation* theOperation); - /// Called when previous operation is finished 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 theWnd - the window where the event happens /// \param theEvent the mouse event - void onMousePressed(ModuleBase_IViewWindow* theWnd, QMouseEvent* theEvent); + //void onMousePressed(ModuleBase_IViewWindow* theWnd, 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 theWnd - the window where the event happens /// \param theEvent the mouse event - virtual void onMouseReleased(ModuleBase_IViewWindow* theWnd, QMouseEvent* theEvent); + //void onMouseReleased(ModuleBase_IViewWindow* theWnd, 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 theWnd - the window where the event happens + /// \param theEvent the mouse event + //void onMouseMoved(ModuleBase_IViewWindow* theWnd, QMouseEvent* theEvent); + + /// SLOT, that is called by mouse double click in the viewer. + /// \param theWnd - the window where the event happens /// \param theEvent the mouse event - virtual void onMouseMoved(ModuleBase_IViewWindow* theWnd, QMouseEvent* theEvent); + //void onMouseDoubleClick(ModuleBase_IViewWindow* theWnd, QMouseEvent* theEvent); /// SLOT, that is called by key release in the viewer. /// The mouse moved point is sent to the current operation to be processed. @@ -92,26 +109,23 @@ protected slots: /// Set a specific type of restarting the current operation void onEnterReleased(); - /// Launches the operation from current highlighting - void launchEditing(); + /// SLOT, that is called by the current operation filling with the preselection. + /// It commits the operation of it is can be committed + void onOperationActivatedByPreselection(); - protected: - /// Returns new instance of operation object (used in createOperation for customization) - virtual ModuleBase_Operation* getNewOperation(const std::string& theFeatureId); + protected: /// Register validators for this module virtual void registerValidators(); + /// Register selection filters for this module + virtual void registerFilters(); + private slots: void onVertexSelected(ObjectPtr theObject, const TopoDS_Shape& theShape); - void onPlaneSelected(const std::shared_ptr& thePln); private: - /// Converts mouse position to 2d coordinates. - /// Member myCurrentSketch has to be correctly defined - void get2dPoint(ModuleBase_IViewWindow* theWnd, QMouseEvent* theEvent, - double& theX, double& theY); /// Breaks sequense of automatically resterted operations void breakOperationSequence(); @@ -120,20 +134,13 @@ protected slots: QString myLastOperationId; FeaturePtr myLastFeature; - bool myIsDragging; - bool myDragDone; - // Automatical restarting mode flag RestartingMode myRestartingMode; - double myCurX, myCurY; - CompositeFeaturePtr myCurrentSketch; - QList myEditingFeatures; - QList myEditingAttr; - - Handle(ModuleBase_ShapeInPlaneFilter) myPlaneFilter; /// A filter which provides selection within a current document or whole PartSet Handle(PartSet_GlobalFilter) myDocumentShapeFilter; + + PartSet_SketcherMgr* mySketchMgr; }; #endif