X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModelAPI%2FModelAPI_Result.h;h=bf15dfeecbf14761ba31f9c28490c1ac070bd6d1;hb=eff4b9f47ed1d703c54830b51681eeab7021aaf0;hp=c02abf60828854ffb8dac14a4c808e9129173efd;hpb=694482299ca580d780c221cc6a3e7574e59fd2c3;p=modules%2Fshaper.git diff --git a/src/ModelAPI/ModelAPI_Result.h b/src/ModelAPI/ModelAPI_Result.h index c02abf608..bf15dfeec 100644 --- a/src/ModelAPI/ModelAPI_Result.h +++ b/src/ModelAPI/ModelAPI_Result.h @@ -21,9 +21,13 @@ class ModelAPI_Feature; class ModelAPI_Result : public ModelAPI_Object { bool myIsConcealed; ///< the result is concealed from the data tree (referenced by other objects) + protected: + bool myIsDisabled; ///< the result is disabled: removed for the user, but keeps the general info public: - /// Reference to the color of the result + /// Reference to the color of the result. + /// The integer array is used. It contains tree values for red green and blue values. The values are in + /// [0, 255] range inline static const std::string& COLOR_ID() { static const std::string MY_COLOR_ID("Color"); @@ -31,19 +35,22 @@ class ModelAPI_Result : public ModelAPI_Object } /// Returns true if the result is concealed from the data tree (referenced by other objects) - inline bool isConcealed() - { - return myIsConcealed; - } + MODELAPI_EXPORT virtual bool isConcealed(); - /// Returns true if the result is concealed from the data tree (referenced by other objects) - inline void setIsConcealed(const bool theValue) - { - myIsConcealed = theValue; - } + /// Sets the result as concealed in the data tree (referenced by other objects) + MODELAPI_EXPORT virtual void setIsConcealed(const bool theValue); - // Retuns the parameters of color definition in the resources config manager - virtual void colorConfigInfo(std::string& theSection, std::string& theName, std::string& theDefault) {} + /// Enables/disables the result. The disabled result does not participate in any calculation + /// and visualization: like it was removed. But it keeps the general parameters: colors, + /// visibility, etc. + /// \param theThis pointer to this object, needed to generate all events if it is necessary + /// \param theFlag makes disabled if it is true + /// \returns true if state is really changed + MODELAPI_EXPORT virtual bool setDisabled(std::shared_ptr theThis, + const bool theFlag); + + /// Returns the result is disabled or not. + MODELAPI_EXPORT virtual bool isDisabled(); /// Request for initialization of data model of the result: adding all attributes virtual void initAttributes() {}; @@ -53,6 +60,17 @@ class ModelAPI_Result : public ModelAPI_Object /// Returns the shape-result produced by this feature (or null if no shapes) MODELAPI_EXPORT virtual std::shared_ptr shape(); + + /// On change of attribute of the result update presentation of this result: + /// for the current moment there are only presentation attributes assigned to results + MODELAPI_EXPORT virtual void attributeChanged(const std::string& theID); + +protected: + /// This method is called just after creation of the object: it must initialize + /// all fields, normally initialized in the constructor + MODELAPI_EXPORT virtual void init(); + +friend class Model_Objects; }; //! Pointer on feature object