mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-04 18:06:22 +03:00
When fuzzy option is in force prevent increasing tolerance of input shapes. Instead pass increased by fuzzy value the tolerances of sub-shapes everywhere where it is needed by intersection algorithms. The following changes in API have been made: - The methods SetFuzzyValue and FuzzyValue have been moved from the classes BOPAlgo_ArgumentAnalyzer, BOPAlgo_Builder, and BOPAlgo_PaveFiller to the base class BOPAlgo_Algo. - The public method BOPDS_DS::VerticesOnIn has been renamed to SubShapesOnIn, and the new output parameter theCommonPB has been added. - In BOPTools_AlgoTools, a new argument "theFuzzyValue" has been added in the methods ComputeVV and AreFacesSameDomain. - In IntTools_Context, a new argument "theFuzzyValue" has been added in the methods ComputeVE and ComputeVF. - The methods SetFuzzyValue and FuzzyValue have been added in the classes IntTools_EdgeEdge, IntTools_FaceFace. - In the class IntTools_EdgeFace, the methods SetTolE, SetTolF, TolE, TolF have been removed, and the methods SetFuzzyValue, FuzzyValue have been added. - The new argument "theTol" has been added in the method IntTools_WLineTool::DecompositionOfWLine. Some improvements in algorithms have been made during fighting with regressions: - Correct initialization of pave blocks for degenerated edges. - In BOPAlgo_PaveFiller::MakeBlocks(), filter out paves on intersection curve that were put on the curve accidentally due to wide range of E-F intersection vertex. - In the method IntTools_Tools::ComputeTolerance the margin added to the computed tolerance has been increased up to 0.001%. - The method BOPAlgo_PaveFiller::PutPaveOnCurve has been corrected in order to use the original vertex tolerance instead of the value increased during putting it on other curves. - The new method BOPDS_PaveBlock::RemoveExtPave has been added. - The vertex tolerance computation in BOPTools_AlgoTools::CorrectCurveOnSurface has been improved, taking into account intersection segments between p-curves (to avoid regression on "bugs modalg_6 bug22794"). - Improve IsExistingPaveBlock to make more stable catching of coincidence of common block with section curve (against regression "bugs modalg_4 bug697_2" on Linux). Test case for the bug has been added. The following test cases have been updated as improvements: boolean gdml_private ZH2 ZI7 ZJ7 boolean volumemaker C4 The test case bugs/modalg_4/pro19653 has been corrected to make it stable. See comment inside the script for details. The test case bugs/modalg_6/bug25880 has been corrected to suppress wrong bfuse commands. The test bugs/modalg_6/bug26954_3 has been corrected to compare the result with more precise reference value. The "faulty" TODO in boolean/volumemaker/A8 has been made actual for Linux as well. //Eliminate compilation error on Linux.
181 lines
5.1 KiB
C++
181 lines
5.1 KiB
C++
// Created on: 2000-11-23
|
|
// Created by: Michael KLOKOV
|
|
// Copyright (c) 2000-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.
|
|
|
|
#ifndef _IntTools_FaceFace_HeaderFile
|
|
#define _IntTools_FaceFace_HeaderFile
|
|
|
|
#include <Standard.hxx>
|
|
#include <Standard_DefineAlloc.hxx>
|
|
#include <Standard_Handle.hxx>
|
|
|
|
#include <Standard_Boolean.hxx>
|
|
#include <IntPatch_Intersection.hxx>
|
|
#include <GeomInt_LineConstructor.hxx>
|
|
#include <Standard_Integer.hxx>
|
|
#include <Standard_Real.hxx>
|
|
#include <IntTools_SequenceOfCurves.hxx>
|
|
#include <TopoDS_Face.hxx>
|
|
#include <IntTools_SequenceOfPntOn2Faces.hxx>
|
|
#include <IntSurf_ListOfPntOn2S.hxx>
|
|
class GeomAdaptor_HSurface;
|
|
class IntTools_Context;
|
|
class StdFail_NotDone;
|
|
class TopoDS_Face;
|
|
class Adaptor3d_TopolTool;
|
|
|
|
|
|
//! This class provides the intersection of
|
|
//! face's underlying surfaces.
|
|
class IntTools_FaceFace
|
|
{
|
|
public:
|
|
|
|
DEFINE_STANDARD_ALLOC
|
|
|
|
|
|
|
|
//! Empty constructor.
|
|
Standard_EXPORT IntTools_FaceFace();
|
|
|
|
|
|
//! Modifier
|
|
Standard_EXPORT void SetParameters (const Standard_Boolean ApproxCurves, const Standard_Boolean ComputeCurveOnS1, const Standard_Boolean ComputeCurveOnS2, const Standard_Real ApproximationTolerance);
|
|
|
|
|
|
//! Intersects underliing surfaces of F1 and F2
|
|
//! Use sum of tolerance of F1 and F2 as intersection
|
|
//! criteria
|
|
Standard_EXPORT void Perform (const TopoDS_Face& F1, const TopoDS_Face& F2);
|
|
|
|
|
|
//! Returns True if the intersection was successful
|
|
Standard_EXPORT Standard_Boolean IsDone() const;
|
|
|
|
|
|
//! Returns sequence of 3d curves as result of intersection
|
|
Standard_EXPORT const IntTools_SequenceOfCurves& Lines() const;
|
|
|
|
|
|
//! Returns sequence of 3d curves as result of intersection
|
|
Standard_EXPORT const IntTools_SequenceOfPntOn2Faces& Points() const;
|
|
|
|
|
|
//! Returns tolerance reached during approximation,
|
|
//! and possibly increased to cover more area due to a small angle between surfaces.
|
|
//! If approximation was not done, returns zero.
|
|
Standard_EXPORT Standard_Real TolReached3d() const;
|
|
|
|
//! Returns tolerance reached during approximation, without any increase.
|
|
//! If approximation was not done, returns zero.
|
|
Standard_EXPORT Standard_Real TolReal() const;
|
|
|
|
//! Returns tolerance reached during approximation.
|
|
//! If approximation was not done, returns zero.
|
|
Standard_EXPORT Standard_Real TolReached2d() const;
|
|
|
|
|
|
//! Returns first of processed faces
|
|
Standard_EXPORT const TopoDS_Face& Face1() const;
|
|
|
|
|
|
//! Returns second of processed faces
|
|
Standard_EXPORT const TopoDS_Face& Face2() const;
|
|
|
|
|
|
//! Returns True if faces are tangent
|
|
Standard_EXPORT Standard_Boolean TangentFaces() const;
|
|
|
|
|
|
//! Provides post-processing the result lines.
|
|
//! <bToSplit> - the flag.
|
|
//! In case of <bToSplit> is true the closed 3D-curves will be splitted
|
|
//! on parts.
|
|
//! In case of <bToSplit> is false the closed 3D-curves remain untouched.
|
|
Standard_EXPORT void PrepareLines3D (const Standard_Boolean bToSplit = Standard_True);
|
|
|
|
Standard_EXPORT void SetList (IntSurf_ListOfPntOn2S& ListOfPnts);
|
|
|
|
|
|
//! Sets the intersecton context
|
|
Standard_EXPORT void SetContext (const Handle(IntTools_Context)& aContext);
|
|
|
|
//! Sets the Fuzzy value
|
|
void SetFuzzyValue (const Standard_Real theFuzz);
|
|
|
|
|
|
//! Returns Fuzzy value
|
|
Standard_Real FuzzyValue() const;
|
|
|
|
//! Gets the intersecton context
|
|
Standard_EXPORT const Handle(IntTools_Context)& Context() const;
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
Standard_EXPORT void MakeCurve (const Standard_Integer Index,
|
|
const Handle(Adaptor3d_TopolTool)& D1,
|
|
const Handle(Adaptor3d_TopolTool)& D2,
|
|
const Standard_Real theToler);
|
|
|
|
Standard_EXPORT void ComputeTolReached3d();
|
|
|
|
Standard_EXPORT Standard_Real ComputeTolerance();
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
Standard_Boolean myIsDone;
|
|
IntPatch_Intersection myIntersector;
|
|
GeomInt_LineConstructor myLConstruct;
|
|
Handle(GeomAdaptor_HSurface) myHS1;
|
|
Handle(GeomAdaptor_HSurface) myHS2;
|
|
Standard_Integer myNbrestr;
|
|
Standard_Real myTolReached2d;
|
|
Standard_Real myTolReached3d;
|
|
Standard_Real myTolReal;
|
|
Standard_Boolean myApprox;
|
|
Standard_Boolean myApprox1;
|
|
Standard_Boolean myApprox2;
|
|
Standard_Real myTolApprox;
|
|
Standard_Real myTolF1;
|
|
Standard_Real myTolF2;
|
|
Standard_Real myTol;
|
|
Standard_Real myFuzzyValue;
|
|
IntTools_SequenceOfCurves mySeqOfCurve;
|
|
Standard_Boolean myTangentFaces;
|
|
TopoDS_Face myFace1;
|
|
TopoDS_Face myFace2;
|
|
IntTools_SequenceOfPntOn2Faces myPnts;
|
|
IntSurf_ListOfPntOn2S myListOfPnts;
|
|
Handle(IntTools_Context) myContext;
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#endif // _IntTools_FaceFace_HeaderFile
|