X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FGeomAPI%2FGeomAPI_Pln.h;h=704c2a0ce0ce0c9b7fcbd1b25529edede0ddeeb0;hb=857f94a96eb62e69746221f2b919335140b117c6;hp=5c173838dcdfbac5a2b370daabb1ee4fdd52d1f2;hpb=37bd12bd6f4626fc2bfa7764c8f4927dc5b01b9c;p=modules%2Fshaper.git diff --git a/src/GeomAPI/GeomAPI_Pln.h b/src/GeomAPI/GeomAPI_Pln.h index 5c173838d..704c2a0ce 100644 --- a/src/GeomAPI/GeomAPI_Pln.h +++ b/src/GeomAPI/GeomAPI_Pln.h @@ -24,38 +24,42 @@ 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 + GEOMAPI_EXPORT std::shared_ptr location() const; /// Returns a plane normal - GEOMAPI_EXPORT + GEOMAPI_EXPORT std::shared_ptr direction() const; /// Returns a plane x direction - GEOMAPI_EXPORT + 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; @@ -63,6 +67,18 @@ class GeomAPI_Pln : public GeomAPI_Interface /// 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