mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
"endl" manipulator for Message_Messenger is renamed to "Message_EndLine". The following entities from std namespace are now used with std:: explicitly specified (from Standard_Stream.hxx): std::istream,std::ostream,std::ofstream,std::ifstream,std::fstream, std::filebuf,std::streambuf,std::streampos,std::ios,std::cout,std::cerr, std::cin,std::endl,std::ends,std::flush,std::setw,std::setprecision, std::hex,std::dec.
1329 lines
41 KiB
C++
1329 lines
41 KiB
C++
// Created on: 1996-02-13
|
|
// Created by: Olga KOULECHOVA
|
|
// Copyright (c) 1996-1999 Matra Datavision
|
|
// Copyright (c) 1999-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 <Bnd_Box.hxx>
|
|
#include <BRep_Tool.hxx>
|
|
#include <BRep_Builder.hxx>
|
|
#include <BRepAlgo.hxx>
|
|
#include <BRepAlgoAPI_BooleanOperation.hxx>
|
|
#include <BRepAlgoAPI_Cut.hxx>
|
|
#include <BRepAlgoAPI_Fuse.hxx>
|
|
#include <BRepBndLib.hxx>
|
|
#include <BRepCheck_Analyzer.hxx>
|
|
#include <BRepFeat.hxx>
|
|
#include <BRepFeat_Builder.hxx>
|
|
#include <BRepFeat_Form.hxx>
|
|
#include <BRepLib.hxx>
|
|
#include <BRepTools_Modifier.hxx>
|
|
#include <BRepTools_TrsfModification.hxx>
|
|
#include <ElCLib.hxx>
|
|
#include <Geom_ConicalSurface.hxx>
|
|
#include <Geom_Curve.hxx>
|
|
#include <Geom_CylindricalSurface.hxx>
|
|
#include <Geom_Plane.hxx>
|
|
#include <Geom_RectangularTrimmedSurface.hxx>
|
|
#include <LocOpe.hxx>
|
|
#include <LocOpe_BuildShape.hxx>
|
|
#include <LocOpe_CSIntersector.hxx>
|
|
#include <LocOpe_FindEdges.hxx>
|
|
#include <LocOpe_Gluer.hxx>
|
|
#include <LocOpe_PntFace.hxx>
|
|
#include <LocOpe_SequenceOfCirc.hxx>
|
|
#include <Precision.hxx>
|
|
#include <Standard_NoSuchObject.hxx>
|
|
#include <TColgp_SequenceOfPnt.hxx>
|
|
#include <TopExp_Explorer.hxx>
|
|
#include <TopoDS.hxx>
|
|
#include <TopoDS_Compound.hxx>
|
|
#include <TopoDS_Shape.hxx>
|
|
#include <TopoDS_Solid.hxx>
|
|
#include <TopTools_DataMapIteratorOfDataMapOfShapeListOfShape.hxx>
|
|
#include <TopTools_DataMapIteratorOfDataMapOfShapeShape.hxx>
|
|
#include <TopTools_ListIteratorOfListOfShape.hxx>
|
|
#include <TopTools_MapIteratorOfMapOfShape.hxx>
|
|
#include <TopTools_MapOfShape.hxx>
|
|
|
|
#ifdef OCCT_DEBUG
|
|
extern Standard_Boolean BRepFeat_GettraceFEAT();
|
|
#endif
|
|
|
|
static void Descendants(const TopoDS_Shape&,
|
|
BRepFeat_Builder&,
|
|
TopTools_MapOfShape&);
|
|
|
|
//=======================================================================
|
|
//function : Perform
|
|
//purpose : topological reconstruction of the result
|
|
//=======================================================================
|
|
void BRepFeat_Form::GlobalPerform ()
|
|
{
|
|
|
|
#ifdef OCCT_DEBUG
|
|
Standard_Boolean trc = BRepFeat_GettraceFEAT();
|
|
if (trc) std::cout << "BRepFeat_Form::GlobalPerform ()" << std::endl;
|
|
#endif
|
|
|
|
if (!mySbOK || !myGSOK || !mySFOK || !mySUOK || !myGFOK ||
|
|
!mySkOK || !myPSOK) {
|
|
#ifdef OCCT_DEBUG
|
|
if (trc) std::cout << " Fields not initialized in BRepFeat_Form" << std::endl;
|
|
#endif
|
|
myStatusError = BRepFeat_NotInitialized;
|
|
NotDone();
|
|
return;
|
|
}
|
|
|
|
//--- Initialisation
|
|
TopExp_Explorer exp,exp2;
|
|
Standard_Integer theOpe = 2;
|
|
TopTools_DataMapIteratorOfDataMapOfShapeShape itm;
|
|
|
|
if(myJustFeat && !myFuse) {
|
|
#ifdef OCCT_DEBUG
|
|
if (trc) std::cout << " Invalid option : myJustFeat + Cut" << std::endl;
|
|
#endif
|
|
myStatusError = BRepFeat_InvOption;
|
|
NotDone();
|
|
return;
|
|
}
|
|
else if(myJustFeat) {
|
|
theOpe = 2;
|
|
}
|
|
else if (!myGluedF.IsEmpty()) {
|
|
theOpe = 1;
|
|
}
|
|
else {}
|
|
Standard_Boolean ChangeOpe = Standard_False;
|
|
|
|
Standard_Boolean FromInShape = Standard_False;
|
|
Standard_Boolean UntilInShape = Standard_False;
|
|
|
|
if (!mySFrom.IsNull()) {
|
|
FromInShape = Standard_True;
|
|
for (exp2.Init(mySFrom,TopAbs_FACE); exp2.More(); exp2.Next()) {
|
|
const TopoDS_Shape& ffrom = exp2.Current();
|
|
for (exp.Init(mySbase,TopAbs_FACE); exp.More(); exp.Next()) {
|
|
if (exp.Current().IsSame(ffrom)) {
|
|
break;
|
|
}
|
|
}
|
|
if (!exp.More()) {
|
|
FromInShape = Standard_False;
|
|
#ifdef OCCT_DEBUG
|
|
if (trc) std::cout << " From not in Shape" << std::endl;
|
|
#endif
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!mySUntil.IsNull()) {
|
|
UntilInShape = Standard_True;
|
|
for (exp2.Init(mySUntil,TopAbs_FACE); exp2.More(); exp2.Next()) {
|
|
const TopoDS_Shape& funtil = exp2.Current();
|
|
for (exp.Init(mySbase,TopAbs_FACE); exp.More(); exp.Next()) {
|
|
if (exp.Current().IsSame(funtil)) {
|
|
break;
|
|
}
|
|
}
|
|
if (!exp.More()) {
|
|
UntilInShape = Standard_False;
|
|
#ifdef OCCT_DEBUG
|
|
if (trc) std::cout << " Until not in Shape" << std::endl;
|
|
#endif
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
TopTools_ListIteratorOfListOfShape it,it2;
|
|
Standard_Integer sens = 0;
|
|
|
|
TColGeom_SequenceOfCurve scur;
|
|
Curves(scur);
|
|
|
|
Standard_Real mf, Mf, mu, Mu;
|
|
|
|
TopAbs_Orientation Orifuntil = TopAbs_INTERNAL;
|
|
TopAbs_Orientation Oriffrom = TopAbs_INTERNAL;
|
|
TopoDS_Face FFrom,FUntil;
|
|
|
|
LocOpe_CSIntersector ASI1;
|
|
LocOpe_CSIntersector ASI2;
|
|
|
|
TopTools_ListOfShape IntList;
|
|
IntList.Clear();
|
|
|
|
//--- 1) by intersection
|
|
|
|
// Intersection Tool Shape From
|
|
if (!mySFrom.IsNull()) {
|
|
ASI1.Init(mySFrom);
|
|
ASI1.Perform(scur);
|
|
}
|
|
|
|
// Intersection Tool Shape Until
|
|
if (!mySUntil.IsNull()) {
|
|
ASI2.Init(mySUntil);
|
|
ASI2.Perform(scur);
|
|
}
|
|
|
|
{
|
|
// Find sens, FFrom, FUntil
|
|
for (Standard_Integer jj=1; jj<=scur.Length(); jj++) {
|
|
if (ASI1.IsDone() && ASI2.IsDone()) {
|
|
if (ASI1.NbPoints(jj) <= 0) {
|
|
continue;
|
|
}
|
|
mf = ASI1.Point(jj,1).Parameter();
|
|
Mf = ASI1.Point(jj,ASI1.NbPoints(jj)).Parameter();
|
|
if (ASI2.NbPoints(jj) <= 0) {
|
|
continue;
|
|
}
|
|
mu = ASI2.Point(jj,1).Parameter();
|
|
Mu = ASI2.Point(jj,ASI2.NbPoints(jj)).Parameter();
|
|
if (!scur(jj)->IsPeriodic()) {
|
|
Standard_Integer ku, kf;
|
|
if (! (mu > Mf || mf > Mu)) { //overlapping intervals
|
|
sens = 1;
|
|
kf = 1;
|
|
ku = ASI2.NbPoints(jj);
|
|
}
|
|
else if (mu > Mf) {
|
|
if (sens == -1) {
|
|
myStatusError = BRepFeat_IntervalOverlap;
|
|
NotDone();
|
|
return;
|
|
}
|
|
sens = 1;
|
|
kf = 1;
|
|
ku = ASI2.NbPoints(jj);
|
|
}
|
|
else {
|
|
if (sens == 1) {
|
|
myStatusError = BRepFeat_IntervalOverlap;
|
|
NotDone();
|
|
return;
|
|
}
|
|
sens = -1;
|
|
kf = ASI1.NbPoints(jj);
|
|
ku = 1;
|
|
}
|
|
if (Oriffrom == TopAbs_INTERNAL) {
|
|
TopAbs_Orientation Oript = ASI1.Point(jj,kf).Orientation();
|
|
if (Oript == TopAbs_FORWARD || Oript == TopAbs_REVERSED) {
|
|
if (sens == -1) {
|
|
Oript = TopAbs::Reverse(Oript);
|
|
}
|
|
Oriffrom = TopAbs::Reverse(Oript);
|
|
FFrom = ASI1.Point(jj,kf).Face();
|
|
}
|
|
}
|
|
if (Orifuntil == TopAbs_INTERNAL) {
|
|
TopAbs_Orientation Oript = ASI2.Point(jj,ku).Orientation();
|
|
if (Oript == TopAbs_FORWARD || Oript == TopAbs_REVERSED) {
|
|
if (sens == -1) {
|
|
Oript = TopAbs::Reverse(Oript);
|
|
}
|
|
Orifuntil = Oript;
|
|
FUntil = ASI2.Point(jj,ku).Face();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
else if (ASI2.IsDone()) {
|
|
if (ASI2.NbPoints(jj) <= 0)
|
|
continue;
|
|
|
|
// for base case prism on mySUntil -> ambivalent direction
|
|
// -> preferrable direction = 1
|
|
if(sens != 1) {
|
|
if (ASI2.Point(jj,1).Parameter()*
|
|
ASI2.Point(jj,ASI2.NbPoints(jj)).Parameter()<=0)
|
|
sens=1;
|
|
else if (ASI2.Point(jj,1).Parameter()<0.)
|
|
sens =-1;
|
|
else
|
|
sens =1;
|
|
}
|
|
|
|
Standard_Integer ku;
|
|
if (sens == -1) {
|
|
ku = 1;
|
|
}
|
|
else {
|
|
ku = ASI2.NbPoints(jj);
|
|
}
|
|
if (Orifuntil == TopAbs_INTERNAL && sens != 0) {
|
|
TopAbs_Orientation Oript = ASI2.Point(jj,ku).Orientation();
|
|
if (Oript == TopAbs_FORWARD || Oript == TopAbs_REVERSED) {
|
|
if (sens == -1) {
|
|
Oript = TopAbs::Reverse(Oript);
|
|
}
|
|
Orifuntil = Oript;
|
|
FUntil = ASI2.Point(jj,ku).Face();
|
|
}
|
|
}
|
|
}
|
|
else {
|
|
sens = 1;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
LocOpe_Gluer theGlue;
|
|
|
|
//--- case of gluing
|
|
|
|
if (theOpe == 1) {
|
|
#ifdef OCCT_DEBUG
|
|
if (trc) std::cout << " Gluer" << std::endl;
|
|
#endif
|
|
Standard_Boolean Collage = Standard_True;
|
|
// cut by FFrom && FUntil
|
|
TopoDS_Shape Comp;
|
|
BRep_Builder B;
|
|
B.MakeCompound(TopoDS::Compound(Comp));
|
|
if (!mySFrom.IsNull()) {
|
|
TopoDS_Solid S = BRepFeat::Tool(mySFrom,FFrom,Oriffrom);
|
|
if (!S.IsNull()) {
|
|
B.Add(Comp,S);
|
|
}
|
|
}
|
|
if (!mySUntil.IsNull()) {
|
|
TopoDS_Solid S = BRepFeat::Tool(mySUntil,FUntil,Orifuntil);
|
|
if (!S.IsNull()) {
|
|
B.Add(Comp,S);
|
|
}
|
|
}
|
|
|
|
LocOpe_FindEdges theFE;
|
|
TopTools_DataMapOfShapeListOfShape locmap;
|
|
TopExp_Explorer expp(Comp, TopAbs_SOLID);
|
|
if(expp.More() && !Comp.IsNull() && !myGShape.IsNull()) {
|
|
BRepAlgoAPI_Cut trP(myGShape, Comp);
|
|
exp.Init(trP.Shape(), TopAbs_SOLID);
|
|
if (exp.Current().IsNull()) {
|
|
theOpe = 2;
|
|
ChangeOpe = Standard_True;
|
|
Collage = Standard_False;
|
|
}
|
|
else {// else X0
|
|
// Only solids are preserved
|
|
TopoDS_Shape theGShape;
|
|
B.MakeCompound(TopoDS::Compound(theGShape));
|
|
for (; exp.More(); exp.Next()) {
|
|
B.Add(theGShape,exp.Current());
|
|
}
|
|
if (!BRepAlgo::IsValid(theGShape)) {
|
|
theOpe = 2;
|
|
ChangeOpe = Standard_True;
|
|
Collage = Standard_False;
|
|
}
|
|
else {// else X1
|
|
if(!mySFrom.IsNull()) {
|
|
TopExp_Explorer ex;
|
|
ex.Init(mySFrom, TopAbs_FACE);
|
|
for(; ex.More(); ex.Next()) {
|
|
const TopoDS_Face& fac = TopoDS::Face(ex.Current());
|
|
if (!FromInShape) {
|
|
TopTools_ListOfShape thelist;
|
|
myMap.Bind(fac, thelist);
|
|
}
|
|
else {
|
|
TopTools_ListOfShape thelist1;
|
|
locmap.Bind(fac, thelist1);
|
|
}
|
|
if (trP.IsDeleted(fac)) {
|
|
}
|
|
else if (!FromInShape) {
|
|
myMap(fac) = trP.Modified(fac);
|
|
if (myMap(fac).IsEmpty()) myMap(fac).Append(fac);
|
|
}
|
|
else {
|
|
locmap(fac) =trP.Modified(fac) ;
|
|
if (locmap(fac).IsEmpty()) locmap(fac).Append(fac);
|
|
}
|
|
}
|
|
}// if(!mySFrom.IsNull())
|
|
//
|
|
if(!mySUntil.IsNull()) {
|
|
TopExp_Explorer ex;
|
|
ex.Init(mySUntil, TopAbs_FACE);
|
|
for(; ex.More(); ex.Next()) {
|
|
const TopoDS_Face& fac = TopoDS::Face(ex.Current());
|
|
if (!UntilInShape) {
|
|
TopTools_ListOfShape thelist2;
|
|
myMap.Bind(fac,thelist2);
|
|
}
|
|
else {
|
|
TopTools_ListOfShape thelist3;
|
|
locmap.Bind(fac,thelist3);
|
|
}
|
|
if (trP.IsDeleted(fac)) {
|
|
}
|
|
else if (!UntilInShape) {
|
|
myMap(fac) = trP.Modified(fac);
|
|
if (myMap(fac).IsEmpty()) myMap(fac).Append(fac);
|
|
}
|
|
else {
|
|
locmap(fac) = trP.Modified(fac);
|
|
if (locmap(fac).IsEmpty()) locmap(fac).Append(fac);
|
|
}
|
|
}
|
|
}// if(!mySUntil.IsNull())
|
|
//
|
|
UpdateDescendants(trP,theGShape,Standard_True); // skip faces
|
|
|
|
theGlue.Init(mySbase,theGShape);
|
|
for (itm.Initialize(myGluedF);itm.More();itm.Next()) {
|
|
const TopoDS_Face& gl = TopoDS::Face(itm.Key());
|
|
TopTools_ListOfShape ldsc;
|
|
if (trP.IsDeleted(gl)) {
|
|
}
|
|
else {
|
|
ldsc = trP.Modified(gl);
|
|
if (ldsc.IsEmpty()) ldsc.Append(gl);
|
|
}
|
|
const TopoDS_Face& glface = TopoDS::Face(itm.Value());
|
|
for (it.Initialize(ldsc);it.More();it.Next()) {
|
|
const TopoDS_Face& fac = TopoDS::Face(it.Value());
|
|
Collage = BRepFeat::IsInside(fac, glface);
|
|
if(!Collage) {
|
|
theOpe = 2;
|
|
ChangeOpe = Standard_True;
|
|
break;
|
|
}
|
|
else {
|
|
theGlue.Bind(fac,glface);
|
|
theFE.Set(fac,glface);
|
|
for (theFE.InitIterator(); theFE.More();theFE.Next()) {
|
|
theGlue.Bind(theFE.EdgeFrom(),theFE.EdgeTo());
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}// else X1
|
|
}// else X0
|
|
}// if(expp.More() && !Comp.IsNull() && !myGShape.IsNull())
|
|
else {
|
|
theGlue.Init(mySbase,myGShape);
|
|
for (itm.Initialize(myGluedF); itm.More();itm.Next()) {
|
|
const TopoDS_Face& glface = TopoDS::Face(itm.Key());
|
|
const TopoDS_Face& fac = TopoDS::Face(myGluedF(glface));
|
|
for (exp.Init(myGShape,TopAbs_FACE); exp.More(); exp.Next()) {
|
|
if (exp.Current().IsSame(glface)) {
|
|
break;
|
|
}
|
|
}
|
|
if (exp.More()) {
|
|
Collage = BRepFeat::IsInside(glface, fac);
|
|
if(!Collage) {
|
|
theOpe = 2;
|
|
ChangeOpe = Standard_True;
|
|
break;
|
|
}
|
|
else {
|
|
theGlue.Bind(glface, fac);
|
|
theFE.Set(glface, fac);
|
|
for (theFE.InitIterator(); theFE.More();theFE.Next()) {
|
|
theGlue.Bind(theFE.EdgeFrom(),theFE.EdgeTo());
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
// Add gluing on start and end face if necessary !!!
|
|
if (FromInShape && Collage) {
|
|
TopExp_Explorer ex(mySFrom,TopAbs_FACE);
|
|
for(; ex.More(); ex.Next()) {
|
|
const TopoDS_Face& fac2 = TopoDS::Face(ex.Current());
|
|
// for (it.Initialize(myMap(fac2)); it.More(); it.Next()) {
|
|
for (it.Initialize(locmap(fac2)); it.More(); it.Next()) {
|
|
const TopoDS_Face& fac1 = TopoDS::Face(it.Value());
|
|
theFE.Set(fac1, fac2);
|
|
theGlue.Bind(fac1, fac2);
|
|
for (theFE.InitIterator(); theFE.More();theFE.Next()) {
|
|
theGlue.Bind(theFE.EdgeFrom(),theFE.EdgeTo());
|
|
}
|
|
}
|
|
// myMap.UnBind(fac2);
|
|
}
|
|
}
|
|
|
|
if (UntilInShape && Collage) {
|
|
TopExp_Explorer ex(mySUntil, TopAbs_FACE);
|
|
for(; ex.More(); ex.Next()) {
|
|
const TopoDS_Face& fac2 = TopoDS::Face(ex.Current());
|
|
// for (it.Initialize(myMap(fac2)); it.More(); it.Next()) {
|
|
for (it.Initialize(locmap(fac2)); it.More(); it.Next()) {
|
|
const TopoDS_Face& fac1 = TopoDS::Face(it.Value());
|
|
theGlue.Bind(fac1, fac2);
|
|
theFE.Set(fac1, fac2);
|
|
for (theFE.InitIterator(); theFE.More();theFE.Next()) {
|
|
theGlue.Bind(theFE.EdgeFrom(),theFE.EdgeTo());
|
|
}
|
|
}
|
|
//myMap.UnBind(fac2); // to avoid fac2 in Map when
|
|
// UpdateDescendants(theGlue) is called
|
|
}
|
|
}
|
|
|
|
LocOpe_Operation ope = theGlue.OpeType();
|
|
if (ope == LocOpe_INVALID ||
|
|
(myFuse && ope != LocOpe_FUSE) ||
|
|
(!myFuse && ope != LocOpe_CUT) ||
|
|
(!Collage)) {
|
|
theOpe = 2;
|
|
ChangeOpe = Standard_True;
|
|
}
|
|
}
|
|
|
|
//--- if the gluing is always applicable
|
|
|
|
if (theOpe == 1) {
|
|
#ifdef OCCT_DEBUG
|
|
if (trc) std::cout << " still Gluer" << std::endl;
|
|
#endif
|
|
theGlue.Perform();
|
|
if (theGlue.IsDone()) {
|
|
TopoDS_Shape shshs = theGlue.ResultingShape();
|
|
// if (BRepOffsetAPI::IsTopologicallyValid(shshs)) {
|
|
if (BRepAlgo::IsValid(shshs)) {
|
|
UpdateDescendants(theGlue);
|
|
myNewEdges = theGlue.Edges();
|
|
myTgtEdges = theGlue.TgtEdges();
|
|
#ifdef OCCT_DEBUG
|
|
if (trc) std::cout << " Gluer result" << std::endl;
|
|
#endif
|
|
Done();
|
|
myShape = theGlue.ResultingShape();
|
|
}
|
|
else {
|
|
theOpe = 2;
|
|
ChangeOpe = Standard_True;
|
|
}
|
|
}
|
|
else {
|
|
theOpe = 2;
|
|
ChangeOpe = Standard_True;
|
|
}
|
|
}
|
|
|
|
|
|
//--- case without gluing + Tool with proper dimensions
|
|
|
|
if (theOpe == 2 && ChangeOpe && myJustGluer) {
|
|
#ifdef OCCT_DEBUG
|
|
if (trc) std::cout << " Gluer failure" << std::endl;
|
|
#endif
|
|
myJustGluer = Standard_False;
|
|
theOpe = 0;
|
|
// Done();
|
|
// return;
|
|
}
|
|
|
|
//--- case without gluing
|
|
|
|
if (theOpe == 2) {
|
|
#ifdef OCCT_DEBUG
|
|
if (trc) std::cout << " No Gluer" << std::endl;
|
|
#endif
|
|
TopoDS_Shape theGShape = myGShape;
|
|
if (ChangeOpe) {
|
|
#ifdef OCCT_DEBUG
|
|
if (trc) std::cout << " Passage to topological operations" << std::endl;
|
|
#endif
|
|
}
|
|
|
|
TopoDS_Shape Comp;
|
|
BRep_Builder B;
|
|
B.MakeCompound(TopoDS::Compound(Comp));
|
|
if (!mySFrom.IsNull() || !mySUntil.IsNull()) {
|
|
if (!mySFrom.IsNull() && !FromInShape) {
|
|
TopoDS_Solid S = BRepFeat::Tool(mySFrom,FFrom,Oriffrom);
|
|
if (!S.IsNull()) {
|
|
B.Add(Comp,S);
|
|
}
|
|
}
|
|
if (!mySUntil.IsNull() && !UntilInShape) {
|
|
if (!mySFrom.IsNull()) {
|
|
if (!mySFrom.IsSame(mySUntil)) {
|
|
TopoDS_Solid S = BRepFeat::Tool(mySUntil,FUntil,Orifuntil);
|
|
if (!S.IsNull()) {
|
|
B.Add(Comp,S);
|
|
}
|
|
}
|
|
}
|
|
else {
|
|
TopoDS_Solid S = BRepFeat::Tool(mySUntil,FUntil,Orifuntil);
|
|
if (!S.IsNull()) {
|
|
B.Add(Comp,S);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
// update type of selection
|
|
if(myPerfSelection == BRepFeat_SelectionU && !UntilInShape) {
|
|
myPerfSelection = BRepFeat_NoSelection;
|
|
}
|
|
else if(myPerfSelection == BRepFeat_SelectionFU &&
|
|
!FromInShape && !UntilInShape) {
|
|
myPerfSelection = BRepFeat_NoSelection;
|
|
}
|
|
else if(myPerfSelection == BRepFeat_SelectionShU && !UntilInShape) {
|
|
myPerfSelection = BRepFeat_NoSelection;
|
|
}
|
|
else {}
|
|
|
|
TopExp_Explorer expp(Comp, TopAbs_SOLID);
|
|
if(expp.More() && !Comp.IsNull() && !myGShape.IsNull()) {
|
|
BRepAlgoAPI_Cut trP(myGShape, Comp);
|
|
// the result is necessarily a compound.
|
|
exp.Init(trP.Shape(),TopAbs_SOLID);
|
|
if (!exp.More()) {
|
|
myStatusError = BRepFeat_EmptyCutResult;
|
|
NotDone();
|
|
return;
|
|
}
|
|
// Only solids are preserved
|
|
theGShape.Nullify();
|
|
B.MakeCompound(TopoDS::Compound(theGShape));
|
|
for (; exp.More(); exp.Next()) {
|
|
B.Add(theGShape,exp.Current());
|
|
}
|
|
if (!BRepAlgo::IsValid(theGShape)) {
|
|
myStatusError = BRepFeat_InvShape;
|
|
NotDone();
|
|
return;
|
|
}
|
|
if(!mySFrom.IsNull()) {
|
|
if(!FromInShape) {
|
|
TopExp_Explorer ex(mySFrom, TopAbs_FACE);
|
|
for(; ex.More(); ex.Next()) {
|
|
const TopoDS_Face& fac = TopoDS::Face(ex.Current());
|
|
TopTools_ListOfShape thelist4;
|
|
myMap.Bind(fac,thelist4);
|
|
if (trP.IsDeleted(fac)) {
|
|
}
|
|
else {
|
|
myMap(fac) = trP.Modified(fac);
|
|
if (myMap(fac).IsEmpty()) myMap(fac).Append(fac);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
if(!mySUntil.IsNull()) {
|
|
if(!UntilInShape) {
|
|
TopExp_Explorer ex(mySUntil, TopAbs_FACE);
|
|
for(; ex.More(); ex.Next()) {
|
|
const TopoDS_Face& fac = TopoDS::Face(ex.Current());
|
|
TopTools_ListOfShape thelist5;
|
|
myMap.Bind(fac,thelist5);
|
|
if (trP.IsDeleted(fac)) {
|
|
}
|
|
else {
|
|
myMap(fac) = trP.Modified(fac);
|
|
if (myMap.IsEmpty()) myMap(fac).Append(fac);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
UpdateDescendants(trP,theGShape,Standard_True);
|
|
}//if(expp.More() && !Comp.IsNull() && !myGShape.IsNull()) {
|
|
//
|
|
|
|
//--- generation of "just feature" for assembly = Parts of tool
|
|
Standard_Boolean bFlag = (myPerfSelection == BRepFeat_NoSelection) ? 0 : 1;
|
|
BRepFeat_Builder theBuilder;
|
|
theBuilder.Init(mySbase, theGShape);
|
|
theBuilder.SetOperation(myFuse, bFlag);
|
|
theBuilder.Perform();
|
|
//
|
|
TopTools_ListOfShape lshape;
|
|
theBuilder.PartsOfTool(lshape);
|
|
//
|
|
Standard_Real pbmin = RealLast(), pbmax = RealFirst();
|
|
Standard_Real prmin = RealLast() - 2*Precision::Confusion();
|
|
Standard_Real prmax = RealFirst() + 2*Precision::Confusion();
|
|
Standard_Boolean flag1 = Standard_False;
|
|
Handle(Geom_Curve) C;
|
|
|
|
//--- Selection of pieces of tool to be preserved
|
|
if(!lshape.IsEmpty() && myPerfSelection != BRepFeat_NoSelection) {
|
|
// Find ParametricMinMax depending on the constraints of Shape From and Until
|
|
// -> prmin, prmax, pbmin and pbmax
|
|
C = BarycCurve();
|
|
if (C.IsNull()) {
|
|
myStatusError = BRepFeat_EmptyBaryCurve;
|
|
NotDone();
|
|
return;
|
|
}
|
|
|
|
if(myPerfSelection == BRepFeat_SelectionSh) {
|
|
BRepFeat::ParametricMinMax(mySbase,C,
|
|
prmin, prmax, pbmin, pbmax, flag1);
|
|
}
|
|
else if(myPerfSelection == BRepFeat_SelectionFU) {
|
|
Standard_Real prmin1, prmax1, prmin2, prmax2;
|
|
Standard_Real prbmin1, prbmax1, prbmin2, prbmax2;
|
|
|
|
BRepFeat::ParametricMinMax(mySFrom,C,
|
|
prmin1, prmax1, prbmin1, prbmax1, flag1);
|
|
BRepFeat::ParametricMinMax(mySUntil,C,
|
|
prmin2, prmax2, prbmin2, prbmax2, flag1);
|
|
|
|
// case of revolutions
|
|
if (C->IsPeriodic()) {
|
|
Standard_Real period = C->Period();
|
|
prmax = prmax2;
|
|
if (flag1) {
|
|
prmin = ElCLib::InPeriod(prmin1,prmax-period,prmax);
|
|
}
|
|
else {
|
|
prmin = Min(prmin1, prmin2);
|
|
}
|
|
pbmax = prbmax2;
|
|
pbmin = ElCLib::InPeriod(prbmin1,pbmax-period,pbmax);
|
|
}
|
|
else {
|
|
prmin = Min(prmin1, prmin2);
|
|
prmax = Max(prmax1, prmax2);
|
|
pbmin = Min(prbmin1, prbmin2);
|
|
pbmax = Max(prbmax1, prbmax2);
|
|
}
|
|
}
|
|
else if(myPerfSelection == BRepFeat_SelectionShU) {
|
|
Standard_Real prmin1, prmax1, prmin2, prmax2;
|
|
Standard_Real prbmin1, prbmax1, prbmin2, prbmax2;
|
|
|
|
if(!myJustFeat && sens == 0) sens =1;
|
|
if (sens == 0) {
|
|
myStatusError = BRepFeat_IncDirection;
|
|
NotDone();
|
|
return;
|
|
}
|
|
|
|
BRepFeat::ParametricMinMax(mySUntil,C,
|
|
prmin1, prmax1, prbmin1, prbmax1, flag1);
|
|
|
|
BRepFeat::ParametricMinMax(mySbase,C,
|
|
prmin2, prmax2, prbmin2, prbmax2, flag1);
|
|
if (sens == 1) {
|
|
prmin = prmin2;
|
|
prmax = prmax1;
|
|
pbmin = prbmin2;
|
|
pbmax = prbmax1;
|
|
}
|
|
else if (sens == -1) {
|
|
prmin = prmin1;
|
|
prmax = prmax2;
|
|
pbmin = prbmin1;
|
|
pbmax = prbmax2;
|
|
}
|
|
}
|
|
else if (myPerfSelection == BRepFeat_SelectionU) {
|
|
Standard_Real prmin1, prmax1, prbmin1, prbmax1;
|
|
if (sens == 0) {
|
|
myStatusError = BRepFeat_IncDirection;
|
|
NotDone();
|
|
return;
|
|
}
|
|
|
|
// Find parts of the tool containing descendants of Shape Until
|
|
BRepFeat::ParametricMinMax(mySUntil,C,
|
|
prmin1, prmax1, prbmin1, prbmax1, flag1);
|
|
if (sens == 1) {
|
|
prmin = RealFirst();
|
|
prmax = prmax1;
|
|
pbmin = RealFirst();
|
|
pbmax = prbmax1;
|
|
}
|
|
else if(sens == -1) {
|
|
prmin = prmin1;
|
|
prmax = RealLast();
|
|
pbmin = prbmin1;
|
|
pbmax = RealLast();
|
|
}
|
|
}
|
|
|
|
|
|
// Finer choice of ParametricMinMax in case when the tool
|
|
// intersects Shapes From and Until
|
|
// case of several intersections (keep PartsOfTool according to the selection)
|
|
// position of the face of intersection in PartsOfTool (before or after)
|
|
Standard_Real delta = Precision::Confusion();
|
|
|
|
if (myPerfSelection != BRepFeat_NoSelection) {
|
|
// modif of the test for cts21181 : (prbmax2 and prnmin2) -> (prbmin1 and prbmax1)
|
|
// correction take into account flag2 for pro15323 and flag3 for pro16060
|
|
if (!mySUntil.IsNull()) {
|
|
TopTools_MapOfShape mapFuntil;
|
|
Descendants(mySUntil,theBuilder,mapFuntil);
|
|
if (!mapFuntil.IsEmpty()) {
|
|
for (it.Initialize(lshape); it.More(); it.Next()) {
|
|
TopExp_Explorer expf;
|
|
for (expf.Init(it.Value(),TopAbs_FACE);
|
|
expf.More(); expf.Next()) {
|
|
if (mapFuntil.Contains(expf.Current())) {
|
|
Standard_Boolean flag2,flag3;
|
|
Standard_Real prmin1, prmax1, prbmin1, prbmax1;
|
|
Standard_Real prmin2, prmax2, prbmin2, prbmax2;
|
|
BRepFeat::ParametricMinMax(expf.Current(),C, prmin1, prmax1,
|
|
prbmin1, prbmax1,flag3);
|
|
BRepFeat::ParametricMinMax(it.Value(),C, prmin2, prmax2,
|
|
prbmin2, prbmax2,flag2);
|
|
if (sens == 1) {
|
|
Standard_Boolean testOK = !flag2;
|
|
if (flag2) {
|
|
testOK = !flag1;
|
|
if (flag1 && prmax2 > prmin + delta) {
|
|
testOK = !flag3;
|
|
if (flag3 && prmax1 == prmax2) {
|
|
testOK = Standard_True;
|
|
}
|
|
}
|
|
}
|
|
if (prbmin1 < pbmax && testOK) {
|
|
if (flag2) {
|
|
flag1 = flag2;
|
|
prmax = prmax2;
|
|
}
|
|
pbmax = prbmin1;
|
|
}
|
|
}
|
|
else if (sens == -1){
|
|
Standard_Boolean testOK = !flag2;
|
|
if (flag2) {
|
|
testOK = !flag1;
|
|
if (flag1 && prmin2 < prmax - delta) {
|
|
testOK = !flag3;
|
|
if (flag3 && prmin1 == prmin2) {
|
|
testOK = Standard_True;
|
|
}
|
|
}
|
|
}
|
|
if (prbmax1 > pbmin && testOK) {
|
|
if (flag2) {
|
|
flag1 = flag2;
|
|
prmin = prmin2;
|
|
}
|
|
pbmin = prbmax1;
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
it.Initialize(lshape);
|
|
}
|
|
}
|
|
if (!mySFrom.IsNull()) {
|
|
TopTools_MapOfShape mapFfrom;
|
|
Descendants(mySFrom, theBuilder, mapFfrom);
|
|
if (!mapFfrom.IsEmpty()) {
|
|
for (it.Initialize(lshape); it.More(); it.Next()) {
|
|
TopExp_Explorer expf;
|
|
for (expf.Init(it.Value(),TopAbs_FACE);
|
|
expf.More(); expf.Next()) {
|
|
if (mapFfrom.Contains(expf.Current())) {
|
|
Standard_Boolean flag2,flag3;
|
|
Standard_Real prmin1, prmax1, prbmin1, prbmax1;
|
|
Standard_Real prmin2, prmax2, prbmin2, prbmax2;
|
|
BRepFeat::ParametricMinMax(expf.Current(),C, prmin1, prmax1,
|
|
prbmin1, prbmax1,flag3);
|
|
BRepFeat::ParametricMinMax(it.Value(),C, prmin2, prmax2,
|
|
prbmin2, prbmax2,flag2);
|
|
if (sens == 1) {
|
|
Standard_Boolean testOK = !flag2;
|
|
if (flag2) {
|
|
testOK = !flag1;
|
|
if (flag1 && prmin2 < prmax - delta) {
|
|
testOK = !flag3;
|
|
if (flag3 && prmin1 == prmin2) {
|
|
testOK = Standard_True;
|
|
}
|
|
}
|
|
}
|
|
if (prbmax1 > pbmin && testOK) {
|
|
if (flag2) {
|
|
flag1 = flag2;
|
|
prmin = prmin2;
|
|
}
|
|
pbmin = prbmax1;
|
|
}
|
|
}
|
|
else if (sens == -1){
|
|
Standard_Boolean testOK = !flag2;
|
|
if (flag2) {
|
|
testOK = !flag1;
|
|
if (flag1 && prmax2 > prmin + delta) {
|
|
testOK = !flag3;
|
|
if (flag3 && prmax1 == prmax2) {
|
|
testOK = Standard_True;
|
|
}
|
|
}
|
|
}
|
|
if (prbmin1 < pbmax && testOK) {
|
|
if (flag2) {
|
|
flag1 = flag2;
|
|
prmax = prmax2;
|
|
}
|
|
pbmax = prbmin1;
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
it.Initialize(lshape);
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
// Parse PartsOfTool to preserve or not depending on ParametricMinMax
|
|
if (!myJustFeat) {
|
|
Standard_Boolean KeepParts = Standard_False;
|
|
Standard_Real prmin1, prmax1, prbmin1, prbmax1;
|
|
Standard_Real min, max, pmin, pmax;
|
|
Standard_Boolean flag2;
|
|
for (it.Initialize(lshape); it.More(); it.Next()) {
|
|
if (C->IsPeriodic()) {
|
|
Standard_Real period = C->Period();
|
|
Standard_Real pr, prb;
|
|
BRepFeat::ParametricMinMax(it.Value(),C, pr, prmax1,
|
|
prb, prbmax1,flag2,Standard_True);
|
|
if (flag2) {
|
|
prmin1 = ElCLib::InPeriod(pr,prmax1-period,prmax1);
|
|
}
|
|
else {
|
|
prmin1 = pr;
|
|
}
|
|
prbmin1 = ElCLib::InPeriod(prb,prbmax1-period,prbmax1);
|
|
}
|
|
else {
|
|
BRepFeat::ParametricMinMax(it.Value(),C,
|
|
prmin1, prmax1, prbmin1, prbmax1,flag2);
|
|
}
|
|
if(flag2 == Standard_False || flag1 == Standard_False) {
|
|
pmin = pbmin;
|
|
pmax = pbmax;
|
|
min = prbmin1;
|
|
max = prbmax1;
|
|
}
|
|
else {
|
|
pmin = prmin;
|
|
pmax = prmax;
|
|
min = prmin1;
|
|
max = prmax1;
|
|
}
|
|
if (!((min > pmax - delta) ||
|
|
(max < pmin + delta))) {
|
|
KeepParts = Standard_True;
|
|
const TopoDS_Shape& S = it.Value();
|
|
theBuilder.KeepPart(S);
|
|
}
|
|
}
|
|
|
|
// Case when no part of the tool is preserved
|
|
if (!KeepParts) {
|
|
#ifdef OCCT_DEBUG
|
|
if (trc) std::cout << " No parts of tool kept" << std::endl;
|
|
#endif
|
|
myStatusError = BRepFeat_NoParts;
|
|
NotDone();
|
|
return;
|
|
}
|
|
}
|
|
else {
|
|
// case JustFeature -> all PartsOfTool are preserved
|
|
Standard_Real prmin1, prmax1, prbmin1, prbmax1;
|
|
Standard_Real min, max, pmin, pmax;
|
|
Standard_Boolean flag2;
|
|
TopoDS_Shape Compo;
|
|
B.MakeCompound(TopoDS::Compound(Compo));
|
|
for (it.Initialize(lshape); it.More(); it.Next()) {
|
|
BRepFeat::ParametricMinMax(it.Value(),C,
|
|
prmin1, prmax1, prbmin1, prbmax1,flag2);
|
|
if(flag2 == Standard_False || flag1 == Standard_False) {
|
|
pmin = pbmin;
|
|
pmax = pbmax;
|
|
min = prbmin1;
|
|
max = prbmax1;
|
|
}
|
|
else {
|
|
pmin = prmin;
|
|
pmax = prmax;
|
|
min = prmin1;
|
|
max = prmax1;
|
|
}
|
|
if ((min < pmax - delta) &&
|
|
(max > pmin + delta)){
|
|
if (!it.Value().IsNull()) {
|
|
B.Add(Compo,it.Value());
|
|
}
|
|
}
|
|
}
|
|
myShape = Compo;
|
|
}
|
|
}
|
|
|
|
//--- Generation of result myShape
|
|
|
|
if (!myJustFeat) {
|
|
// removal of edges of section that have no common vertices
|
|
// with PartsOfTool preserved
|
|
if (bFlag) {
|
|
theBuilder.PerformResult();
|
|
myShape = theBuilder.Shape();
|
|
} else {
|
|
myShape = theBuilder.Shape();
|
|
}
|
|
Done();
|
|
}
|
|
else {
|
|
// all is already done
|
|
Done();
|
|
}
|
|
}
|
|
|
|
myStatusError = BRepFeat_OK;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : IsDeleted
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
Standard_Boolean BRepFeat_Form::IsDeleted(const TopoDS_Shape& F)
|
|
{
|
|
return (myMap(F).IsEmpty());
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : Modified
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
const TopTools_ListOfShape& BRepFeat_Form::Modified
|
|
(const TopoDS_Shape& F)
|
|
{
|
|
if (myMap.IsBound(F)) {
|
|
static TopTools_ListOfShape list;
|
|
list.Clear(); // For the second passage DPF
|
|
TopTools_ListIteratorOfListOfShape ite(myMap(F));
|
|
for(; ite.More(); ite.Next()) {
|
|
const TopoDS_Shape& sh = ite.Value();
|
|
if(!sh.IsSame(F))
|
|
list.Append(sh);
|
|
}
|
|
return list;
|
|
}
|
|
return myGenerated; // empty list
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : Generated
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
const TopTools_ListOfShape& BRepFeat_Form::Generated
|
|
(const TopoDS_Shape& S)
|
|
{
|
|
if (myMap.IsBound(S) &&
|
|
S.ShapeType() != TopAbs_FACE) { // check if filter on face or not
|
|
static TopTools_ListOfShape list;
|
|
list.Clear(); // For the second passage DPF
|
|
TopTools_ListIteratorOfListOfShape ite(myMap(S));
|
|
for(; ite.More(); ite.Next()) {
|
|
const TopoDS_Shape& sh = ite.Value();
|
|
if(!sh.IsSame(S))
|
|
list.Append(sh);
|
|
}
|
|
return list;
|
|
}
|
|
else return myGenerated;
|
|
}
|
|
|
|
|
|
|
|
//=======================================================================
|
|
//function : UpdateDescendants
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
void BRepFeat_Form::UpdateDescendants(const LocOpe_Gluer& G)
|
|
{
|
|
TopTools_DataMapIteratorOfDataMapOfShapeListOfShape itdm;
|
|
TopTools_ListIteratorOfListOfShape it,it2;
|
|
TopTools_MapIteratorOfMapOfShape itm;
|
|
|
|
for (itdm.Initialize(myMap);itdm.More();itdm.Next()) {
|
|
const TopoDS_Shape& orig = itdm.Key();
|
|
TopTools_MapOfShape newdsc;
|
|
for (it.Initialize(itdm.Value());it.More();it.Next()) {
|
|
const TopoDS_Face& fdsc = TopoDS::Face(it.Value());
|
|
for (it2.Initialize(G.DescendantFaces(fdsc));
|
|
it2.More();it2.Next()) {
|
|
newdsc.Add(it2.Value());
|
|
}
|
|
}
|
|
myMap.ChangeFind(orig).Clear();
|
|
for (itm.Initialize(newdsc);itm.More();itm.Next()) {
|
|
myMap.ChangeFind(orig).Append(itm.Key());
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//=======================================================================
|
|
//function : FirstShape
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
const TopTools_ListOfShape& BRepFeat_Form::FirstShape() const
|
|
{
|
|
if (!myFShape.IsNull()) {
|
|
return myMap(myFShape);
|
|
}
|
|
return myGenerated; // empty list
|
|
}
|
|
|
|
|
|
//=======================================================================
|
|
//function : LastShape
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
const TopTools_ListOfShape& BRepFeat_Form::LastShape() const
|
|
{
|
|
if (!myLShape.IsNull()) {
|
|
return myMap(myLShape);
|
|
}
|
|
return myGenerated; // empty list
|
|
}
|
|
|
|
|
|
//=======================================================================
|
|
//function : NewEdges
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
const TopTools_ListOfShape& BRepFeat_Form::NewEdges() const
|
|
{
|
|
return myNewEdges;
|
|
}
|
|
|
|
|
|
//=======================================================================
|
|
//function : NewEdges
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
const TopTools_ListOfShape& BRepFeat_Form::TgtEdges() const
|
|
{
|
|
return myTgtEdges;
|
|
}
|
|
|
|
|
|
//=======================================================================
|
|
//function : TransformSUntil
|
|
//purpose : Limitation of the shape until the case of infinite faces
|
|
//=======================================================================
|
|
|
|
Standard_Boolean BRepFeat_Form::TransformShapeFU(const Standard_Integer flag)
|
|
{
|
|
#ifdef OCCT_DEBUG
|
|
Standard_Boolean trc = BRepFeat_GettraceFEAT();
|
|
#endif
|
|
Standard_Boolean Trf = Standard_False;
|
|
|
|
TopoDS_Shape shapefu;
|
|
if(flag == 0)
|
|
shapefu = mySFrom;
|
|
else if(flag == 1)
|
|
shapefu = mySUntil;
|
|
else
|
|
return Trf;
|
|
|
|
TopExp_Explorer exp(shapefu, TopAbs_FACE);
|
|
if (!exp.More()) { // no faces... It is necessary to return an error
|
|
#ifdef OCCT_DEBUG
|
|
if (trc) std::cout << " BRepFeat_Form::TransformShapeFU : invalid Shape" << std::endl;
|
|
#endif
|
|
return Trf;
|
|
}
|
|
|
|
exp.Next();
|
|
if (!exp.More()) { // the only face. Is it infinite?
|
|
exp.ReInit();
|
|
TopoDS_Face fac = TopoDS::Face(exp.Current());
|
|
|
|
Handle(Geom_Surface) S = BRep_Tool::Surface(fac);
|
|
Handle(Standard_Type) styp = S->DynamicType();
|
|
if (styp == STANDARD_TYPE(Geom_RectangularTrimmedSurface)) {
|
|
S = Handle(Geom_RectangularTrimmedSurface)::DownCast(S)->BasisSurface();
|
|
styp = S->DynamicType();
|
|
}
|
|
|
|
if (styp == STANDARD_TYPE(Geom_Plane) ||
|
|
styp == STANDARD_TYPE(Geom_CylindricalSurface) ||
|
|
styp == STANDARD_TYPE(Geom_ConicalSurface)) {
|
|
TopExp_Explorer exp1(fac, TopAbs_WIRE);
|
|
if (!exp1.More()) {
|
|
Trf = Standard_True;
|
|
}
|
|
else {
|
|
Trf = BRep_Tool::NaturalRestriction(fac);
|
|
}
|
|
|
|
}
|
|
if (Trf) {
|
|
BRepFeat::FaceUntil(mySbase, fac);
|
|
}
|
|
|
|
if(flag == 0) {
|
|
TopTools_ListOfShape thelist6;
|
|
myMap.Bind(mySFrom,thelist6);
|
|
myMap(mySFrom).Append(fac);
|
|
mySFrom = fac;
|
|
}
|
|
else if(flag == 1) {
|
|
TopTools_ListOfShape thelist7;
|
|
myMap.Bind(mySUntil,thelist7);
|
|
myMap(mySUntil).Append(fac);
|
|
mySUntil = fac;
|
|
}
|
|
else {
|
|
}
|
|
}
|
|
else {
|
|
for (exp.ReInit(); exp.More(); exp.Next()) {
|
|
const TopoDS_Shape& fac = exp.Current();
|
|
TopTools_ListOfShape thelist8;
|
|
myMap.Bind(fac,thelist8);
|
|
myMap(fac).Append(fac);
|
|
}
|
|
}
|
|
#ifdef OCCT_DEBUG
|
|
if (trc) {
|
|
if (Trf && (flag == 0)) std::cout << " TransformShapeFU From" << std::endl;
|
|
if (Trf && (flag == 1)) std::cout << " TransformShapeFU Until" << std::endl;
|
|
}
|
|
#endif
|
|
return Trf;
|
|
}
|
|
|
|
|
|
//=======================================================================
|
|
//function : CurrentStatusError
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
BRepFeat_StatusError BRepFeat_Form::CurrentStatusError() const
|
|
{
|
|
return myStatusError;
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : Descendants
|
|
//purpose :
|
|
//=======================================================================
|
|
|
|
static void Descendants(const TopoDS_Shape& S,
|
|
BRepFeat_Builder& theFB,
|
|
TopTools_MapOfShape& mapF)
|
|
{
|
|
mapF.Clear();
|
|
TopTools_ListIteratorOfListOfShape it;
|
|
TopExp_Explorer exp;
|
|
for (exp.Init(S,TopAbs_FACE); exp.More(); exp.Next()) {
|
|
|
|
const TopoDS_Face& fdsc = TopoDS::Face(exp.Current());
|
|
const TopTools_ListOfShape& aLM=theFB.Modified(fdsc);
|
|
it.Initialize(aLM);
|
|
for (; it.More(); it.Next()) {
|
|
mapF.Add(it.Value());
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
//=======================================================================
|
|
//function : UpdateDescendants
|
|
//purpose :
|
|
//=======================================================================
|
|
void BRepFeat_Form::UpdateDescendants(const BRepAlgoAPI_BooleanOperation& aBOP,
|
|
const TopoDS_Shape& S,
|
|
const Standard_Boolean SkipFace)
|
|
{
|
|
TopTools_DataMapIteratorOfDataMapOfShapeListOfShape itdm;
|
|
TopTools_ListIteratorOfListOfShape it,it2;
|
|
TopTools_MapIteratorOfMapOfShape itm;
|
|
TopExp_Explorer exp;
|
|
|
|
for (itdm.Initialize(myMap);itdm.More();itdm.Next()) {
|
|
const TopoDS_Shape& orig = itdm.Key();
|
|
if (SkipFace && orig.ShapeType() == TopAbs_FACE) {
|
|
continue;
|
|
}
|
|
TopTools_MapOfShape newdsc;
|
|
|
|
if (itdm.Value().IsEmpty()) {myMap.ChangeFind(orig).Append(orig);}
|
|
|
|
for (it.Initialize(itdm.Value());it.More();it.Next()) {
|
|
const TopoDS_Shape& sh = it.Value();
|
|
if(sh.ShapeType() != TopAbs_FACE) continue;
|
|
const TopoDS_Face& fdsc = TopoDS::Face(it.Value());
|
|
for (exp.Init(S,TopAbs_FACE);exp.More();exp.Next()) {
|
|
if (exp.Current().IsSame(fdsc)) { // preserved
|
|
newdsc.Add(fdsc);
|
|
break;
|
|
}
|
|
}
|
|
if (!exp.More()) {
|
|
BRepAlgoAPI_BooleanOperation* pBOP=(BRepAlgoAPI_BooleanOperation*)&aBOP;
|
|
const TopTools_ListOfShape& aLM=pBOP->Modified(fdsc);
|
|
it2.Initialize(aLM);
|
|
for (; it2.More(); it2.Next()) {
|
|
const TopoDS_Shape& aS=it2.Value();
|
|
newdsc.Add(aS);
|
|
}
|
|
|
|
}
|
|
}
|
|
myMap.ChangeFind(orig).Clear();
|
|
for (itm.Initialize(newdsc); itm.More(); itm.Next()) {
|
|
// check the appartenance to the shape...
|
|
for (exp.Init(S,TopAbs_FACE);exp.More();exp.Next()) {
|
|
if (exp.Current().IsSame(itm.Key())) {
|
|
// const TopoDS_Shape& sh = itm.Key();
|
|
myMap.ChangeFind(orig).Append(itm.Key());
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|