X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FGeomAlgoAPI%2FGeomAlgoAPI_Boolean.h;h=ab7ae15772a8ed96fdca2e21814196ef7581c314;hb=refs%2Fheads%2FV9_11_BR;hp=5c2059b88f1cf20867e1980b056152be198347dd;hpb=c3ae28ba30027cc4a6a757ef623f40adaae96ead;p=modules%2Fshaper.git diff --git a/src/GeomAlgoAPI/GeomAlgoAPI_Boolean.h b/src/GeomAlgoAPI/GeomAlgoAPI_Boolean.h index 5c2059b88..ab7ae1577 100644 --- a/src/GeomAlgoAPI/GeomAlgoAPI_Boolean.h +++ b/src/GeomAlgoAPI/GeomAlgoAPI_Boolean.h @@ -1,69 +1,85 @@ -// Copyright (C) 2014-20xx CEA/DEN, EDF R&D - -// File: GeomAlgoAPI_Boolean.h -// Created: 02 Sept 2014 -// Author: Vitaly Smetannikov +// Copyright (C) 2014-2023 CEA, EDF +// +// 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 +// #ifndef GeomAlgoAPI_Boolean_H_ #define GeomAlgoAPI_Boolean_H_ #include #include +#include #include -#include -#include - -#include -/** \class GeomAlgoAPI_Boolean - * \ingroup DataAlgo - * \brief Allows to perform of boolean operations - */ -class GeomAlgoAPI_Boolean : public GeomAPI_Interface +/// \class GeomAlgoAPI_Boolean +/// \ingroup DataAlgo +/// \brief Allows to perform of boolean operations +class GeomAlgoAPI_Boolean : public GeomAlgoAPI_MakeShape { public: - /// Type of booelan operation - enum OperationType{ - BOOL_CUT, ///< Cut objects - BOOL_FUSE, ///< Fuse objects - BOOL_COMMON ///< Take common part of objects - }; - public: + /// Constructor. + /// \param[in] theObject the main object. + /// \param[in] theTool the tool object. + /// \param[in] theOperationType type of boolean operation. + /// \param[in] theFuzzy additional tolerance value. + /// If the fuzzy value is non-positive, the boolean operation will use a default + // additional tolerance value of 1.e-5. + GEOMALGOAPI_EXPORT GeomAlgoAPI_Boolean(const GeomShapePtr theObject, + const GeomShapePtr theTool, + const GeomAlgoAPI_Tools::BOPType theOperationType, + const double theFuzzy = -1); /// Constructor. - GEOMALGOAPI_EXPORT GeomAlgoAPI_Boolean(const ListOfShape& theObjects, + /// \param[in] theObject the main object. + /// \param[in] theTools list of tools. + /// \param[in] theOperationType type of boolean operation. + /// \param[in] theFuzzy additional tolerance value. + /// If the fuzzy value is non-positive, the boolean operation will use a default + // additional tolerance value of 1.e-5. + GEOMALGOAPI_EXPORT GeomAlgoAPI_Boolean(const GeomShapePtr theObject, const ListOfShape& theTools, - const OperationType theOperationType); - - /// \return true if algorithm succeed. - GEOMALGOAPI_EXPORT const bool isDone() const; - - /// \return true if resulting shape is valid. - GEOMALGOAPI_EXPORT const bool isValid() const; + const GeomAlgoAPI_Tools::BOPType theOperationType, + const double theFuzzy = -1); - /// \return result of the boolean algorithm. - GEOMALGOAPI_EXPORT const std::shared_ptr& shape() const; - /// \return map of sub-shapes of the result. To be used for History keeping. - GEOMALGOAPI_EXPORT std::shared_ptr mapOfShapes() const; + /// Constructor. + /// \param[in] theObjects list of main objects. + /// \param[in] theTools list of tools. + /// \param[in] theOperationType type of boolean operation. + /// \param[in] theFuzzy additional tolerance value. + /// If the fuzzy value is non-positive, the boolean operation will use a default + // additional tolerance value of 1.e-5. + GEOMALGOAPI_EXPORT GeomAlgoAPI_Boolean(const ListOfShape& theObjects, + const ListOfShape& theTools, + const GeomAlgoAPI_Tools::BOPType theOperationType, + const double theFuzzy = -1); - /// \return interface for for History processing. - GEOMALGOAPI_EXPORT std::shared_ptr makeShape() const; + /// Redefinition of the generic method for the Fuse problem: OCCT 30481 + GEOMALGOAPI_EXPORT virtual void modified(const GeomShapePtr theOldShape, + ListOfShape& theNewShapes); private: /// Builds resulting shape. void build(const ListOfShape& theObjects, const ListOfShape& theTools, - const OperationType theOperationType); - -private: - /// Fields. - bool myDone; - std::shared_ptr myShape; - std::shared_ptr myMap; - std::shared_ptr myMkShape; + const GeomAlgoAPI_Tools::BOPType theOperationType, + const double theFuzzy); }; #endif