X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FGeomAPI%2FGeomAPI_Edge.h;h=1c4802ecc687b10585a3ea5c8c761bec5c0b3057;hb=7f873aed4bae5a98dca078209699b54276b46fce;hp=f1c74c5d55573b1f92310a1d306aa7cc7339611d;hpb=8dc74f82810d5f597b78633b457efb0ef4f89f9f;p=modules%2Fshaper.git diff --git a/src/GeomAPI/GeomAPI_Edge.h b/src/GeomAPI/GeomAPI_Edge.h index f1c74c5d5..1c4802ecc 100644 --- a/src/GeomAPI/GeomAPI_Edge.h +++ b/src/GeomAPI/GeomAPI_Edge.h @@ -1,3 +1,5 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D + // File: GeomAPI_Edge.hxx // Created: 24 Jul 2014 // Author: Artem ZHIDKOV @@ -7,28 +9,22 @@ #include +class GeomAPI_Pnt; +class GeomAPI_Circ; + /**\class GeomAPI_Edge - * \ingroup DataModel +* \ingroup DataModel * \brief Interface to the edge object */ class GEOMAPI_EXPORT GeomAPI_Edge : public GeomAPI_Shape { - public: - /// Creation of empty (null) shape - GeomAPI_Edge(); - - /// Returns whether the shape is a vertex - virtual bool isVertex() const - { - return false; - } - - /// Returns whether the shape is an edge - virtual bool isEdge() const - { - return true; - } +public: + /// Creation of empty (null) shape + GeomAPI_Edge(); + + /// Creation of edge by the edge-shape + GeomAPI_Edge(const std::shared_ptr& theShape); /// Verifies that the edge is a line bool isLine() const; @@ -38,6 +34,18 @@ class GEOMAPI_EXPORT GeomAPI_Edge : public GeomAPI_Shape /// Verifies that the edge is an arc of circle bool isArc() const; + + /// Returns the first vertex coordinates of the edge + std::shared_ptr firstPoint(); + + /// Returns the Last vertex coordinates of the edge + std::shared_ptr lastPoint(); + + /// Returns a circle if edge is based on the cirsle curve + std::shared_ptr circle(); + + /// Returns true if the current edge is geometrically equal to the given edge + bool isEqual(const std::shared_ptr theEdge) const; }; #endif