X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSet%2FPartSet_OperationPrs.h;h=c11c5cf02b53ed96287cb5ad2a3d9a973e64af6e;hb=b240d1def415f30a9569bd71f6715c72c0a92291;hp=935e4936d112f84a5002f0fc7241c13b763bd309;hpb=6c1a412473622b7fe884ec5c4476f2ce9c012d88;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_OperationPrs.h b/src/PartSet/PartSet_OperationPrs.h old mode 100755 new mode 100644 index 935e4936d..c11c5cf02 --- a/src/PartSet/PartSet_OperationPrs.h +++ b/src/PartSet/PartSet_OperationPrs.h @@ -1,8 +1,21 @@ -// Copyright (C) 2014-20xx CEA/DEN, EDF R&D - -// File: PartSet_OperationPrs.h -// Created: 01 Jul 2015 -// Author: Natalia ERMOLAEVA +// Copyright (C) 2014-2019 CEA/DEN, EDF R&D +// +// This library is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 2.1 of the License, or (at your option) any later version. +// +// This library is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public +// License along with this library; if not, write to the Free Software +// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +// +// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com +// #ifndef PartSet_OperationPrs_H #define PartSet_OperationPrs_H @@ -21,6 +34,12 @@ #include #include +#include +#include +#include +#include +#include + #include #include @@ -28,8 +47,8 @@ DEFINE_STANDARD_HANDLE(PartSet_OperationPrs, ViewerData_AISShape) -class XGUI_Workshop; class XGUI_Displayer; +class SelectMgr_Selection; /** * \ingroup GUI @@ -45,22 +64,17 @@ public: /// Constructor Standard_EXPORT PartSet_OperationPrs(ModuleBase_IWorkshop* theWorkshop); - /// Returns true if the feature contains attributes, which has references to other features - /// \param theFeature a feature - /// \return boolean result - bool canActivate(const FeaturePtr& theFeature); + /// Returns true if the feature contains shapes or results + bool hasShapes(); - /// Sets the operation feature. It is used in Compute method to group the feature parameter shapes - /// theFeature a feature - void setFeature(const FeaturePtr& theFeature); + /// Sets the colors for the presentation compute + /// \param theColor an argument shapes color + void setShapeColor(const Quantity_Color& theColor); - /// Returns true if the presentation - bool dependOn(const ObjectPtr& theObject); + /// Switch on using of the AIS presentation with of the shape object increased on the delta + void useAISWidth(); - // Recompute internal list of shaped dependent on the current feature - void updateShapes(); - - DEFINE_STANDARD_RTTI(PartSet_OperationPrs) + DEFINE_STANDARD_RTTIEXT(PartSet_OperationPrs, ViewerData_AISShape) protected: /// Redefinition of virtual function @@ -71,33 +85,96 @@ protected: /// Redefinition of virtual function Standard_EXPORT virtual void ComputeSelection(const Handle(SelectMgr_Selection)& aSelection, const Standard_Integer aMode) ; + +protected: + /// list of visualized shapes + /// \return a map of shapes + NCollection_DataMap& shapesMap(); + private: - /// Return true if the object is visible. If the object is feature, it returns true - /// if all results of the feature are shown - /// \param theDisplayer a displayer - /// \param theObject an object - /// \return a boolean value - bool isVisible(XGUI_Displayer* theDislayer, const ObjectPtr& theObject); + /// Fills the map by the feature object and shapes, which should be visuaziled + /// Gets feature attributes, collect objects to whom the attributes refer + /// \param theFeature a current feature + /// \param theWorkshop a current workshop + /// \param theObjectShapes an output map + /// \param theObjectShape an output map of objects + static void getFeatureShapes(const FeaturePtr& theFeature, + ModuleBase_IWorkshop* theWorkshop, + QMap >& theObjectShapes); /// Fills the map by the feature object and shapes, which should be visuaziled - /// Gets the feature attribute, collect objects to whom the attribute refers + /// Gets feature attributes, collect objects to whom the attributes refer + /// \param theFeature a current feature + /// \param theWorkshop a current workshop + /// \param theObjectShapes an output map + /// \param theObjectShape an output map of objects + static void getResultShapes(const FeaturePtr& theFeature, + ModuleBase_IWorkshop* theWorkshop, + QMap >& theObjectShapes, + const bool theListShouldBeCleared = true); + + /// Fills the map by the feature presentation if the feature is presentable + /// \param theFeature a current feature + /// \param theWorkshop a current workshop + /// \param theObjectShapes an output map /// \param theObjectShape an output map of objects - void getFeatureShapes(QMap >& theObjectShapes); + static void getPresentationShapes(const FeaturePtr& theFeature, + ModuleBase_IWorkshop* theWorkshop, + QMap >& theObjectShapes, + const bool theListShouldBeCleared = true); + + /// Fills the map by the feature object and shapes, which should be visuaziled + /// Gets the active widget, obtain the highlighted presentations if it has such and + /// fill map by object and shapes + /// \param theWorkshop a current workshop + /// \param theObjectShapes an output map of objects + static void getHighlightedShapes(ModuleBase_IWorkshop* theWorkshop, + QMap >& theObjectShapes); /// Returns true if the attribute type belong to reference attribute /// \param theAttribute an attribute /// \return a boolean value static bool isSelectionAttribute(const AttributePtr& theAttribute); - /// Converts the current workshop to XGUI workshop - /// \return a workshop instance - XGUI_Workshop* workshop() const; + /// Appends the shape for the result into the container if the result is visible and + /// the shape is not null. + /// \param theWorkshop a current workshop + /// \param theResult an object to be appended + /// \param theGeomShape a shape to be appended + /// \param theObjectShapes a filled container + static void addValue(const ObjectPtr& theObject, const GeomShapePtr& theShape, + const FeaturePtr& theFeature, ModuleBase_IWorkshop* theWorkshop, + QMap >& theObjectShapes); + + /// Appends the shape for the result into the container if the result is visible and + /// the shape is not null. + /// \param theWorkshop a current workshop + /// \param theObject an object to be appended + /// \param theGeomShape a shape to be appended + /// \param theObjectShapes a filled container + static void appendShapeIfVisible(ModuleBase_IWorkshop* theWorkshop, + const ObjectPtr& theObject, + GeomShapePtr theGeomShape, + QMap >& theObjectShapes); + + /// Fills the list of shapes by map of model objects + /// \param theFeatureShape a container to find shapes + /// \param theShapesMap an out container + static void fillShapeList(const QMap >& theFeatureShapes, + ModuleBase_IWorkshop* theWorkshop, + NCollection_DataMap& theShapeToPrsMap); private: - ModuleBase_IWorkshop* myWorkshop; - FeaturePtr myFeature; /// Reference to a feature object - QMap > myFeatureShapes; /// visualized shapes - std::list myFeatureResults; /// visualized feature results + /// list of visualized shapes + NCollection_DataMap myShapeToPrsMap; + + ModuleBase_IWorkshop* myWorkshop; /// current workshop + Quantity_Color myShapeColor; /// color of feature depended shapes + + /// flag if the width of a shape object should be used for the shape visualization + bool myUseAISWidth; + + friend class PartSet_CustomPrs; };