X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FSketcherPrs%2FSketcherPrs_SymbolPrs.h;h=a08d98b5604e9da89deb2ece54c9c2164a07d66e;hb=ea593bc59e7e9461f6c4e2afd3f24d621edb1011;hp=8bbae4ddadaaa4f504b1ba86a783cb81910e2c16;hpb=0bbc862db48081f4ff407177716e6fb8c16e930f;p=modules%2Fshaper.git diff --git a/src/SketcherPrs/SketcherPrs_SymbolPrs.h b/src/SketcherPrs/SketcherPrs_SymbolPrs.h index 8bbae4dda..a08d98b56 100644 --- a/src/SketcherPrs/SketcherPrs_SymbolPrs.h +++ b/src/SketcherPrs/SketcherPrs_SymbolPrs.h @@ -1,13 +1,27 @@ -// Copyright (C) 2014-20xx CEA/DEN, EDF R&D - -// File: SketcherPrs_SymbolPrs.h -// Created: 12 March 2015 -// Author: Vitaly SMETANNIKOV +// 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 SketcherPrs_SymbolPrs_H #define SketcherPrs_SymbolPrs_H #include "SketcherPrs_SensitivePoint.h" +#include #include #include @@ -41,7 +55,7 @@ public: /// \param theConstraint a constraint feature /// \param thePlane a coordinate plane of current sketch Standard_EXPORT SketcherPrs_SymbolPrs(ModelAPI_Feature* theConstraint, - const std::shared_ptr& thePlane); + SketchPlugin_Sketch* theSketcher); virtual ~SketcherPrs_SymbolPrs(); @@ -50,18 +64,23 @@ public: const SelectMgr_SequenceOfOwner& theOwners); //! Method which hilight an owner belonging to - //! this selectable object ( for fast presentation draw ) Standard_EXPORT virtual void HilightOwnerWithColor( const Handle(PrsMgr_PresentationManager3d)& thePM, - const Handle(Graphic3d_HighlightStyle)& theStyle, + const Handle(Prs3d_Drawer)& theStyle, const Handle(SelectMgr_EntityOwner)& theOwner); /// Returns sketcher plane - Standard_EXPORT std::shared_ptr plane() const { return myPlane; } + Standard_EXPORT std::shared_ptr plane() const + { + return mySketcher->coordinatePlane(); + } /// Returns feature object Standard_EXPORT ModelAPI_Feature* feature() const { return myConstraint; } + /// Returns Sketcher object (owner of the constraint) + Standard_EXPORT ModelAPI_CompositeFeature* sketcher() const { return mySketcher; } + /// Return array of points where symbols will be placed const Handle(Graphic3d_ArrayOfPoints)& pointsArray() const { return myPntArray; } @@ -111,26 +130,26 @@ protected: /// Update myPntArray according to presentation positions /// \return true in case of success - virtual bool updateIfReadyToDisplay(double theStep) const { return true; } + virtual bool updateIfReadyToDisplay(double theStep, bool withColor) const { return true; } /// Draw a shape into the given presentation scene /// \param theShape the shape to draw /// \param thePrs the presentation scene void drawShape(const std::shared_ptr& theShape, - const Handle(Prs3d_Presentation)& thePrs) const; + const Handle(Prs3d_Presentation)& thePrs, Quantity_Color theColor) const; /// Draw a list of shapes stored in a RefListAttribute /// \param theListAttr the attribute of reference3s list /// \param thePrs the presentation scene void drawListOfShapes(const std::shared_ptr& theListAttr, - const Handle(Prs3d_Presentation)& thePrs) const; + const Handle(Prs3d_Presentation)& thePrs, Quantity_Color theColor) const; protected: /// Constraint feature ModelAPI_Feature* myConstraint; - /// Plane of the current sketcher - std::shared_ptr myPlane; + /// Sketcher feature + SketchPlugin_Sketch* mySketcher; /// Aspect for entities drawing Handle(Graphic3d_AspectMarker3d) myAspect; @@ -150,7 +169,6 @@ private: bool myIsCustomColor; /// state if the presentation is visualized in custom color Quantity_Color myCustomColor; /// the color of mid ring if there is a conflict - //Quantity_Color myIsCustomColor; //bool myIsConflicting; /// state if the presentation is visualized in error state Handle(Image_AlienPixMap) myErrorIcon; Handle(Graphic3d_MarkerImage) myErrorImage;