X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSet%2FPartSet_WidgetShapeSelector.h;h=57b9a1c10fff2d36c1dadb966dd0d587adc3ebff;hb=50a8df0c6a66da8067b16155e5ae39f8f26a7ebc;hp=6c81641c83e08ffa443756a2a7b77e18d53158e9;hpb=d0e122f8a53eee773269e778db3115c36070dbf1;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_WidgetShapeSelector.h b/src/PartSet/PartSet_WidgetShapeSelector.h index 6c81641c8..57b9a1c10 100644 --- a/src/PartSet/PartSet_WidgetShapeSelector.h +++ b/src/PartSet/PartSet_WidgetShapeSelector.h @@ -1,9 +1,21 @@ -// Copyright (C) 2014-20xx CEA/DEN, EDF R&D - -// File: PartSet_WidgetShapeSelector.h -// Created: 27 Nov 2014 -// Author: Vitaly Smetannikov - +// Copyright (C) 2014-2020 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_WidgetShapeSelector_H #define PartSet_WidgetShapeSelector_H @@ -14,11 +26,12 @@ #include +class PartSet_ExternalObjectsMgr; /** -* \ingroup Module +* \ingroup Modules * Customosation of ModuleBase_WidgetShapeSelector in order to provide -* working with sketch specific objects. +* working with sketch specific objects and external objects. */ class PARTSET_EXPORT PartSet_WidgetShapeSelector: public ModuleBase_WidgetShapeSelector { @@ -28,14 +41,10 @@ Q_OBJECT /// \param theParent the parent object /// \param theWorkshop instance of workshop interface /// \param theData the widget configuation. The attribute of the model widget is obtained from - /// \param theParentId is Id of a parent of the current attribute PartSet_WidgetShapeSelector(QWidget* theParent, ModuleBase_IWorkshop* theWorkshop, - const Config_WidgetAPI* theData, const std::string& theParentId) - : ModuleBase_WidgetShapeSelector(theParent, theWorkshop, theData, theParentId) {} + const Config_WidgetAPI* theData); - virtual ~PartSet_WidgetShapeSelector() {} - - virtual bool storeValue() const; + virtual ~PartSet_WidgetShapeSelector(); /// Set sketcher /// \param theSketch a sketcher object @@ -44,48 +53,41 @@ Q_OBJECT /// Retrurns installed sketcher CompositeFeaturePtr sketch() const { return mySketch; } -protected: - /// Check the selected with validators if installed - virtual bool isValid(ObjectPtr theObj, std::shared_ptr theShape); - -private: - /// Pointer to a sketch - CompositeFeaturePtr mySketch; -}; - -/** -* \ingroup Module -* Customosation of ModuleBase_WidgetShapeSelector in order to provide -* working with constraints. -*/ -class PARTSET_EXPORT PartSet_WidgetConstraintShapeSelector: public ModuleBase_WidgetShapeSelector -{ -Q_OBJECT - public: - /// Constructor - /// \param theParent the parent object - /// \param theWorkshop instance of workshop interface - /// \param theData the widget configuation. The attribute of the model widget is obtained from - /// \param theParentId is Id of a parent of the current attribute - PartSet_WidgetConstraintShapeSelector(QWidget* theParent, ModuleBase_IWorkshop* theWorkshop, - const Config_WidgetAPI* theData, const std::string& theParentId) - : ModuleBase_WidgetShapeSelector(theParent, theWorkshop, theData, theParentId) {} - - virtual ~PartSet_WidgetConstraintShapeSelector() {} - - /// Saves the internal parameters to the given feature - virtual bool storeValue() const; + /// Appends into container of workshop selection filters + /// \param [out] theModuleSelectionFilters module additional modes, -1 means all default modes + /// \param [out] theSelectionFilters selection filters + virtual void selectionFilters(QIntList& theModuleSelectionFilters, + SelectMgr_ListOfFilter& theSelectionFilters); - /// Set sketcher - /// \param theSketch a sketcher object - void setSketcher(CompositeFeaturePtr theSketch) { mySketch = theSketch; } +protected: + /// Checks the widget validity. By default, it returns true. + /// \param thePrs a selected presentation in the view + /// \return a boolean value + virtual bool isValidSelectionCustom(const std::shared_ptr& thePrs); + + /// Return an object and geom shape by the viewer presentation + /// \param thePrs a selection + /// \param theObject an output object + /// \param theShape a shape of the selection + virtual void getGeomSelection(const std::shared_ptr& thePrs, + ObjectPtr& theObject, + GeomShapePtr& theShape); + + /// Creates a backup of the current values of the attribute + /// It should be realized in the specific widget because of different + /// parameters of the current attribute + /// \param theAttribute an attribute + /// \param theValid a boolean flag, if restore happens for valid parameters + void restoreAttributeValue(const AttributePtr& theAttribute, const bool theValid); - /// Retrurns installed sketcher - CompositeFeaturePtr sketch() const { return mySketch; } +protected: + /// A reference to external objects manager + PartSet_ExternalObjectsMgr* myExternalObjectMgr; -private: - /// Pointer to a sketch + /// Pointer to a sketch CompositeFeaturePtr mySketch; + + bool myUseSketchPlane; ///< state whether the sketch plane filter should be switched on }; #endif \ No newline at end of file