X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2FSketchPlugin%2FSketchPlugin_ConstraintAngle.h;h=b1bfcc24902e1ec2103d6a1d7fe6c3bc4fb2eaab;hb=refs%2Fheads%2FV9_11_BR;hp=ba00fbc9d76449eb5753dd92b1f666efe9b67cbd;hpb=b3695c3af5289903f1c0fa01bbb7c40203c5e544;p=modules%2Fshaper.git diff --git a/src/SketchPlugin/SketchPlugin_ConstraintAngle.h b/src/SketchPlugin/SketchPlugin_ConstraintAngle.h index ba00fbc9d..b1bfcc249 100644 --- a/src/SketchPlugin/SketchPlugin_ConstraintAngle.h +++ b/src/SketchPlugin/SketchPlugin_ConstraintAngle.h @@ -1,4 +1,4 @@ -// Copyright (C) 2014-2017 CEA/DEN, EDF R&D +// Copyright (C) 2014-2023 CEA, EDF // // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public @@ -12,19 +12,20 @@ // // 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 SketchPlugin_ConstraintAngle_H_ #define SketchPlugin_ConstraintAngle_H_ #include "SketchPlugin.h" -#include +#include "SketchPlugin_Sketch.h" #include "SketchPlugin_ConstraintBase.h" +#include + /** \class SketchPlugin_ConstraintAngle * \ingroup Plugins * \brief Feature for creation of a new constraint fix angle between two lines @@ -32,9 +33,10 @@ * This constraint has two attributes: * SketchPlugin_Constraint::ENTITY_A() and SketchPlugin_Constraint::ENTITY_B() */ -class SketchPlugin_ConstraintAngle : public SketchPlugin_ConstraintBase +class SketchPlugin_ConstraintAngle : public SketchPlugin_ConstraintBase, + public ModelAPI_IReentrant { - public: +public: /// Angle constraint kind inline static const std::string& ID() { @@ -54,6 +56,12 @@ class SketchPlugin_ConstraintAngle : public SketchPlugin_ConstraintBase static const std::string MY_TYPE_ID("AngleType"); return MY_TYPE_ID; } + /// attribute name of previous value of operation type + inline static const std::string& PREV_TYPE_ID() + { + static const std::string MY_TYPE_ID("AngleTypePrevious"); + return MY_TYPE_ID; + } /// attribute name of operation type inline static const std::string& ANGLE_VALUE_ID() @@ -75,6 +83,39 @@ class SketchPlugin_ConstraintAngle : public SketchPlugin_ConstraintBase return MY_ANGLE_REVERSED_ID; } + /// attribute name of dimension location type + inline static const std::string& LOCATION_TYPE_ID() + { + static const std::string MY_LOCATION_TYPE_ID("LocationType"); + return MY_LOCATION_TYPE_ID; + } + + /// attribute name indicating the first point selected + inline static const std::string& SELECTED_FIRST_POINT_ID() + { + static const std::string MY_SELECTED_FIRST_POINT_ID("SelectedPointA"); + return MY_SELECTED_FIRST_POINT_ID; + } + + /// attribute name indicating the second point selected + inline static const std::string& SELECTED_SECOND_POINT_ID() + { + static const std::string MY_SELECTED_SECOND_POINT_ID("SelectedPointB"); + return MY_SELECTED_SECOND_POINT_ID; + } + +public: + static const int THE_VERSION_0 = 0; + static const int THE_VERSION_1 = 20191210; + + /// Attribute name of the version of Angle feature + inline static const std::string& VERSION_ID() + { + static const std::string MY_VERSION_ID("version"); + return MY_VERSION_ID; + } + +public: /// \brief Creates a new part document if needed SKETCHPLUGIN_EXPORT virtual void execute(); @@ -97,21 +138,31 @@ class SketchPlugin_ConstraintAngle : public SketchPlugin_ConstraintBase /// Returns the AIS preview SKETCHPLUGIN_EXPORT virtual AISObjectPtr getAISObject(AISObjectPtr thePrevious); + /// Apply information of the message to current object. + /// It fills selected point and the first object. + virtual std::string processEvent(const std::shared_ptr& theMessage); + + /// \brief Use plugin manager for features creation + SketchPlugin_ConstraintAngle(); + +protected: /// Calculate current value of the angle - double calculateAngle(); + void calculateAngle(); + + /// Compute the position of the angle presentation (the quarter selected by the user) + void calculateAnglePosition(); /// Converts the angle value according to the current angle type and sketch plane normal. /// The in/out angle is in degree. /// \param theAngle a source for the calculated angle - /// \param isPreviousValueObtuse a flag if obtuse should be processed /// \param a double angle value - double getAngleForType(double theAngle, bool isPreviousValueObtuse = false); + double getAngleForType(double theAngle, bool isReversed1 = false, bool isReversed2 = false); - /// Update value of VALUE attribute by the combination of the current angle type and angle value - void updateConstraintValueByAngleValue(); + /// Update value of ANGLE_VALUE attribute according to the current type + void updateAngleValue(); - /// \brief Use plugin manager for features creation - SketchPlugin_ConstraintAngle(); + /// Update parameters of the Angle to meet requirements for the latest version + void updateVersion(); private: bool myFlyoutUpdate; ///< to avoid cyclic dependencies on automatic updates of flyout point