X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModuleBase%2FModuleBase_ViewerPrs.h;h=419447edb1096006ce2c438123e49df921dd9a14;hb=f9fd953bf814fad40ae045f6164c7f80229b0872;hp=83c9e319354e36d1cde486cb650d719b0e772a22;hpb=42db601320a02457d3db1090f2837e7c9e024f8d;p=modules%2Fshaper.git diff --git a/src/ModuleBase/ModuleBase_ViewerPrs.h b/src/ModuleBase/ModuleBase_ViewerPrs.h index 83c9e3193..419447edb 100644 --- a/src/ModuleBase/ModuleBase_ViewerPrs.h +++ b/src/ModuleBase/ModuleBase_ViewerPrs.h @@ -1,3 +1,5 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D + // File: ModuleBase_ViewerPrs.h // Created: 20 Apr 2014 // Author: Natalia ERMOLAEVA @@ -7,7 +9,7 @@ #include "ModuleBase.h" -#include +#include #include #include #include @@ -15,37 +17,28 @@ #include /**\class ModuleBase_ViewerPrs - * \ingroup Module base + * \ingroup GUI * \brief Presentation. Provides container to have feature, shape and/or selection owner. */ -class ModuleBase_ViewerPrs +class MODULEBASE_EXPORT ModuleBase_ViewerPrs { public: /// Constructor - ModuleBase_ViewerPrs() - { - } + ModuleBase_ViewerPrs(); /// Constructor - /// \param theFeature a model feature + /// \param theResult an object /// \param theShape a viewer shape /// \param theOwner a selection owner ModuleBase_ViewerPrs(ObjectPtr theResult, const TopoDS_Shape& theShape, - Handle_SelectMgr_EntityOwner theOwner) - : myResult(theResult), - myShape(theShape), - myOwner(theOwner) - { - } + Handle_SelectMgr_EntityOwner theOwner); /// Destructor - virtual ~ModuleBase_ViewerPrs() - { - } + virtual ~ModuleBase_ViewerPrs(); - /// Sets the feature. - /// \param theFeature a feature instance - void setFeature(ObjectPtr theResult) + /// Sets the object. + /// \param theResult an object instance + void setObject(ObjectPtr theResult) { myResult = theResult; } @@ -57,8 +50,8 @@ class ModuleBase_ViewerPrs return myResult; } - /// Returns the presentation owner - /// \param the owner + /// Set the presentation owner + /// \param theOwner an owner to set void setOwner(Handle_SelectMgr_EntityOwner theOwner) { myOwner = theOwner; @@ -85,16 +78,29 @@ class ModuleBase_ViewerPrs return myShape; } + /// Set interactive object + /// \param theIO an interactive object void setInteractive(const Handle(AIS_InteractiveObject)& theIO) { myInteractive = theIO; } + /// Returns interactive object if it is installed Handle(AIS_InteractiveObject) interactive() const { return myInteractive; } + /// Returns true if all presentation fields are empty + /// \return boolean value + bool isEmpty() const + { + return myShape.IsNull() && + myOwner.IsNull() && !myResult.get(); + } + + /// Returns True if the current object is equal to the given one + /// \param thePrs an object to compare bool operator==(const ModuleBase_ViewerPrs& thePrs) { bool aResult = (myResult.get() == thePrs.object().get()); @@ -108,7 +114,7 @@ class ModuleBase_ViewerPrs ObjectPtr myResult; /// the feature Handle(SelectMgr_EntityOwner) myOwner; /// the selection owner TopoDS_Shape myShape; /// the shape - Handle(AIS_InteractiveObject) myInteractive; + Handle(AIS_InteractiveObject) myInteractive; /// interactive object }; #endif