X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FGeomAPI%2FGeomAPI_Pln.h;h=704c2a0ce0ce0c9b7fcbd1b25529edede0ddeeb0;hb=857f94a96eb62e69746221f2b919335140b117c6;hp=e0564557e531a2fbf45d7c4c7599325b54f676b0;hpb=868158fe6d39b25e60ac528295b1c908821e4af5;p=modules%2Fshaper.git diff --git a/src/GeomAPI/GeomAPI_Pln.h b/src/GeomAPI/GeomAPI_Pln.h index e0564557e..704c2a0ce 100644 --- a/src/GeomAPI/GeomAPI_Pln.h +++ b/src/GeomAPI/GeomAPI_Pln.h @@ -13,6 +13,7 @@ class GeomAPI_Ax3; class GeomAPI_Pnt; class GeomAPI_Dir; +class GeomAPI_Lin; /**\class GeomAPI_Pln * \ingroup DataModel @@ -23,33 +24,61 @@ class GeomAPI_Pln : public GeomAPI_Interface { public: /// Creation of plane by the axis placement - GEOMAPI_EXPORT + GEOMAPI_EXPORT GeomAPI_Pln(const std::shared_ptr& theAxis); /// Creation of plane by the point and normal - GEOMAPI_EXPORT + GEOMAPI_EXPORT GeomAPI_Pln(const std::shared_ptr& thePoint, const std::shared_ptr& theNormal); /// Creation of plane by coefficients (Ax+By+Cz+D=0) - GEOMAPI_EXPORT + GEOMAPI_EXPORT GeomAPI_Pln(const double theA, const double theB, const double theC, const double theD); /// Returns a point of this plane - GEOMAPI_EXPORT - std::shared_ptr location(); + GEOMAPI_EXPORT + std::shared_ptr location() const; /// Returns a plane normal - GEOMAPI_EXPORT - std::shared_ptr direction(); + GEOMAPI_EXPORT + std::shared_ptr direction() const; + + /// Returns a plane x direction + GEOMAPI_EXPORT + std::shared_ptr xDirection() const; /// Returns the plane coefficients (Ax+By+Cz+D=0) - GEOMAPI_EXPORT + GEOMAPI_EXPORT void coefficients(double& theA, double& theB, double& theC, double& theD); /// Returns true if planes are coincident. GEOMAPI_EXPORT bool isCoincident(const std::shared_ptr thePlane, const double theTolerance = 1.e-7); + + /// Returns true if plane is parallel to theLine. + GEOMAPI_EXPORT + bool isParallel(const std::shared_ptr theLine); + + /// Returns intersection point or empty if no intersections + GEOMAPI_EXPORT + std::shared_ptr intersect(const std::shared_ptr& theLine) const; + + /// Returns projection of the given point onto the plane + GEOMAPI_EXPORT + std::shared_ptr project(const std::shared_ptr& thePoint) const; + + /// \return distance between planes. + GEOMAPI_EXPORT + double distance(const std::shared_ptr thePlane) const; + + /// Translates the plane along direction theDir on distance theDist + GEOMAPI_EXPORT + void translate(const std::shared_ptr theDir, const double theDist); + + /// \return intersection line of two planes. Empty if they are parallel. + GEOMAPI_EXPORT + std::shared_ptr intersect(const std::shared_ptr thePlane) const; }; #endif