X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FPartSet%2FPartSet_SketcherMgr.h;h=bfc8bfac67c08ef9afd5a86cf501755c8e61fe8d;hb=55721f7e81cd960ce315296b8fdf97489284933f;hp=5396144b3aa48a213182cb80a5fdb159532556a0;hpb=5a67842979db286af5bb5015fe413d8b06c6587e;p=modules%2Fshaper.git diff --git a/src/PartSet/PartSet_SketcherMgr.h b/src/PartSet/PartSet_SketcherMgr.h index 5396144b3..bfc8bfac6 100644 --- a/src/PartSet/PartSet_SketcherMgr.h +++ b/src/PartSet/PartSet_SketcherMgr.h @@ -1,4 +1,4 @@ -// Copyright (C) 2014-2017 CEA/DEN, EDF R&D +// 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 @@ -12,10 +12,9 @@ // // 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 +// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // -// See http://www.salome-platform.org/ or -// email : webmaster.salome@opencascade.com +// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com // #ifndef PartSet_SketcherMgr_H @@ -23,38 +22,74 @@ #include "PartSet.h" -#include "PartSet_Filters.h" +#include "PartSet_PreviewSketchPlane.h" #include "PartSet_Tools.h" #include #include #include #include +#include -#include #include #include #include + +#ifdef HAVE_SALOME + #include +#else + #include +#endif + + #include +#include + #include #include +#include #include #include #include +#include + class PartSet_Module; class ModuleBase_IViewWindow; class ModuleBase_ModelWidget; class ModuleBase_Operation; class XGUI_OperationMgr; class XGUI_Workshop; +class XGUI_Displayer; +class PartSet_ExternalPointsMgr; class AIS_InteractiveObject; class QMouseEvent; + +#ifdef HAVE_SALOME +class PartSet_Fitter : public OCCViewer_Fitter +#else +class PartSet_Fitter : public AppElements_Fitter +#endif +{ +public: + PartSet_Fitter(CompositeFeaturePtr theCurrentSketch): + mySketch(theCurrentSketch) {} + + /// A method which has top be reimplemented to provide alterantive implementation FitAll command + /// \param theView - a view which has to be fit + virtual void fitAll(Handle(V3d_View) theView); + +private: + CompositeFeaturePtr mySketch; +}; + + + /** * \ingroup Modules * A class for management of sketch operations @@ -170,6 +205,10 @@ public: /// Returns current Sketch feature/ Returns NULL if there is no launched sketch operation CompositeFeaturePtr activeSketch() const { return myCurrentSketch; } + /// Returns help class to visualize sketcher plane + /// \return a preview plane + PartSet_PreviewSketchPlane* previewSketchPlane() const { return mySketchPlane; } + /// Starts sketch operation void startSketch(ModuleBase_Operation* ); @@ -188,9 +227,16 @@ public: /// \param theOperation a committed operation void commitNestedSketch(ModuleBase_Operation* theOperation); - /// Append the sketch plane filter into the current viewer - /// \param toActivate state whether the filter should be activated/deactivated - void activatePlaneFilter(const bool& toActivate); + /// Returns true if the filter is created by the sketch manager + /// \param theFilterType a checked type + /// \return boolean value + bool sketchSelectionFilter(const ModuleBase_SelectionFilterType theFilterType); + + /// Append selection filter into the module and type of the filter in internal container + /// \param theFilterType selection filter type + /// \param theFilter added filter + void registerSelectionFilter(const ModuleBase_SelectionFilterType theFilterType, + const Handle(SelectMgr_Filter)& theFilter); /// Commit the operation if it is possible. If the operation is dimention constraint, /// it gives widget editor to input dimention value @@ -290,8 +336,9 @@ public: static const QStringList& constraintsIdList(); /// Returns a list of modes, where the AIS objects should be activated + /// \param theSketch a sketch object, modes are empty if sketch plane is not defined yet /// \param theModes a list of modes - static void sketchSelectionModes(QIntList& theModes); + static void sketchSelectionModes(const CompositeFeaturePtr& theSketch, QIntList& theModes); /// Create specific for the module presentation /// \param theResult an object for presentation @@ -318,10 +365,18 @@ public: void updateBySketchParameters(const PartSet_Tools::ConstraintVisibleState& theType, bool theState); + bool isShowFreePointsShown() const { + return myPointsHighlight.size() > 0; + } + public slots: /// Process sketch plane selected event void onPlaneSelected(const std::shared_ptr& thePln); + /// The slot is called when user checks "Show free points" button + /// \param toShow a state of the check box + void onShowPoints(bool toShow); + private slots: /// Toggle show constraints void onShowConstraintsToggle(int theType, bool theState); @@ -412,6 +467,7 @@ private: private: PartSet_Module* myModule; + PartSet_PreviewSketchPlane* mySketchPlane; // display/erase sketch plane on start/stop sketch bool myPreviousDrawModeEnabled; // the previous selection enabled state in the viewer bool myIsEditLaunching; @@ -426,12 +482,18 @@ private: CompositeFeaturePtr myCurrentSketch; - Handle(PartSet_CirclePointFilter) myCirclePointFilter; - Handle(ModuleBase_ShapeInPlaneFilter) myPlaneFilter; + std::set mySelectionFilterTypes; + FeatureToSelectionMap myCurrentSelection; bool myPreviousUpdateViewerEnabled; QMap myIsConstraintsShown; + + PartSet_ExternalPointsMgr* myExternalPointsMgr; + + QMap myPointsHighlight; + + bool myNoDragMoving; };