X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSet%2FPartSet_ExternalObjectsMgr.h;h=4cc3696da8008aa11a2dc74ba36ef840544d4ccb;hb=32208dedf0b2b5bd50b5b86c464f37a8e0eb07d0;hp=6451751dee3dda3e01d0e659f079de9f3583d918;hpb=9d9ff3badaec1d230a701582d588b1e75c0fc09c;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_ExternalObjectsMgr.h b/src/PartSet/PartSet_ExternalObjectsMgr.h old mode 100644 new mode 100755 index 6451751de..4cc3696da --- a/src/PartSet/PartSet_ExternalObjectsMgr.h +++ b/src/PartSet/PartSet_ExternalObjectsMgr.h @@ -18,6 +18,9 @@ #include +class ModuleBase_IWorkshop; +class XGUI_Workshop; + /** * \ingroup Modules * Customosation of ModuleBase_WidgetShapeSelector in order to provide @@ -28,34 +31,68 @@ class PARTSET_EXPORT PartSet_ExternalObjectsMgr public: /// Constructor /// \param theExternal the external state + /// \param theCanCreateExternal the state if it can and should create external features /// \param theDefaultValue the default value for the external object using - PartSet_ExternalObjectsMgr(const std::string& theExternal, const bool theDefaultValue); + PartSet_ExternalObjectsMgr(const std::string& theExternal, + const std::string& theCanCreateExternal, + const bool theDefaultValue); virtual ~PartSet_ExternalObjectsMgr() {} /// Returns the state whether the external object is used bool useExternal() const { return myUseExternal; } + /// Returns if new external objects can be created + /// \return boolean value + bool canCreateExternal() { return myCanCreateExternal;} + + /// Checks validity of the given object + /// \param theObject an object to check + /// \return valid or not valid + bool isValidObject(const ObjectPtr& theObject); + /// Finds or create and external object /// \param theSelectedObject an object /// \param theShape a selected shape, which is used in the selection attribute /// \param theSketch a current sketch + /// \param theTemporary the created external object is temporary, execute is not performed for it /// \return the object ObjectPtr externalObject(const ObjectPtr& theSelectedObject, const GeomShapePtr& theShape, - const CompositeFeaturePtr& theSketch); + const CompositeFeaturePtr& theSketch, const bool theTemporary = false); // Removes the external presentation from the model /// \param theSketch a current sketch /// \param theFeature a current feature + /// \param theWorkshop a current workshop + /// \param theTemporary if true, a temporary external object is removed overwise all ext objects void removeExternal(const CompositeFeaturePtr& theSketch, - const FeaturePtr& theFeature); + const FeaturePtr& theFeature, + ModuleBase_IWorkshop* theWorkshop, + const bool theTemporary); + +protected: + /// Delete from the document the feature of the object. It deletes all objects, which refers to + /// the deleted one. The parameter feature is ignored even it refer to the deleted object. + /// \param theObject a removed object + /// \param theSketch a current sketch + /// \param theFeature a current feature + /// \param theWorkshop a current workshop + void removeExternalObject(const ObjectPtr& theObject, + const CompositeFeaturePtr& theSketch, + const FeaturePtr& theFeature, + ModuleBase_IWorkshop* theWorkshop); + + /// Returns the workshop + static XGUI_Workshop* workshop(ModuleBase_IWorkshop* theWorkshop); protected: /// An external object - QObjectPtrList myExternalObjects; + ObjectPtr myExternalObjectValidated; /// Boolean value about the neccessity of the external object use bool myUseExternal; + /// Boolean value about the necessity of a new external object creation + bool myCanCreateExternal; }; #endif \ No newline at end of file