PAL8378: fix a bug in Partition algorithm

This commit is contained in:
jfa 2005-04-11 05:44:10 +00:00
parent 6288e136f4
commit 0213ec6649
3 changed files with 219 additions and 184 deletions

View File

@ -375,6 +375,9 @@ is
PrepareSetForFace(me:out; PrepareSetForFace(me:out;
nF1 :Integer from Standard; nF1 :Integer from Standard;
nF2 :Integer from Standard; nF2 :Integer from Standard;
--modified by NIZNHY-PKV Fri Apr 1 11:19:15 2005f
aLPB: ListOfPaveBlock from BOPTools;
--modified by NIZNHY-PKV Fri Apr 1 10:54:16 2005t
aPSF:out PaveSet from BOPTools); aPSF:out PaveSet from BOPTools);
PutPaveOnCurve(me:out; PutPaveOnCurve(me:out;
@ -405,10 +408,18 @@ is
aTol: Real from Standard) aTol: Real from Standard)
returns Integer from Standard; returns Integer from Standard;
-- IsExistingPaveBlock (me:out;
-- aPB : PaveBlock from BOPTools;
-- aFF : SSInterference from BOPTools)
-- returns Boolean from Standard;
--modified by NIZNHY-PKV Fri Apr 1 09:35:34 2005f
IsExistingPaveBlock (me:out; IsExistingPaveBlock (me:out;
aPB : PaveBlock from BOPTools; aPB : PaveBlock from BOPTools;
aFF : SSInterference from BOPTools) aLPB: ListOfPaveBlock from BOPTools;
aTol: Real from Standard)
returns Boolean from Standard; returns Boolean from Standard;
--modified by NIZNHY-PKV Fri Apr 1 09:35:39 2005t
MakePCurves (me:out); MakePCurves (me:out);

View File

@ -1,16 +1,23 @@
// File generated by CPPExt (Value) // File generated by CPPExt (Value)
// Copyright (C) 1991,1995 by
// //
// MATRA DATAVISION, FRANCE // Copyright (C) 1991 - 2000 by
// Matra Datavision SA. All rights reserved.
// //
// This software is furnished in accordance with the terms and conditions // Copyright (C) 2001 - 2004 by
// of the contract and with the inclusion of the above copyright notice. // Open CASCADE SA. All rights reserved.
// This software or any other copy thereof may not be provided or otherwise
// be made available to any other person. No title to an ownership of the
// software is hereby transferred.
// //
// At the termination of the contract, the software and all copies of this // This file is part of the Open CASCADE Technology software.
// software must be deleted. //
// This software may be distributed and/or modified under the terms and
// conditions of the Open CASCADE Public License as defined by Open CASCADE SA
// and appearing in the file LICENSE included in the packaging of this file.
//
// This software is distributed on an "AS IS" basis, without warranty of any
// kind, and Open CASCADE SA hereby disclaims all such warranties,
// including without limitation, any warranties of merchantability, fitness
// for a particular purpose or non-infringement. Please see the License for
// the specific terms and conditions governing rights and limitations under the
// License.
#ifndef _NMTTools_PaveFiller_HeaderFile #ifndef _NMTTools_PaveFiller_HeaderFile
#define _NMTTools_PaveFiller_HeaderFile #define _NMTTools_PaveFiller_HeaderFile
@ -139,13 +146,13 @@ Standard_EXPORT void RealSplitsInFace(const Standard_Integer nE1,const Standar
Standard_EXPORT void RealSplitsOnEdge(const Standard_Integer nE1,const Standard_Integer nE2,BOPTools_ListOfPaveBlock& aLs) ; Standard_EXPORT void RealSplitsOnEdge(const Standard_Integer nE1,const Standard_Integer nE2,BOPTools_ListOfPaveBlock& aLs) ;
Standard_EXPORT void RealSplitsOnFace(const Standard_Integer nE1,const Standard_Integer nF2,BOPTools_ListOfPaveBlock& aLs) ; Standard_EXPORT void RealSplitsOnFace(const Standard_Integer nE1,const Standard_Integer nF2,BOPTools_ListOfPaveBlock& aLs) ;
Standard_EXPORT void RealSplitsOnFace(const Standard_Integer aBid,const Standard_Integer nF1,const Standard_Integer nF2,BOPTools_ListOfPaveBlock& aLs) ; Standard_EXPORT void RealSplitsOnFace(const Standard_Integer aBid,const Standard_Integer nF1,const Standard_Integer nF2,BOPTools_ListOfPaveBlock& aLs) ;
Standard_EXPORT void PrepareSetForFace(const Standard_Integer nF1,const Standard_Integer nF2,BOPTools_PaveSet& aPSF) ; Standard_EXPORT void PrepareSetForFace(const Standard_Integer nF1,const Standard_Integer nF2,const BOPTools_ListOfPaveBlock& aLPB,BOPTools_PaveSet& aPSF) ;
Standard_EXPORT void PutPaveOnCurve(const BOPTools_PaveSet& aPSF,const Standard_Real aTol,BOPTools_Curve& aBC) ; Standard_EXPORT void PutPaveOnCurve(const BOPTools_PaveSet& aPSF,const Standard_Real aTol,BOPTools_Curve& aBC) ;
Standard_EXPORT void PutBoundPaveOnCurve(BOPTools_Curve& aBC,BOPTools_SSInterference& aFF) ; Standard_EXPORT void PutBoundPaveOnCurve(BOPTools_Curve& aBC,BOPTools_SSInterference& aFF) ;
Standard_EXPORT void PutBoundPaveOnCurve(const gp_Pnt& aP,const Standard_Real aT,BOPTools_Curve& aBC,BOPTools_SSInterference& aFF) ; Standard_EXPORT void PutBoundPaveOnCurve(const gp_Pnt& aP,const Standard_Real aT,BOPTools_Curve& aBC,BOPTools_SSInterference& aFF) ;
Standard_EXPORT Standard_Boolean FindPave(const gp_Pnt& aP,const Standard_Real aTpV,const BOPTools_PaveSet& aPS,BOPTools_Pave& aPV) ; Standard_EXPORT Standard_Boolean FindPave(const gp_Pnt& aP,const Standard_Real aTpV,const BOPTools_PaveSet& aPS,BOPTools_Pave& aPV) ;
Standard_EXPORT Standard_Integer CheckIntermediatePoint(const BOPTools_PaveBlock& aPB,const BOPTools_PaveBlock& aPBR,const Standard_Real aTol) ; Standard_EXPORT Standard_Integer CheckIntermediatePoint(const BOPTools_PaveBlock& aPB,const BOPTools_PaveBlock& aPBR,const Standard_Real aTol) ;
Standard_EXPORT Standard_Boolean IsExistingPaveBlock(const BOPTools_PaveBlock& aPB,const BOPTools_SSInterference& aFF) ; Standard_EXPORT Standard_Boolean IsExistingPaveBlock(const BOPTools_PaveBlock& aPB,const BOPTools_ListOfPaveBlock& aLPB,const Standard_Real aTol) ;
Standard_EXPORT void MakePCurves() ; Standard_EXPORT void MakePCurves() ;

View File

@ -64,9 +64,6 @@
#include <NMTTools_Tools.hxx> #include <NMTTools_Tools.hxx>
#include <BRepLib.hxx> #include <BRepLib.hxx>
#include <Geom2d_TrimmedCurve.hxx> #include <Geom2d_TrimmedCurve.hxx>
//
#include <Geom_Surface.hxx>
#include <TopLoc_Location.hxx>
static static
Standard_Boolean IsPairFound(const Standard_Integer nF1, Standard_Boolean IsPairFound(const Standard_Integer nF1,
@ -87,6 +84,7 @@ static
Standard_Boolean IsFound(const TColStd_IndexedMapOfInteger& aMapWhat, Standard_Boolean IsFound(const TColStd_IndexedMapOfInteger& aMapWhat,
const TColStd_IndexedMapOfInteger& aMapWith); const TColStd_IndexedMapOfInteger& aMapWith);
//======================================================================= //=======================================================================
// function: PerformFF // function: PerformFF
// purpose: // purpose:
@ -223,9 +221,9 @@ static
Standard_Integer i, aNbFFs, nF1, nF2, aBid=0; Standard_Integer i, aNbFFs, nF1, nF2, aBid=0;
Standard_Integer nV1, nV2, j, aNbCurves; Standard_Integer nV1, nV2, j, aNbCurves;
Standard_Real aTolR3D, aTol2D, aT1, aT2, aTolPPC=Precision::PConfusion(); Standard_Real aTolR3D, aTol2D, aT1, aT2, aTolPPC=Precision::PConfusion();
TColStd_MapOfInteger aMap;
NMTTools_IndexedDataMapOfShapePaveBlock aMEPB; NMTTools_IndexedDataMapOfShapePaveBlock aMEPB;
BooleanOperations_IndexedDataMapOfShapeInteger aMapEI; BooleanOperations_IndexedDataMapOfShapeInteger aMapEI;
BOPTools_ListIteratorOfListOfPaveBlock anIt;
// //
BOPTools_CArray1OfSSInterference& aFFs=myIntrPool->SSInterferences(); BOPTools_CArray1OfSSInterference& aFFs=myIntrPool->SSInterferences();
// //
@ -241,21 +239,50 @@ static
const TopoDS_Face& aF1=TopoDS::Face(myDS->Shape(nF1)); const TopoDS_Face& aF1=TopoDS::Face(myDS->Shape(nF1));
const TopoDS_Face& aF2=TopoDS::Face(myDS->Shape(nF2)); const TopoDS_Face& aF2=TopoDS::Face(myDS->Shape(nF2));
// //
// Add blocks that are existing ones for this FF-interference BOPTools_ListOfPaveBlock aLPB, aLPBC;
BOPTools_ListOfPaveBlock aLPB; //
//modified by NIZNHY-PKV Fri Mar 11 15:43:02 2005 f
{
Standard_Integer nFj1, nFj2, nE;
TColStd_IndexedMapOfInteger aMFence;
BOPTools_ListOfPaveBlock aLPBCx;
//
for (j=1; j<=aNbFFs; ++j) {
BOPTools_SSInterference& aFFj=aFFs(j);
aFFj.Indices(nFj1, nFj2);
//
if ((nF1==nFj1 && nFj2!=nF2) ||
(nF1==nFj2 && nFj1!=nF2) ||
(nF2==nFj1 && nFj2!=nF1) ||
(nF2==nFj2 && nFj1!=nF1)) {
RealSplitsInFace (aBid, nFj1, nFj2, aLPBCx);
RealSplitsInFace (aBid, nFj2, nFj1, aLPBCx);
RealSplitsOnFace (aBid, nFj1, nFj2, aLPBCx);
}
}
//
anIt.Initialize(aLPBCx);
for (; anIt.More(); anIt.Next()) {
const BOPTools_PaveBlock& aPBCx=anIt.Value();
//
nE=aPBCx.Edge();
if (!aMFence.Contains(nE)) {
aMFence.Add(nE);
aLPBC.Append(aPBCx);
}
}
}
//
//modified by NIZNHY-PKV Fri Apr 1 09:49:57 2005t
//
RealSplitsInFace (aBid, nF1, nF2, aLPB); RealSplitsInFace (aBid, nF1, nF2, aLPB);
RealSplitsInFace (aBid, nF2, nF1, aLPB); RealSplitsInFace (aBid, nF2, nF1, aLPB);
RealSplitsOnFace (aBid, nF1, nF2, aLPB); RealSplitsOnFace (aBid, nF1, nF2, aLPB);
// //
aMap.Clear(); anIt.Initialize(aLPB);
BOPTools_ListIteratorOfListOfPaveBlock anIt(aLPB);
for (; anIt.More(); anIt.Next()) { for (; anIt.More(); anIt.Next()) {
const BOPTools_PaveBlock& aPB=anIt.Value(); const BOPTools_PaveBlock& aPB=anIt.Value();
aFFi.AppendBlock(aPB); aFFi.AppendBlock(aPB);
nV1=aPB.Pave1().Index();
nV2=aPB.Pave2().Index();
aMap.Add(nV1);
aMap.Add(nV2);
} }
// //
BOPTools_SequenceOfCurves& aSCvs=aFFi.Curves(); BOPTools_SequenceOfCurves& aSCvs=aFFi.Curves();
@ -269,7 +296,10 @@ static
// //
BOPTools_PaveSet aPSF; BOPTools_PaveSet aPSF;
// //
PrepareSetForFace (nF1, nF2, aPSF); //modified by NIZNHY-PKV Fri Apr 1 10:53:09 2005f
PrepareSetForFace (nF1, nF2, aLPBC, aPSF);
//PrepareSetForFace (nF1, nF2, aPSF);
//modified by NIZNHY-PKV Thu Mar 31 16:16:47 2005t
// //
// Put Paves On Curves // Put Paves On Curves
for (j=1; j<=aNbCurves; ++j) { for (j=1; j<=aNbCurves; ++j) {
@ -309,11 +339,20 @@ static
continue;// mkk ft continue;// mkk ft
} }
// //
bIsExistingPaveBlock=IsExistingPaveBlock(aPBNew, aFFi); //modified by NIZNHY-PKV Fri Apr 1 09:56:11 2005f
// 1
const BOPTools_ListOfPaveBlock& aLPBFF=aFFi.PaveBlocks();
bIsExistingPaveBlock=IsExistingPaveBlock(aPBNew, aLPBFF, aTolR3D);
//bIsExistingPaveBlock=IsExistingPaveBlock(aPBNew, aFFi);
if (bIsExistingPaveBlock) { if (bIsExistingPaveBlock) {
// aPBNew was (or just lays) boundary PB
continue; continue;
} }
// 2
bIsExistingPaveBlock=IsExistingPaveBlock(aPBNew, aLPBC, aTolR3D);
if (bIsExistingPaveBlock) {
continue;
}
//modified by NIZNHY-PKV Fri Apr 1 09:56:14 2005t
// Checking of validity in 2D // Checking of validity in 2D
// //
bIsValidIn2D=myContext.IsValidBlockForFaces(aT1, aT2, aIC, aF1, aF2, aTol2D); bIsValidIn2D=myContext.IsValidBlockForFaces(aT1, aT2, aIC, aF1, aF2, aTol2D);
@ -527,9 +566,10 @@ static
// //
if (aCBAPI.IsCommonBlock(aPB)) { if (aCBAPI.IsCommonBlock(aPB)) {
// it can be Common Block // it can be Common Block
Standard_Real aTolEx; Standard_Boolean bHasPCOnF, bFound;
Handle(Geom2d_Curve) aC2D1, aC2D2; Standard_Integer nF, k, nEOrx, nF1x, nF2x;
TopoDS_Face aF1FWD, aF2FWD; Standard_Real aTolEx, aT1x, aT2x;
BOPTools_ListIteratorOfListOfPaveBlock aItPBx;
// //
NMTTools_CommonBlock& aCB=aCBAPI.CommonBlock(aPB); NMTTools_CommonBlock& aCB=aCBAPI.CommonBlock(aPB);
const BOPTools_ListOfPaveBlock& aLPBx=aCB.PaveBlocks(); const BOPTools_ListOfPaveBlock& aLPBx=aCB.PaveBlocks();
@ -539,18 +579,49 @@ static
const TopoDS_Edge& aEx=TopoDS::Edge(tDS.Shape(mE)); const TopoDS_Edge& aEx=TopoDS::Edge(tDS.Shape(mE));
aTolEx=BRep_Tool::Tolerance(aEx); aTolEx=BRep_Tool::Tolerance(aEx);
// //
//modified by NIZNHY-PKV Mon Dec 27 14:30:15 2004 f for (k=0; k<2; ++k) {
nF=(!k) ? nF1 : nF2;
const TopoDS_Face& aF=TopoDS::Face(myDS->Shape(nF));
// //
aF1FWD=aF1; bHasPCOnF=BOPTools_Tools2D::HasCurveOnSurface(aEx, aF);
aF1FWD.Orientation(TopAbs_FORWARD); if (bHasPCOnF) {
NMTTools_Tools::MakePCurve(aEx, aF1FWD, aC2D1, aTolEx); continue;
}
// //
aF2FWD=aF2; bFound=Standard_False;
aF2FWD.Orientation(TopAbs_FORWARD); aItPBx.Initialize(aLPBx);
NMTTools_Tools::MakePCurve(aEx, aF2FWD, aC2D2, aTolEx); for (; aItPBx.More(); aItPBx.Next()) {
BOPTools_PaveBlock& aPBx=aIt.Value();
nEOrx=aPBx.OriginalEdge();
const TopoDS_Shape& aEOrx=tDS.Shape(nEOrx);
BOPTools_PaveBlock& aPBSEx=aMEPB.ChangeFromKey(aEOrx);
aT1x=aPBSEx.Pave1().Param();
aT2x=aPBSEx.Pave2().Param();
const IntTools_Curve& aICx=aPBSEx.Curve();
// //
// block A has been removed nF1x=aPBSEx.Face1();
//modified by NIZNHY-PKV Mon Dec 27 14:33:26 2004 t nF2x=aPBSEx.Face2();
//
if (nF1x==nF) {
Handle(Geom2d_Curve) aC2D1x=aICx.FirstCurve2d();
Handle(Geom2d_TrimmedCurve)aC2D1xT =new Geom2d_TrimmedCurve(aC2D1x, aT1x, aT2x);
aBB.UpdateEdge(aEx, aC2D1xT, aF, aTolEx);
bFound=!bFound;
break;
}
//
if (nF2x==nF) {
Handle(Geom2d_Curve) aC2D2x=aICx.SecondCurve2d();
Handle(Geom2d_TrimmedCurve)aC2D2xT =new Geom2d_TrimmedCurve(aC2D2x, aT1x, aT2x);
aBB.UpdateEdge(aEx, aC2D2xT, aF, aTolEx);
bFound=!bFound;
break;
}
}
if (bFound){
BRepLib::SameParameter(aEx, aTolEx, Standard_True);
}
}
} //if (aCBAPI.IsCommonBlock(aPB)) } //if (aCBAPI.IsCommonBlock(aPB))
// //
// new SE // new SE
@ -648,106 +719,25 @@ static
BOPTools_Tools2D::BuildPCurveForEdgeOnFace(aE, aF1FWD); BOPTools_Tools2D::BuildPCurveForEdgeOnFace(aE, aF1FWD);
BOPTools_Tools2D::BuildPCurveForEdgeOnFace(aE, aF2FWD); BOPTools_Tools2D::BuildPCurveForEdgeOnFace(aE, aF2FWD);
} }
//
// Section Edges processing
/*
Standard_Integer aNbCurves, k, aNbV;
Standard_Real aTolEdge, aTolR2D, aTolFact, aTolV, aTolVmax;
BRep_Builder aBB;
//
BOPTools_SequenceOfCurves& aSC=aFF.Curves();
aNbCurves=aSC.Length();
if (!aNbCurves) {
continue;
} }
//
const BOPTools_Curve& aBC=aSC(1);
const BOPTools_ListOfPaveBlock& aLPB=aBC.NewPaveBlocks();
anIt.Initialize(aLPB);
for (; anIt.More(); anIt.Next()) {
const BOPTools_PaveBlock& aPB=anIt.Value();
nE=aPB.Edge();
const TopoDS_Edge& aE=TopoDS::Edge(myDS->Shape(nE));
//
aTolEdge=BRep_Tool::Tolerance(aE);
aTolR2D=aFF.TolR2D();
aTolFact=Max(aTolEdge, aTolR2D);
//
// Check vertices tolerances and correct them if necessary
// to prevent situation when TolE > TolV
//
TopTools_IndexedMapOfShape aVMap;
TopExp::MapShapes(aE, TopAbs_VERTEX, aVMap);
aTolVmax=-1.;
aNbV=aVMap.Extent();
for (k=1; k<=aNbV; ++k) {
const TopoDS_Vertex& aV=TopoDS::Vertex(aVMap(k));
aTolV=BRep_Tool::Tolerance(aV);
if (aTolV>aTolVmax) {
aTolVmax=aTolV;
}
}
//
if (aTolFact>aTolVmax) {
aTolFact=aTolVmax;
}
//
Standard_Real aTFirst, aTLast, aOutFirst, aOutLast, aOutTol;
Handle(Geom2d_Curve) aC2D1, aC2D1A, aC2D2, aC2D2A;
Handle(Geom_TrimmedCurve)aC3DETrim;
//
const Handle(Geom_Curve)& aC3DE=BRep_Tool::Curve(aE, aTFirst, aTLast);
aC3DETrim=new Geom_TrimmedCurve(aC3DE, aTFirst, aTLast);
//
// first P-Curve
BOPTools_Tools2D::BuildPCurveForEdgeOnFace(aE, aF1FWD);
BOPTools_Tools2D::CurveOnSurface(aE, aF1FWD, aC2D1, aOutFirst, aOutLast, aOutTol, Standard_True);
//
if (aC3DE->IsPeriodic()) {
BOPTools_Tools2D::AdjustPCurveOnFace(aF1FWD, aTFirst, aTLast, aC2D1, aC2D1A);
}
else {
BOPTools_Tools2D::AdjustPCurveOnFace(aF1FWD, aC3DETrim, aC2D1, aC2D1A);
}
//
aBB.UpdateEdge(aE, aC2D1A, aF1FWD, aTolFact);
//
// second P-Curve
BOPTools_Tools2D::BuildPCurveForEdgeOnFace(aE, aF2FWD);
BOPTools_Tools2D::CurveOnSurface(aE, aF2FWD, aC2D2, aOutFirst, aOutLast, aOutTol, Standard_True);
//
if (aC3DE->IsPeriodic()) {
BOPTools_Tools2D::AdjustPCurveOnFace(aF2FWD, aTFirst, aTLast, aC2D2, aC2D2A);
}
else {
BOPTools_Tools2D::AdjustPCurveOnFace(aF2FWD, aC3DETrim, aC2D2, aC2D2A);
}
//
aBB.UpdateEdge(aE, aC2D2A, aF2FWD, aTolFact);
}
*/
}
} }
//modified by NIZNHY-PKV Fri Apr 1 09:36:06 2005f
//======================================================================= //=======================================================================
// function: IsExistingPaveBlock // function: IsExistingPaveBlock
// purpose: // purpose:
//======================================================================= //=======================================================================
Standard_Boolean NMTTools_PaveFiller::IsExistingPaveBlock(const BOPTools_PaveBlock& aPBNew, Standard_Boolean NMTTools_PaveFiller::IsExistingPaveBlock(const BOPTools_PaveBlock& aPBNew,
const BOPTools_SSInterference& aFFi) const BOPTools_ListOfPaveBlock& aLPBR,
const Standard_Real aTolR3D)
{ {
Standard_Boolean bFlag=Standard_False; Standard_Boolean bFlag;
Standard_Integer nVNew1, nVNew2, nV1, nV2, iC; Standard_Integer nVNew1, nVNew2, nV1, nV2, iC;
Standard_Real aTolR3D;
BOPTools_ListIteratorOfListOfPaveBlock anIt; BOPTools_ListIteratorOfListOfPaveBlock anIt;
// //
aTolR3D=aFFi.TolR3D(); bFlag=Standard_False;
//
nVNew1=aPBNew.Pave1().Index(); nVNew1=aPBNew.Pave1().Index();
nVNew2=aPBNew.Pave2().Index(); nVNew2=aPBNew.Pave2().Index();
// //
const BOPTools_ListOfPaveBlock& aLPBR=aFFi.PaveBlocks();
anIt.Initialize(aLPBR); anIt.Initialize(aLPBR);
for (; anIt.More(); anIt.Next()) { for (; anIt.More(); anIt.Next()) {
const BOPTools_PaveBlock& aPBR=anIt.Value(); const BOPTools_PaveBlock& aPBR=anIt.Value();
@ -763,6 +753,7 @@ static
} }
return bFlag; return bFlag;
} }
//modified by NIZNHY-PKV Fri Apr 1 09:36:06 2005t
//======================================================================= //=======================================================================
// function: CheckIntermediatePoint // function: CheckIntermediatePoint
// purpose: // purpose:
@ -929,19 +920,35 @@ static
//======================================================================= //=======================================================================
void NMTTools_PaveFiller::PrepareSetForFace(const Standard_Integer nF1, void NMTTools_PaveFiller::PrepareSetForFace(const Standard_Integer nF1,
const Standard_Integer nF2, const Standard_Integer nF2,
const BOPTools_ListOfPaveBlock& aLPBC,
BOPTools_PaveSet& aPSF) BOPTools_PaveSet& aPSF)
{ {
Standard_Integer nV1, nV2; Standard_Integer nV1, nV2;
TColStd_MapOfInteger aMap; TColStd_MapOfInteger aMap;
BOPTools_ListOfPaveBlock aLPB1, aLPB2; BOPTools_ListOfPaveBlock aLPB1, aLPB2, aLPBS;
BOPTools_ListIteratorOfListOfPaveBlock anIt; BOPTools_ListIteratorOfListOfPaveBlock anIt;
// //
RealSplitsFace(nF1, aLPB1); RealSplitsFace(nF1, aLPB1);
RealSplitsFace(nF2, aLPB2);
//
aLPB1.Append(aLPB2);
//
anIt.Initialize(aLPB1); anIt.Initialize(aLPB1);
for (; anIt.More(); anIt.Next()) {
const BOPTools_PaveBlock& aPB=anIt.Value();
aLPBS.Append(aPB);
}
//
RealSplitsFace(nF2, aLPB2);
anIt.Initialize(aLPB2);
for (; anIt.More(); anIt.Next()) {
const BOPTools_PaveBlock& aPB=anIt.Value();
aLPBS.Append(aPB);
}
//
anIt.Initialize(aLPBC);
for (; anIt.More(); anIt.Next()) {
const BOPTools_PaveBlock& aPB=anIt.Value();
aLPBS.Append(aPB);
}
//
anIt.Initialize(aLPBS);
for (; anIt.More(); anIt.Next()) { for (; anIt.More(); anIt.Next()) {
const BOPTools_PaveBlock& aPB=anIt.Value(); const BOPTools_PaveBlock& aPB=anIt.Value();
const BOPTools_Pave& aPave1=aPB.Pave1(); const BOPTools_Pave& aPave1=aPB.Pave1();
@ -1121,48 +1128,58 @@ Standard_Boolean IsFound(const TColStd_IndexedMapOfInteger& aMapWhat,
return bFlag; return bFlag;
} }
/* /*
// block A //=======================================================================
for (k=0; k<2; ++k) { // function: PrepareSetForFace
nF=(!k) ? nF1 : nF2; // purpose:
const TopoDS_Face& aF=TopoDS::Face(myDS->Shape(nF)); //=======================================================================
void NMTTools_PaveFiller::PrepareSetForFace(const Standard_Integer nF1,
const Standard_Integer nF2,
BOPTools_PaveSet& aPSF)
{
Standard_Integer nV1, nV2;
TColStd_MapOfInteger aMap;
BOPTools_ListOfPaveBlock aLPB1, aLPB2;
BOPTools_ListIteratorOfListOfPaveBlock anIt;
// //
bHasPCOnF=BOPTools_Tools2D::HasCurveOnSurface(aEx, aF); RealSplitsFace(nF1, aLPB1);
if (bHasPCOnF) { RealSplitsFace(nF2, aLPB2);
continue;
}
// //
bFound=Standard_False; aLPB1.Append(aLPB2);
aItPBx.Initialize(aLPBx);
for (; aItPBx.More(); aItPBx.Next()) {
BOPTools_PaveBlock& aPBx=aIt.Value();
nEOrx=aPBx.OriginalEdge();
const TopoDS_Shape& aEOrx=tDS.Shape(nEOrx);
BOPTools_PaveBlock& aPBSEx=aMEPB.ChangeFromKey(aEOrx);
aT1x=aPBSEx.Pave1().Param();
aT2x=aPBSEx.Pave2().Param();
const IntTools_Curve& aICx=aPBSEx.Curve();
// //
nF1x=aPBSEx.Face1(); anIt.Initialize(aLPB1);
nF2x=aPBSEx.Face2(); for (; anIt.More(); anIt.Next()) {
const BOPTools_PaveBlock& aPB=anIt.Value();
const BOPTools_Pave& aPave1=aPB.Pave1();
nV1=aPave1.Index();
if (!aMap.Contains(nV1)) {
aMap.Add(nV1);
aPSF.Append(aPave1);
}
const BOPTools_Pave& aPave2=aPB.Pave2();
nV2=aPave2.Index();
if (!aMap.Contains(nV2)) {
aMap.Add(nV2);
aPSF.Append(aPave2);
}
}
}
*/
/*
//=======================================================================
// function: IsExistingPaveBlock
// purpose:
//=======================================================================
Standard_Boolean NMTTools_PaveFiller::IsExistingPaveBlock(const BOPTools_PaveBlock& aPBNew,
const BOPTools_SSInterference& aFFi)
{
Standard_Boolean bFlag;
Standard_Real aTolR3D;
// //
if (nF1x==nF) { aTolR3D=aFFi.TolR3D();
Handle(Geom2d_Curve) aC2D1x=aICx.FirstCurve2d(); const BOPTools_ListOfPaveBlock& aLPBR=aFFi.PaveBlocks();
Handle(Geom2d_TrimmedCurve)aC2D1xT =new Geom2d_TrimmedCurve(aC2D1x, aT1x, aT2x);
aBB.UpdateEdge(aEx, aC2D1xT, aF, aTolEx);
bFound=!bFound;
break;
}
// //
if (nF2x==nF) { bFlag=IsExistingPaveBlock(aPBNew, aLPBR, aTolR3D);
Handle(Geom2d_Curve) aC2D2x=aICx.SecondCurve2d(); //
Handle(Geom2d_TrimmedCurve)aC2D2xT =new Geom2d_TrimmedCurve(aC2D2x, aT1x, aT2x); return bFlag;
aBB.UpdateEdge(aEx, aC2D2xT, aF, aTolEx); }
bFound=!bFound; */
break;
}
}
if (bFound){
BRepLib::SameParameter(aEx, aTolEx, Standard_True);
}
}
*/