// SPDX-License-Identifier: LGPL-2.1-or-later /*************************************************************************** * Copyright (c) 2024 Eric Price (CorvusCorax) * * * * * * This file is part of FreeCAD. * * * * FreeCAD 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. * * * * FreeCAD 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 FreeCAD. If not, see * * . * * * **************************************************************************/ /** * FCBRepAlgoAPI provides a wrapper for various OCCT functions. */ #include #include #include #include #include #include #include FCBRepAlgoAPI_BooleanOperation::FCBRepAlgoAPI_BooleanOperation() { SetRunParallel(Standard_True); SetNonDestructive(Standard_True); } FCBRepAlgoAPI_BooleanOperation::FCBRepAlgoAPI_BooleanOperation(const TopoDS_Shape& theS1, const TopoDS_Shape& theS2, const BOPAlgo_Operation theOperation) : BRepAlgoAPI_BooleanOperation(theS1, theS2, theOperation) { if (!BRepCheck_Analyzer(theS1).IsValid()){ Standard_ConstructionError::Raise("Base shape is not valid for boolean operation"); } if (! BRepCheck_Analyzer(theS2).IsValid()){ Standard_ConstructionError::Raise("Tool shape is not valid for boolean operation"); } setAutoFuzzy(); SetRunParallel(Standard_True); SetNonDestructive(Standard_True); } void FCBRepAlgoAPI_BooleanOperation::setAutoFuzzy() { FCBRepAlgoAPIHelper::setAutoFuzzy(this); } void FCBRepAlgoAPIHelper::setAutoFuzzy(BRepAlgoAPI_BooleanOperation* op) { Bnd_Box bounds; for (TopTools_ListOfShape::Iterator it(op->Arguments()); it.More(); it.Next()) BRepBndLib::Add(it.Value(), bounds); for (TopTools_ListOfShape::Iterator it(op->Tools()); it.More(); it.Next()) BRepBndLib::Add(it.Value(), bounds); op->SetFuzzyValue(Part::FuzzyHelper::getBooleanFuzzy() * sqrt(bounds.SquareExtent()) * Precision::Confusion()); } void FCBRepAlgoAPIHelper::setAutoFuzzy(BRepAlgoAPI_BuilderAlgo* op) { Bnd_Box bounds; for (TopTools_ListOfShape::Iterator it(op->Arguments()); it.More(); it.Next()) BRepBndLib::Add(it.Value(), bounds); op->SetFuzzyValue(Part::FuzzyHelper::getBooleanFuzzy() * sqrt(bounds.SquareExtent()) * Precision::Confusion()); }