mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
Implementation of Fuzzy Boolean operations. Such operations allow to perform Boolean operations on the shapes with near-coincidence between the entities of these shapes, i.e. between shapes in which some entities from one shape are intended to be coincide with some entities from the other, but the coincidence is not precise. API for Boolean operations has been improved to have a possibility to add new options. Modified entities: 1. New option of setting additional tolerance have been added to the following classes: class BOPAlgo_ArgumentAnalyzer class BOPAlgo_BOP class BOPAlgo_Builder class BOPAlgo_MakerVolume class BOPAlgo_PaveFiller class BOPDS_DS class BRepAlgoAPI_BooleanOperation class BRepAlgoAPI_Check class BRepAlgoAPI_Common class BRepAlgoAPI_Cut class BRepAlgoAPI_Fuse class BRepAlgoAPI_Section 2. Following draw commands have been modified to support new functionality: BOP commands: bop b1 b2 [tol] bcommon r b1 b2 [tol] bcut r b1 b2 [tol] bfuse r b1 b2 [tol] bsection r s1 s2 [-n2d/-n2d1/-n2d2] [-na] [tol] mkvolume r b1 b2 ... [-c] [-ni] [-s] [tol] bfillds [-s -t] [tol] Check commands: bopcheck Shape [level of check: 0 - 9] [-t -s] [-tol tol] bopargcheck [-F/O/C/T/S/U] [/R|F|T|V|E|I|P|C|S]] [#BF] [-tol tol] 3. Two new classes have been added to API to provide the root interface for algorithms class BRepAlgoAPI_Algo class BRepAlgoAPI_BuilderAlgo Fix to eliminate the warning. Test-cases for issue #25477
206 lines
6.5 KiB
C++
206 lines
6.5 KiB
C++
// Created on: 2012-12-17
|
|
// Created by: Eugeny MALTCHIKOV
|
|
// Copyright (c) 2012-2014 OPEN CASCADE SAS
|
|
//
|
|
// This file is part of Open CASCADE Technology software library.
|
|
//
|
|
// This library is free software; you can redistribute it and/or modify it under
|
|
// the terms of the GNU Lesser General Public License version 2.1 as published
|
|
// by the Free Software Foundation, with special exception defined in the file
|
|
// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
|
|
// distribution for complete text of the license and disclaimer of any warranty.
|
|
//
|
|
// Alternatively, this file may be used under the terms of Open CASCADE
|
|
// commercial license or contractual agreement.
|
|
|
|
#include <BRepAlgoAPI_Check.ixx>
|
|
#include <BOPAlgo_ArgumentAnalyzer.hxx>
|
|
#include <BRepCheck_Analyzer.hxx>
|
|
|
|
//=======================================================================
|
|
//function : BRepAlgoAPI_Check
|
|
//purpose :
|
|
//=======================================================================
|
|
BRepAlgoAPI_Check::BRepAlgoAPI_Check()
|
|
:
|
|
BRepAlgoAPI_Algo(),
|
|
myAnalyzer(NULL),
|
|
myFuzzyValue(0.)
|
|
{
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : BRepAlgoAPI_Check
|
|
//purpose :
|
|
//=======================================================================
|
|
BRepAlgoAPI_Check::BRepAlgoAPI_Check(const TopoDS_Shape& theS,
|
|
const Standard_Boolean bTestSE,
|
|
const Standard_Boolean bTestSI)
|
|
: BRepAlgoAPI_Algo(),
|
|
myFuzzyValue(0.)
|
|
{
|
|
Init(theS, TopoDS_Shape(), BOPAlgo_UNKNOWN, bTestSE, bTestSI);
|
|
//
|
|
Perform();
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : BRepAlgoAPI_Check
|
|
//purpose :
|
|
//=======================================================================
|
|
BRepAlgoAPI_Check::BRepAlgoAPI_Check(const TopoDS_Shape& theS1,
|
|
const TopoDS_Shape& theS2,
|
|
const BOPAlgo_Operation theOp,
|
|
const Standard_Boolean bTestSE,
|
|
const Standard_Boolean bTestSI)
|
|
: BRepAlgoAPI_Algo(),
|
|
myFuzzyValue(0.)
|
|
{
|
|
Init(theS1, theS2, theOp, bTestSE, bTestSI);
|
|
//
|
|
Perform();
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : ~BRepAlgoAPI_Check
|
|
//purpose :
|
|
//=======================================================================
|
|
BRepAlgoAPI_Check::~BRepAlgoAPI_Check()
|
|
{
|
|
if(myAnalyzer){
|
|
delete myAnalyzer;
|
|
myAnalyzer=NULL;
|
|
}
|
|
myResult.Clear();
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : SetFuzzyValue
|
|
//purpose :
|
|
//=======================================================================
|
|
void BRepAlgoAPI_Check::SetFuzzyValue(const Standard_Real theFuzz)
|
|
{
|
|
if (theFuzz > 0.) {
|
|
myFuzzyValue = theFuzz;
|
|
}
|
|
}
|
|
//=======================================================================
|
|
//function : FuzzyValue
|
|
//purpose :
|
|
//=======================================================================
|
|
Standard_Real BRepAlgoAPI_Check::FuzzyValue() const
|
|
{
|
|
return myFuzzyValue;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : SetData
|
|
//purpose :
|
|
//=======================================================================
|
|
void BRepAlgoAPI_Check::SetData(const TopoDS_Shape& theS,
|
|
const Standard_Boolean bTestSE,
|
|
const Standard_Boolean bTestSI)
|
|
{
|
|
Init(theS, TopoDS_Shape(), BOPAlgo_UNKNOWN, bTestSE, bTestSI);
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : SetData
|
|
//purpose :
|
|
//=======================================================================
|
|
void BRepAlgoAPI_Check::SetData(const TopoDS_Shape& theS1,
|
|
const TopoDS_Shape& theS2,
|
|
const BOPAlgo_Operation theOp,
|
|
const Standard_Boolean bTestSE,
|
|
const Standard_Boolean bTestSI)
|
|
{
|
|
Init(theS1, theS2, theOp, bTestSE, bTestSI);
|
|
}
|
|
//=======================================================================
|
|
//function : Init
|
|
//purpose :
|
|
//=======================================================================
|
|
void BRepAlgoAPI_Check::Init(const TopoDS_Shape& theS1,
|
|
const TopoDS_Shape& theS2,
|
|
const BOPAlgo_Operation theOp,
|
|
const Standard_Boolean bTestSE,
|
|
const Standard_Boolean bTestSI)
|
|
{
|
|
myResult.Clear();
|
|
myS1 = theS1;
|
|
myS2 = theS2;
|
|
//
|
|
myAnalyzer = new BOPAlgo_ArgumentAnalyzer();
|
|
//
|
|
myAnalyzer->SetShape1(myS1);
|
|
myAnalyzer->SetShape2(myS2);
|
|
myAnalyzer->OperationType() = theOp;
|
|
myAnalyzer->ArgumentTypeMode() = Standard_True;
|
|
myAnalyzer->SmallEdgeMode() = bTestSE;
|
|
myAnalyzer->SelfInterMode() = bTestSI;
|
|
//
|
|
myAnalyzer->SetRunParallel(myRunParallel);
|
|
myAnalyzer->SetProgressIndicator(myProgressIndicator);
|
|
myAnalyzer->SetFuzzyValue(myFuzzyValue);
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : Result
|
|
//purpose :
|
|
//=======================================================================
|
|
const BOPAlgo_ListOfCheckResult& BRepAlgoAPI_Check::Result()
|
|
{
|
|
return myResult;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : IsValid
|
|
//purpose :
|
|
//=======================================================================
|
|
Standard_Boolean BRepAlgoAPI_Check::IsValid()
|
|
{
|
|
return myResult.IsEmpty();
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : Perform
|
|
//purpose :
|
|
//=======================================================================
|
|
void BRepAlgoAPI_Check::Perform()
|
|
{
|
|
Standard_Boolean isS1, isS2;
|
|
//incompatibility of shape types, small edges and self-interference
|
|
myAnalyzer->Perform();
|
|
if (myAnalyzer->HasFaulty()) {
|
|
myResult = myAnalyzer->GetCheckResult();
|
|
}
|
|
|
|
//topological validity
|
|
isS1 = !myS1.IsNull();
|
|
isS2 = !myS2.IsNull();
|
|
if (isS1) {
|
|
BRepCheck_Analyzer anS1(myS1);
|
|
isS1 = anS1.IsValid();
|
|
} else {
|
|
isS1 = Standard_True;
|
|
}
|
|
//
|
|
if (isS2) {
|
|
BRepCheck_Analyzer anS2(myS2);
|
|
isS2 = anS2.IsValid();
|
|
} else {
|
|
isS2 = Standard_True;
|
|
}
|
|
if (!isS1 || !isS2) {
|
|
BOPAlgo_CheckResult aRes;
|
|
aRes.SetCheckStatus(BOPAlgo_NotValid);
|
|
if (!isS1) {
|
|
aRes.SetShape1(myS1);
|
|
}
|
|
if (!isS1) {
|
|
aRes.SetShape2(myS2);
|
|
}
|
|
myResult.Append(aRes);
|
|
}
|
|
}
|