-// Copyright (C) 2014-20xx CEA/DEN, EDF R&D -->
-
-// File: SketchPlugin_MacroArc.h
-// Created: 26 May 2014
-// Author: Artem ZHIDKOV
+// 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
+// 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 SketchPlugin_MacroArc_H_
#define SketchPlugin_MacroArc_H_
-#include "SketchPlugin.h"
+#include <ModelAPI_IReentrant.h>
+#include "SketchPlugin.h"
#include "SketchPlugin_SketchEntity.h"
#include <GeomAPI_IPresentable.h>
* it is calculated if all attributes are initialized.
*/
class SketchPlugin_MacroArc: public SketchPlugin_SketchEntity,
- public GeomAPI_IPresentable
+ public GeomAPI_IPresentable,
+ public ModelAPI_IReentrant
{
public:
/// Arc feature kind
return ID;
}
+ inline static const std::string& ARC_TYPE_BY_TRANSVERSAL_LINE()
+ {
+ static const std::string ID("by_transversal_line");
+ return ID;
+ }
+
/// Central 2D point of the circle which contains the arc
inline static const std::string& CENTER_POINT_ID()
{
}
/// Start 2D point of the arc
- inline static const std::string& START_POINT_ID()
+ inline static const std::string& START_POINT_1_ID()
+ {
+ static const std::string ID = "start_point_1";
+ return ID;
+ }
+
+ /// Start 2D point of the arc
+ inline static const std::string& START_POINT_2_ID()
{
- static const std::string ID = "start_point";
+ static const std::string ID = "start_point_2";
return ID;
}
}
/// End 2D point of the arc
- inline static const std::string& END_POINT_ID()
+ inline static const std::string& END_POINT_1_ID()
+ {
+ static const std::string ID = "end_point_1";
+ return ID;
+ }
+
+ /// End 2D point of the arc
+ inline static const std::string& END_POINT_2_ID()
+ {
+ static const std::string ID = "end_point_2";
+ return ID;
+ }
+
+ /// End 2D point of the arc
+ inline static const std::string& END_POINT_3_ID()
+ {
+ static const std::string ID = "end_point_3";
+ return ID;
+ }
+
+ /// End 2D point of the arc
+ inline static const std::string& END_POINT_4_ID()
{
- static const std::string ID = "end_point";
+ static const std::string ID = "end_point_4";
return ID;
}
return ID;
}
+ static const std::string& TRANSVERSAL_POINT_ID()
+ {
+ static const std::string ID("transversal_point");
+ return ID;
+ }
+
/// Reversed flag
inline static const std::string& REVERSED_ID()
{
return ID;
}
+ /// Arc angle.
+ static const std::string& EDIT_ARC_TYPE_ID()
+ {
+ static const std::string ID("edit_arc_type");
+ return ID;
+ }
+
/// Returns the kind of a feature
SKETCHPLUGIN_EXPORT virtual const std::string& getKind()
{
/// Creates an arc-shape
SKETCHPLUGIN_EXPORT virtual void execute();
- /// Moves the feature
- /// \param theDeltaX the delta for X coordinate is moved
- /// \param theDeltaY the delta for Y coordinate is moved
- SKETCHPLUGIN_EXPORT virtual void move(const double theDeltaX, const double theDeltaY)
- {
- };
-
/// Reimplemented from ModelAPI_Feature::isMacro().
SKETCHPLUGIN_EXPORT virtual bool isMacro() const {return true;};
SKETCHPLUGIN_EXPORT virtual bool isPreviewNeeded() const {return false;};
+ /// Apply information of the message to current object. It fills reference object,
+ /// tangent type and tangent point refence in case of tangent arc
+ virtual std::string processEvent(const std::shared_ptr<Events_Message>& theMessage);
+
/// Use plugin manager for features creation.
SketchPlugin_MacroArc();
+ /// Returns shape of arc.
+ /// \param isBound if true prepare arc, otherwice create circle containing this arc
+ GeomShapePtr getArcShape(bool isBound = true);
+
private:
/// Set fields for center, start and end points
void fillByCenterAndTwoPassed();
/// Set fields for center, start and end points by selected passed points
void fillByThreePassedPoints();
- /// Set fields for center, start and end points by selected tangent edge
- void fillByTangentEdge();
+ /// Set fields for center, start and end points by selected tangent or transversal edge
+ /// \param theTransversal if \c true, builds transversal arc, otherwise builds tangential arc.
+ void fillByEdge(bool theTransversal);
FeaturePtr createArcFeature();