--- /dev/null
+// Copyright (C) 2014-2017 CEA/DEN, EDF R&D
+//
+// This library is free software; you can redistribute it and/or
+// modify it under the terms of the GNU Lesser General Public
+// License as published by the Free Software Foundation; either
+// version 2.1 of the License, or (at your option) any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+// Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public
+// License along with this library; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+//
+// See http://www.salome-platform.org/ or
+// email : webmaster.salome@opencascade.com<mailto:webmaster.salome@opencascade.com>
+//
+
+#include "GeomAlgoAPI_MakeVolume.h"
+
+#include <GeomAlgoAPI_ShapeTools.h>
+
+#include <BOPAlgo_MakerVolume.hxx>
+
+//=================================================================================================
+std::shared_ptr<GeomAPI_Shape> GeomAlgoAPI_MakeVolume::make(const ListOfShape& theFaces)
+{
+ GeomAlgoAPI_MakeVolume aMkVolAlgo(theFaces);
+ GeomShapePtr aResult;
+ if(aMkVolAlgo.isDone() && !aMkVolAlgo.shape()->isNull() && aMkVolAlgo.isValid())
+ aResult = aMkVolAlgo.shape();
+ return aResult;
+}
+
+//=================================================================================================
+GeomAlgoAPI_MakeVolume::GeomAlgoAPI_MakeVolume(const ListOfShape& theFaces)
+{
+ build(theFaces);
+}
+
+static void convertToTopoDS(const ListOfShape& theShapes, TopTools_ListOfShape& theTopoDSShapes)
+{
+ for (ListOfShape::const_iterator anIt = theShapes.begin(); anIt != theShapes.end(); ++anIt)
+ theTopoDSShapes.Append((*anIt)->impl<TopoDS_Shape>());
+}
+
+//=================================================================================================
+void GeomAlgoAPI_MakeVolume::build(const ListOfShape& theFaces)
+{
+ if (theFaces.empty()) {
+ return;
+ }
+
+ // create make volume opration
+ BOPAlgo_MakerVolume* aVolumeMaker = new BOPAlgo_MakerVolume;
+ this->setImpl(aVolumeMaker);
+ this->setBuilderType(OCCT_BOPAlgo_Builder);
+
+ // list of arguments
+ TopTools_ListOfShape anArgs;
+ convertToTopoDS(theFaces, anArgs);
+
+ // parameters of the volume maker
+ aVolumeMaker->SetArguments(anArgs);
+ aVolumeMaker->SetIntersect(true); // split edges and faces
+ aVolumeMaker->SetAvoidInternalShapes(true);
+ aVolumeMaker->SetGlue(BOPAlgo_GlueShift);
+
+ // building and getting result
+ aVolumeMaker->Perform();
+#ifdef USE_OCCT_720
+ if (aVolumeMaker->HasErrors())
+ return;
+#else
+ if(aVolumeMaker->ErrorStatus() != 0) {
+ return;
+ }
+#endif
+ TopoDS_Shape aResult = aVolumeMaker->Shape();
+
+ if(aResult.ShapeType() == TopAbs_COMPOUND) {
+ std::shared_ptr<GeomAPI_Shape> aGeomShape(new GeomAPI_Shape);
+ aGeomShape->setImpl(new TopoDS_Shape(aResult));
+ aResult = GeomAlgoAPI_ShapeTools::groupSharedTopology(aGeomShape)->impl<TopoDS_Shape>();
+ }
+
+ // Setting result.
+ if(aResult.IsNull()) {
+ return;
+ }
+ std::shared_ptr<GeomAPI_Shape> aShape(new GeomAPI_Shape());
+ aShape->setImpl(new TopoDS_Shape(aResult));
+ this->setShape(aShape);
+ this->setDone(true);
+}
--- /dev/null
+// Copyright (C) 2014-2017 CEA/DEN, EDF R&D
+//
+// This library is free software; you can redistribute it and/or
+// modify it under the terms of the GNU Lesser General Public
+// License as published by the Free Software Foundation; either
+// version 2.1 of the License, or (at your option) any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+// Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public
+// License along with this library; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+//
+// See http://www.salome-platform.org/ or
+// email : webmaster.salome@opencascade.com<mailto:webmaster.salome@opencascade.com>
+//
+
+#ifndef GeomAlgoAPI_MakeVolume_H_
+#define GeomAlgoAPI_MakeVolume_H_
+
+#include <GeomAlgoAPI.h>
+#include <GeomAlgoAPI_MakeShape.h>
+
+#include <GeomAPI_Shape.h>
+
+/// \class GeomAlgoAPI_MakeVolume
+/// \ingroup DataAlgo
+/// \brief Perform building solid (compsolid) from a list of faces.
+class GeomAlgoAPI_MakeVolume : public GeomAlgoAPI_MakeShape
+{
+public:
+ /// \brief Perform making volume.
+ /// \param[in] theObjects list of faces.
+ /// \return a solid or a compsolid as result of operation.
+ GEOMALGOAPI_EXPORT static std::shared_ptr<GeomAPI_Shape> make(const ListOfShape& theFaces);
+
+ /// Constructor.
+ GEOMALGOAPI_EXPORT GeomAlgoAPI_MakeVolume(const ListOfShape& theFaces);
+
+private:
+ /// Builds resulting shape.
+ void build(const ListOfShape& theFaces);
+};
+
+#endif