]> SALOME platform Git repositories - modules/shaper.git/blob - src/GeomAPI/GeomAPI_Lin2d.h
Salome HOME
6619c4ff72b552680780ff009fc36636bad4215d
[modules/shaper.git] / src / GeomAPI / GeomAPI_Lin2d.h
1 // Copyright (C) 2014-20xx CEA/DEN, EDF R&D
2
3 // File:        GeomAPI_Lin2d.h
4 // Created:     29 May 2014
5 // Author:      Artem ZHIDKOV
6
7 #ifndef GeomAPI_Lin2d_H_
8 #define GeomAPI_Lin2d_H_
9
10 #include <GeomAPI_Interface.h>
11 #include <memory>
12
13 class GeomAPI_Dir2d;
14 class GeomAPI_Pnt2d;
15
16 /**\class GeomAPI_Lin2d
17  * \ingroup DataModel
18  * \brief Line in 2D
19  */
20
21 class GeomAPI_Lin2d : public GeomAPI_Interface
22 {
23  public:
24   /// Creation of line defined by cordinates of start and end points
25   GEOMAPI_EXPORT
26   GeomAPI_Lin2d(const double theStartX, const double theStartY, const double theEndX,
27                 const double theEndY);
28   /// Creation of line defined by start and end points
29   GEOMAPI_EXPORT
30   GeomAPI_Lin2d(const std::shared_ptr<GeomAPI_Pnt2d>& theStart,
31                 const std::shared_ptr<GeomAPI_Pnt2d>& theEnd);
32   /// Creation of line defined by origin and direction
33   GEOMAPI_EXPORT
34   GeomAPI_Lin2d(const std::shared_ptr<GeomAPI_Pnt2d>& theOrigin,
35                 const std::shared_ptr<GeomAPI_Dir2d>& theDirection);
36
37   /// Returns point on the line (first point)
38   GEOMAPI_EXPORT
39   std::shared_ptr<GeomAPI_Pnt2d> location();
40
41   /// Returns a line direction
42   GEOMAPI_EXPORT
43   std::shared_ptr<GeomAPI_Dir2d> direction();
44
45   /// Distance between two points
46   GEOMAPI_EXPORT
47   double distance(const std::shared_ptr<GeomAPI_Pnt2d>& theOther) const;
48   /// Intersection of two lines
49   GEOMAPI_EXPORT
50   const std::shared_ptr<GeomAPI_Pnt2d> intersect(
51       const std::shared_ptr<GeomAPI_Lin2d>& theLine) const;
52   /// Project point on line
53   GEOMAPI_EXPORT
54   const std::shared_ptr<GeomAPI_Pnt2d> project(
55       const std::shared_ptr<GeomAPI_Pnt2d>& thePoint) const;
56   /// Computes the cross product of the line direction and a vector
57   /// from the line start point to the point
58   GEOMAPI_EXPORT
59   bool isRight(const std::shared_ptr<GeomAPI_Pnt2d>& thePoint) const;
60
61   /// Returns a location point shifted on theShift in perpendicular direction
62   GEOMAPI_EXPORT
63   std::shared_ptr<GeomAPI_Pnt2d> shiftedLocation(double theShift) const;
64 };
65
66 #endif
67