X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FGeomAPI%2FGeomAPI_Lin2d.cpp;h=3f956050f4d6bcb7b50b15b77f6fe99981a6ebb5;hb=bdbfb368d71ed11cc0391354a7d86c880cd94949;hp=a59c5b4ea0fa801faa8ba7eb54ff97e3fb6afecf;hpb=35a88fdd724349275bbff32b9596a44e7cd422e2;p=modules%2Fshaper.git diff --git a/src/GeomAPI/GeomAPI_Lin2d.cpp b/src/GeomAPI/GeomAPI_Lin2d.cpp index a59c5b4ea..3f956050f 100644 --- a/src/GeomAPI/GeomAPI_Lin2d.cpp +++ b/src/GeomAPI/GeomAPI_Lin2d.cpp @@ -1,9 +1,12 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D + // File: GeomAPI_Lin2d.cpp // Created: 29 May 2014 // Author: Artem ZHIDKOV #include #include +#include #include #include @@ -12,7 +15,7 @@ #include -#define MY_LIN2D static_cast(myImpl) +#define MY_LIN2D implPtr() static gp_Lin2d* newLine2d(const double theStartX, const double theStartY, const double theEndX, const double theEndY) @@ -22,6 +25,7 @@ static gp_Lin2d* newLine2d(const double theStartX, const double theStartY, const return new gp_Lin2d(aStart, gp_Dir2d(aDir)); } + GeomAPI_Lin2d::GeomAPI_Lin2d(const double theStartX, const double theStartY, const double theEndX, const double theEndY) : GeomAPI_Interface(newLine2d(theStartX, theStartY, theEndX, theEndY)) @@ -34,6 +38,26 @@ GeomAPI_Lin2d::GeomAPI_Lin2d(const std::shared_ptr& theStart, { } +GeomAPI_Lin2d::GeomAPI_Lin2d(const std::shared_ptr& theOrigin, + const std::shared_ptr& theDirection) + : GeomAPI_Interface(newLine2d(theOrigin->x(), theOrigin->y(), + theOrigin->x() + theDirection->x(), theOrigin->y() + theDirection->y())) +{ +} + + +std::shared_ptr GeomAPI_Lin2d::location() +{ + gp_Pnt2d aLoc = impl().Location(); + return std::shared_ptr(new GeomAPI_Pnt2d(aLoc.X(), aLoc.Y())); +} + +std::shared_ptr GeomAPI_Lin2d::direction() +{ + const gp_Dir2d& aDir = impl().Direction(); + return std::shared_ptr(new GeomAPI_Dir2d(aDir.X(), aDir.Y())); +} + double GeomAPI_Lin2d::distance(const std::shared_ptr& theOther) const { return MY_LIN2D->Distance(theOther->impl()); @@ -79,5 +103,6 @@ std::shared_ptr GeomAPI_Lin2d::shiftedLocation(double theShift) c aVec.Reverse(); aVec.Scale(theShift); gp_Lin2d aLin = MY_LIN2D->Translated(aVec); - return std::shared_ptr(new GeomAPI_Pnt2d(aLin.Location().X(), aLin.Location().Y())); + return std::shared_ptr(new GeomAPI_Pnt2d(aLin.Location().X(), + aLin.Location().Y())); }