X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSet%2FPartSet_Module.h;h=a475b5f657a5fd47ce73ef4c3133de788db89d1e;hb=7cb6ac084270943d926ec7ef35bf9e63d6a3eaf5;hp=ecb1dffdcba1b2ad6df7ee806a4d37f69f03f1ba;hpb=430d8ae1b92d91eb26158425481534b5ed87ca7b;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_Module.h b/src/PartSet/PartSet_Module.h index ecb1dffdc..a475b5f65 100644 --- a/src/PartSet/PartSet_Module.h +++ b/src/PartSet/PartSet_Module.h @@ -4,7 +4,6 @@ #define PartSet_Module_H #include "PartSet.h" -#include "PartSet_DocumentDataModel.h" #include #include @@ -21,6 +20,7 @@ #include #include #include +#include #include @@ -69,11 +69,21 @@ public: /// Call back forlast tuning of property panel before operation performance virtual void propertyPanelDefined(ModuleBase_Operation* theOperation); + /// Creates an operation and send it to loop + /// \param theCmdId the operation name + virtual void launchOperation(const QString& theCmdId); + /// Realizes some functionality by an operation start /// Displays all sketcher sub-Objects, hides sketcher result, appends selection filters + /// Activate the operation presentation /// \param theOperation a started operation virtual void onOperationStarted(ModuleBase_Operation* theOperation); + /// Realizes some functionality by an operation resume + /// Activate the operation presentation + /// \param theOperation a resumed operation + virtual void onOperationResumed(ModuleBase_Operation* theOperation); + /// Realizes some functionality by an operation commit /// Restarts sketcher operation automatically of it is necessary /// \param theOperation a committed operation @@ -100,10 +110,21 @@ public: /// \return the boolean result virtual bool canRedo() const; + /// Returnas true if the action can be applyed to the object + /// \param theObject a checked object + /// \param theActionId an identifier of action, to be found in the menu manager like "DELETE_CMD" + /// \return the a booean result + virtual bool canApplyAction(const ObjectPtr& theObject, const QString& theActionId) const; + /// Returns True if the current operation can be committed. Asks the sketch manager. /// \return a boolean value virtual bool canCommitOperation() const; + /// Returns whether the object can be erased at the bounds of the active operation. + /// The sub-objects of the current operation can not be erased + /// \param theObject a model object + virtual bool canEraseObject(const ObjectPtr& theObject) const; + /// Returns whether the object can be displayed at the bounds of the active operation. /// Display only current operation results for usual operation and ask the sketcher manager /// if it is a sketch operation @@ -134,10 +155,14 @@ public: /// \return true if items are added and there is no necessity to provide standard menu bool isMouseOverWindow(); + /// Returns sketch manager object PartSet_SketcherMgr* sketchMgr() const { return mySketchMgr; } - /// Returns data model object for representation of data tree in Object browser - virtual ModuleBase_IDocumentDataModel* dataModel() const { return myDataModel; } + /// Performs functionality on closing document + virtual void closeDocument(); + + /// Clears specific presentations in the viewer + virtual void clearViewer(); /// Event Listener method /// \param theMessage an event message @@ -151,8 +176,10 @@ public: * If the object is result with the color attribute value set, it is used, * otherwise the customize is applyed to the object's feature if it is a custom prs * \param theObject an object instance + * \param theUpdateViewer the parameter whether the viewer should be update immediatelly + * \returns true if the object is modified */ - virtual void customizeObject(ObjectPtr theObject); + virtual bool customizeObject(ObjectPtr theObject, const bool theUpdateViewer); /// This method is called on object browser creation for customisation of module specific features /// \param theObjectBrowser a pinter on Object Browser widget @@ -164,6 +191,15 @@ public: //! Returns data object by AIS virtual ObjectPtr findPresentedObject(const AISObjectPtr& theAIS) const; + /// Update state of pop-up menu items in viewer + /// \param theStdActions - a map of standard actions + virtual void updateViewerMenu(const QMap& theStdActions); + + //! Returns the feature error if the current state of the feature in the module is not correct + //! If the feature is correct, it returns an empty value + //! \return string value + virtual QString getFeatureError(const FeaturePtr& theFeature); + public slots: /// SLOT, that is called by no more widget signal emitted by property panel /// Set a specific flag to restart the sketcher operation @@ -179,6 +215,11 @@ public slots: /// \param theAIS a presentation object virtual void onObjectDisplayed(ObjectPtr theObject, AISObjectPtr theAIS); + /// Slot called on before object erase + /// \param theObject a data object + /// \param theAIS a presentation object + virtual void onBeforeObjectErase(ObjectPtr theObject, AISObjectPtr theAIS); + /// Called on transformation in current viewer /// \param theTrsfType type of tranformation void onViewTransformed(int theTrsfType = 2); @@ -241,7 +282,9 @@ protected slots: PartSet_CustomPrs* myCustomPrs; int myVisualLayerId; - PartSet_DocumentDataModel* myDataModel; + bool myHasConstraintShown; + + QModelIndex aActivePartIndex; }; #endif