X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FGeomAPI%2FGeomAPI_Shape.cpp;h=5a84a3d98680abc7ba2753556332fe53b31bffb1;hb=60e95a5502a6940c6c27ce5d561b3c684b0b0a4f;hp=0e5bcb010afce528fa68654ab66f867f918af232;hpb=758a57d77b6fa3a0485fa3378a1280c7e87a74aa;p=modules%2Fshaper.git diff --git a/src/GeomAPI/GeomAPI_Shape.cpp b/src/GeomAPI/GeomAPI_Shape.cpp index 0e5bcb010..5a84a3d98 100644 --- a/src/GeomAPI/GeomAPI_Shape.cpp +++ b/src/GeomAPI/GeomAPI_Shape.cpp @@ -1,3 +1,5 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D + // File: GeomAPI_Shape.cpp // Created: 23 Apr 2014 // Author: Mikhail PONIKAROV @@ -5,6 +7,11 @@ #include #include +#include +#include +#include + +#include #define MY_SHAPE static_cast(myImpl) @@ -18,7 +25,7 @@ bool GeomAPI_Shape::isNull() const return MY_SHAPE->IsNull() == Standard_True; } -bool GeomAPI_Shape::isEqual(const boost::shared_ptr theShape) const +bool GeomAPI_Shape::isEqual(const std::shared_ptr theShape) const { if (isNull()) return theShape->isNull(); @@ -39,3 +46,29 @@ bool GeomAPI_Shape::isEdge() const const TopoDS_Shape& aShape = const_cast(this)->impl(); return aShape.ShapeType() == TopAbs_EDGE; } + +bool GeomAPI_Shape::isFace() const +{ + const TopoDS_Shape& aShape = const_cast(this)->impl(); + return aShape.ShapeType() == TopAbs_FACE; +} + +bool GeomAPI_Shape::computeSize(double& theXmin, double& theYmin, double& theZmin, + double& theXmax, double& theYmax, double& theZmax) const +{ + const TopoDS_Shape& aShape = const_cast(this)->impl(); + if (aShape.IsNull()) + return false; + Bnd_Box aBndBox; + BRepBndLib::Add(aShape, aBndBox); + aBndBox.Get(theXmin, theYmin, theZmin, theXmax, theYmax, theZmax); + return true; +} + +std::string GeomAPI_Shape::getShapeStream() const +{ + std::ostringstream aStream; + const TopoDS_Shape& aShape = const_cast(this)->impl(); + BRepTools::Write(aShape, aStream); + return aStream.str(); +}