1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-05 18:16:23 +03:00

0024096: Eliminate compiler warning C4505 in MSVC++ with warning level 4

Removed obsolete functions from sources.
Some useful debug functions were 'defined' ( put into #ifdef ...#endif )
Removed some redundant code
This commit is contained in:
omy 2013-08-02 09:54:03 +04:00 committed by bugmaster
parent 7ff8f0197e
commit 4e18e72a22
59 changed files with 80 additions and 3093 deletions

View File

@ -45,6 +45,7 @@
static Standard_Integer IndexOfSection = 0; static Standard_Integer IndexOfSection = 0;
extern Standard_Boolean Blend_GettraceDRAWSECT(); extern Standard_Boolean Blend_GettraceDRAWSECT();
#ifdef DEB_BBPP_N_TRDERIV
//----------------------------------------------------- //-----------------------------------------------------
// For debug : visualisation of the section // For debug : visualisation of the section
static Standard_Boolean BBPP(const Standard_Real param, static Standard_Boolean BBPP(const Standard_Real param,
@ -118,7 +119,7 @@ static void tracederiv(Blend_RstRstFunction& Func,
cout<<"dy estimated : "<<scal*(TP2d1(i).Y()-TP2d2(i).Y())<<endl; cout<<"dy estimated : "<<scal*(TP2d1(i).Y()-TP2d2(i).Y())<<endl;
} }
} }
#endif
//----------------------------------------------------- //-----------------------------------------------------
static void Drawsect(const Standard_Real param, static void Drawsect(const Standard_Real param,
@ -580,7 +581,7 @@ void BRepBlend_RstRstLineBuilder::InternalPerform(Blend_RstRstFunction& Func,
while (!Arrive) { while (!Arrive) {
Standard_Boolean bonpoint = 1; Standard_Boolean bonpoint = 1;
#if 0 #ifdef DEB_BBPP_N_TRDERIV
//debdebdebdebdebdeb //debdebdebdebdebdeb
Func.Set(param); Func.Set(param);
rsnld.Perform(Func, parinit, infbound, supbound); rsnld.Perform(Func, parinit, infbound, supbound);

View File

@ -44,6 +44,7 @@
#endif #endif
static Standard_Integer IndexOfSection = 0; static Standard_Integer IndexOfSection = 0;
extern Standard_Boolean Blend_GettraceDRAWSECT(); extern Standard_Boolean Blend_GettraceDRAWSECT();
#ifdef DEB_BBPP_N_TRDERIV
// for debug : visualisation of the section // for debug : visualisation of the section
static Standard_Boolean BBPP(const Standard_Real param, static Standard_Boolean BBPP(const Standard_Real param,
Blend_SurfRstFunction& Func, Blend_SurfRstFunction& Func,
@ -112,7 +113,7 @@ static void tracederiv(Blend_SurfRstFunction& Func,
cout<<"dy estimated : "<<scal*(TP2d1(i).Y()-TP2d2(i).Y())<<endl; cout<<"dy estimated : "<<scal*(TP2d1(i).Y()-TP2d2(i).Y())<<endl;
} }
} }
#endif
static void Drawsect(const Standard_Real param, static void Drawsect(const Standard_Real param,
Blend_SurfRstFunction& Func) Blend_SurfRstFunction& Func)
{ {
@ -542,7 +543,7 @@ void BRepBlend_SurfRstLineBuilder::InternalPerform(Blend_SurfRstFunction& Func,
while (!Arrive) { while (!Arrive) {
Standard_Boolean bonpoint = 1; Standard_Boolean bonpoint = 1;
#if 0 #ifdef DEB_BBPP_N_TRDERIV
//debdebdebdebdebdeb //debdebdebdebdebdeb
Func.Set(param); Func.Set(param);
rsnld.Perform(Func,parinit,infbound,supbound); rsnld.Perform(Func,parinit,infbound,supbound);

View File

@ -129,16 +129,6 @@
#include <BRepBuilderAPI_BndBoxTreeSelector.hxx> #include <BRepBuilderAPI_BndBoxTreeSelector.hxx>
#include <NCollection_UBTreeFiller.hxx> #include <NCollection_UBTreeFiller.hxx>
static void SortBox (const Handle(Bnd_HArray1OfBox) hSetBoxes,
const Bnd_Box& aBox,
TColStd_ListOfInteger& listIndex)
{
Standard_Integer i, nbBoxes = hSetBoxes->Length();
for (i = 1; i <= nbBoxes; i++)
if (!aBox.IsOut(hSetBoxes->Value(i)))
listIndex.Append(i);
}
//======================================================================= //=======================================================================
//function : SameRange //function : SameRange
//purpose : //purpose :

View File

@ -108,13 +108,6 @@ static void Propagate(const TopTools_IndexedDataMapOfShapeListOfShape&,
const TopoDS_Shape&, // Face const TopoDS_Shape&, // Face
TopTools_MapOfShape&); // mapofface TopTools_MapOfShape&); // mapofface
#ifdef DEB
static TopAbs_Orientation GetOrientation(const TopoDS_Face&,
const TopoDS_Shape&);
#endif
inline Standard_Boolean IsOriented(const TopoDS_Shape& S) inline Standard_Boolean IsOriented(const TopoDS_Shape& S)
{ {
return (S.Orientation() == TopAbs_FORWARD || return (S.Orientation() == TopAbs_FORWARD ||
@ -849,27 +842,6 @@ Standard_Integer BRepCheck_Shell::NbConnectedSet(TopTools_ListOfShape& theSets)
return theSets.Extent(); return theSets.Extent();
} }
//=======================================================================
//function : GetOrientation
//purpose :
//=======================================================================
#ifdef DEB
static TopAbs_Orientation GetOrientation(const TopoDS_Face& F,
const TopoDS_Shape& S)
{
TopExp_Explorer exp;
for (exp.Init(S,TopAbs_FACE); exp.More(); exp.Next()) {
if (exp.Current().IsSame(F)) {
return exp.Current().Orientation();
}
}
return TopAbs_FORWARD; // for compilation
}
#endif
//======================================================================= //=======================================================================
//function : Propagate //function : Propagate
//purpose : //purpose :

View File

@ -94,23 +94,6 @@ static void MajMap(const TopoDS_Shape&,
TopoDS_Shape&, // myFShape TopoDS_Shape&, // myFShape
TopoDS_Shape&); // myLShape TopoDS_Shape&); // myLShape
static void SetGluedFaces(const TopoDS_Face& theSkface,
const TopoDS_Shape& theSbase,
const TopoDS_Shape& thePbase,
const TopTools_DataMapOfShapeListOfShape& theSlmap,
LocOpe_DPrism&,
TopTools_DataMapOfShapeShape&);
#ifdef DEB
static void VerifGluedFaces(const TopoDS_Face& theSkface,
const TopoDS_Shape& thePbase,
Handle(Geom_Curve)& theBCurve,
TColGeom_SequenceOfCurve& theCurves,
LocOpe_DPrism& theDPrism,
TopTools_DataMapOfShapeShape& theMap);
#endif
static Standard_Real HeightMax(const TopoDS_Shape& theSbase, static Standard_Real HeightMax(const TopoDS_Shape& theSbase,
const TopoDS_Face& theSkface, const TopoDS_Face& theSkface,
const TopoDS_Shape& theSFrom, const TopoDS_Shape& theSFrom,
@ -307,7 +290,6 @@ void BRepFeat_MakeDPrism::Perform(const Standard_Real Height)
const TopoDS_Face& ff = TopoDS::Face(exp.Current()); const TopoDS_Face& ff = TopoDS::Face(exp.Current());
if(ToFuse(ff, FFace)) { if(ToFuse(ff, FFace)) {
TopTools_DataMapOfShapeListOfShape sl; TopTools_DataMapOfShapeListOfShape sl;
//SetGluedFaces(ff, mySbase, FFace, sl, theDPrism, myGluedF);
break; break;
} }
} }
@ -315,9 +297,7 @@ void BRepFeat_MakeDPrism::Perform(const Standard_Real Height)
// management of gluing faces // management of gluing faces
//SetGluedFaces(mySkface, mySbase, theBase, mySlface, theDPrism, myGluedF);
GluedFacesValid(); GluedFacesValid();
// VerifGluedFaces(mySkface, theBase, myBCurve, myCurves, theDPrism, myGluedF);
if(!myGluedF.IsEmpty()) { // case gluing if(!myGluedF.IsEmpty()) { // case gluing
myJustGluer = Standard_True; myJustGluer = Standard_True;
@ -407,11 +387,7 @@ void BRepFeat_MakeDPrism::Perform(const TopoDS_Shape& Until)
return; return;
} }
//SetGluedFaces(mySkface, mySbase, theBase, mySlface, theDPrism, myGluedF);
GluedFacesValid(); GluedFacesValid();
// VerifGluedFaces(mySkface, theBase, myBCurve, myCurves, theDPrism, myGluedF);
theDPrism.Curves(myCurves); theDPrism.Curves(myCurves);
myBCurve = theDPrism.BarycCurve(); myBCurve = theDPrism.BarycCurve();
GlobalPerform(); GlobalPerform();
@ -572,7 +548,6 @@ void BRepFeat_MakeDPrism::Perform(const TopoDS_Shape& From,
GeneratedShapeValid(); GeneratedShapeValid();
// management of gluing faces // management of gluing faces
//SetGluedFaces(TopoDS_Face(), // on ne veut pas binder mySkface
// mySbase, myPbase, mySlface, theDPrism, myGluedF); // mySbase, myPbase, mySlface, theDPrism, myGluedF);
GluedFacesValid(); GluedFacesValid();
theDPrism.Curves(myCurves); theDPrism.Curves(myCurves);
@ -983,10 +958,7 @@ void BRepFeat_MakeDPrism::PerformUntilHeight(const TopoDS_Shape& Until,
return; return;
} }
//SetGluedFaces(mySkface, mySbase, theBase, mySlface, theDPrism, myGluedF);
GluedFacesValid(); GluedFacesValid();
// VerifGluedFaces(mySkface, theBase, myBCurve, myCurves, theDPrism, myGluedF);
theDPrism.Curves(myCurves); theDPrism.Curves(myCurves);
myBCurve = theDPrism.BarycCurve(); myBCurve = theDPrism.BarycCurve();
GlobalPerform(); GlobalPerform();
@ -1262,125 +1234,6 @@ Standard_Integer SensOfPrism(const Handle(Geom_Curve) C,
return sens; return sens;
} }
//=======================================================================
//function : SetGluedFaces
//purpose :
//=======================================================================
static void SetGluedFaces(const TopoDS_Face& theSkface,
const TopoDS_Shape& theSbase,
const TopoDS_Shape& thePbase,
const TopTools_DataMapOfShapeListOfShape& theSlmap,
LocOpe_DPrism& theDPrism,
TopTools_DataMapOfShapeShape& theMap)
{
TopExp_Explorer exp;
if (!theSkface.IsNull() && thePbase.ShapeType() == TopAbs_FACE) {
for (exp.Init(theSbase,TopAbs_FACE); exp.More(); exp.Next()) {
if (exp.Current().IsSame(theSkface)) {
theMap.Bind(thePbase,theSkface);
break;
}
}
}
else {
TopExp_Explorer exp2;
for (exp.Init(thePbase,TopAbs_FACE);exp.More();exp.Next()) {
const TopoDS_Face& fac = TopoDS::Face(exp.Current());
for (exp2.Init(theSbase,TopAbs_FACE);exp2.More();exp2.Next()) {
if (exp2.Current().IsSame(fac)) {
theMap.Bind(fac,fac);
break;
}
}
}
}
// Sliding
TopTools_DataMapIteratorOfDataMapOfShapeListOfShape itm(theSlmap);
if(!theSlmap.IsEmpty()) {
for (; itm.More(); itm.Next()) {
const TopoDS_Face& fac = TopoDS::Face(itm.Key());
const TopTools_ListOfShape& ledg = itm.Value();
for (TopTools_ListIteratorOfListOfShape it(ledg); it.More(); it.Next()) {
const TopTools_ListOfShape& gfac = theDPrism.Shapes(it.Value());
if (gfac.Extent() != 1) {
#ifdef DEB
Standard_Boolean trc = BRepFeat_GettraceFEAT();
if (trc) cout << " BRepFeat_MakeDPrism : Pb SetGluedFace" << endl;
#endif
}
theMap.Bind(gfac.First(),fac);
}
}
}
}
//=======================================================================
//function : VerifGluedFaces
//purpose : Checking intersection Tool/theSkface = thePbase
// if yes -> OK if no -> case without gluing
//=======================================================================
#ifdef DEB
static void VerifGluedFaces(const TopoDS_Face& theSkface,
const TopoDS_Shape& thePbase,
Handle(Geom_Curve)& theBCurve,
TColGeom_SequenceOfCurve& theCurves,
LocOpe_DPrism& theDPrism,
TopTools_DataMapOfShapeShape& theMap)
{
Standard_Boolean GluedFaces = Standard_True;
TopoDS_Shape VraiDPrism = theDPrism.Shape();
TColGeom_SequenceOfCurve scur;
theDPrism.Curves(theCurves);
theBCurve = theDPrism.BarycCurve();
scur.Clear();
scur.Append(theBCurve);
LocOpe_CSIntersector ASI(theSkface);
ASI.Perform(scur);
if (ASI.IsDone() && ASI.NbPoints(1) >=1) {
TopAbs_Orientation Or = ASI.Point(1,1).Orientation();
TopoDS_Face FSk = ASI.Point(1,1).Face();
TopoDS_Shape Comp;
BRep_Builder B;
B.MakeCompound(TopoDS::Compound(Comp));
TopoDS_Solid S = BRepFeat::Tool(theSkface, FSk, Or);
if (!S.IsNull()) B.Add(Comp,S);
//modified by NIZNHY-PKV Thu Mar 21 17:48:45 2002 f
//BRepAlgo_Cut trP(VraiDPrism,Comp);
BRepAlgoAPI_Cut trP(VraiDPrism,Comp);
//modified by NIZNHY-PKV Thu Mar 21 17:48:49 2002 t
TopoDS_Shape Cutsh = trP.Shape();
TopExp_Explorer ex(Cutsh, TopAbs_SOLID);
for(; ex.More(); ex.Next()) {
TopExp_Explorer ex1(ex.Current(), TopAbs_FACE);
for(; ex1.More(); ex1.Next()) {
const TopoDS_Face& fac1 = TopoDS::Face(ex1.Current());
TopExp_Explorer ex2(thePbase, TopAbs_FACE);
for(; ex2.More(); ex2.Next()) {
const TopoDS_Face& fac2 = TopoDS::Face(ex2.Current());
if(fac1.IsSame(fac2)) break;
}
if (ex2.More()) break;
}
if (ex1.More()) continue;
GluedFaces = Standard_False;
break;
}
if (!GluedFaces) {
#ifdef DEB
Standard_Boolean trc = BRepFeat_GettraceFEAT();
if (trc) cout << " Intersection DPrism/skface : no gluing" << endl;
#endif
theMap.Clear();
}
}
}
#endif
//======================================================================= //=======================================================================
//function : MajMap //function : MajMap
//purpose : //purpose :

View File

@ -69,16 +69,6 @@ static void MajMap(const TopoDS_Shape&, // base
TopoDS_Shape&, // myFShape TopoDS_Shape&, // myFShape
TopoDS_Shape&); // myLShape TopoDS_Shape&); // myLShape
static void SetGluedFaces(const TopoDS_Face& theSkface,
const TopoDS_Shape& theSbase,
const TopoDS_Shape& thePbase,
const TopTools_DataMapOfShapeListOfShape&
theSlmap,
LocOpe_Pipe&,
TopTools_DataMapOfShapeShape&);
//======================================================================= //=======================================================================
//function : Init //function : Init
//purpose : //purpose :
@ -217,7 +207,6 @@ void BRepFeat_MakePipe::Perform()
myGShape = VraiPipe; myGShape = VraiPipe;
GeneratedShapeValid(); GeneratedShapeValid();
//SetGluedFaces(mySkface, mySbase, myPbase, mySlface, thePipe, myGluedF);
GluedFacesValid(); GluedFacesValid();
if(myGluedF.IsEmpty()) { if(myGluedF.IsEmpty()) {
@ -291,7 +280,6 @@ void BRepFeat_MakePipe::Perform(const TopoDS_Shape& Until)
myGShape = VraiTuyau; myGShape = VraiTuyau;
GeneratedShapeValid(); GeneratedShapeValid();
//SetGluedFaces(mySkface, mySbase, myPbase, mySlface, thePipe, myGluedF);
GluedFacesValid(); GluedFacesValid();
myFShape = thePipe.FirstShape(); myFShape = thePipe.FirstShape();
@ -351,7 +339,6 @@ void BRepFeat_MakePipe::Perform(const TopoDS_Shape& From,
myGShape = VraiTuyau; myGShape = VraiTuyau;
GeneratedShapeValid(); GeneratedShapeValid();
//SetGluedFaces(TopoDS_Face(), // on ne veut pas binder mySkface
// mySbase, myPbase, mySlface, thePipe, myGluedF); // mySbase, myPbase, mySlface, thePipe, myGluedF);
GluedFacesValid(); GluedFacesValid();
@ -384,63 +371,6 @@ Handle(Geom_Curve) BRepFeat_MakePipe::BarycCurve()
return myBCurve; return myBCurve;
} }
//=======================================================================
//function : SetGluedFaces
//purpose : management of faces of gluing and sliding
//=======================================================================
static void SetGluedFaces(const TopoDS_Face& theSkface,
const TopoDS_Shape& theSbase,
const TopoDS_Shape& thePbase,
const TopTools_DataMapOfShapeListOfShape& theSlmap,
LocOpe_Pipe& thePipe,
TopTools_DataMapOfShapeShape& theMap)
{
TopExp_Explorer exp;
if (!theSkface.IsNull() && thePbase.ShapeType() == TopAbs_FACE) {
for (exp.Init(theSbase,TopAbs_FACE); exp.More(); exp.Next()) {
if (exp.Current().IsSame(theSkface)) {
theMap.Bind(thePbase,theSkface);
break;
}
}
}
else {
TopExp_Explorer exp2;
for (exp.Init(thePbase,TopAbs_FACE);exp.More();exp.Next()) {
const TopoDS_Face& fac = TopoDS::Face(exp.Current());
for (exp2.Init(theSbase,TopAbs_FACE);exp2.More();exp2.Next()) {
if (exp2.Current().IsSame(fac)) {
theMap.Bind(fac,fac);
break;
}
}
}
}
// Sliding
TopTools_DataMapIteratorOfDataMapOfShapeListOfShape itm(theSlmap);
if(!theSlmap.IsEmpty()) {
for (; itm.More(); itm.Next()) {
const TopoDS_Face& fac = TopoDS::Face(itm.Key());
const TopTools_ListOfShape& ledg = itm.Value();
TopTools_ListIteratorOfListOfShape it;
for (it.Initialize(ledg); it.More(); it.Next()) {
const TopTools_ListOfShape& gfac = thePipe.Shapes(it.Value());
if (gfac.Extent() != 1) {
#ifdef DEB
Standard_Boolean trc = BRepFeat_GettraceFEAT();
if (trc) cout << " BRepFeat_MakeDPipe : Pb SetGluedFace" << endl;
#endif
}
theMap.Bind(gfac.First(),fac);
}
}
}
}
//======================================================================= //=======================================================================
//function : MajMap //function : MajMap
//purpose : management of descendants //purpose : management of descendants

View File

@ -94,23 +94,6 @@ static void MajMap(const TopoDS_Shape&, // base
static Standard_Boolean ToFuse(const TopoDS_Face& , static Standard_Boolean ToFuse(const TopoDS_Face& ,
const TopoDS_Face&); const TopoDS_Face&);
static void SetGluedFaces(const TopoDS_Face& theSkface,
const TopoDS_Shape& theSbase,
const TopoDS_Shape& thePbase,
const TopTools_DataMapOfShapeListOfShape& theSlmap,
LocOpe_Prism&,
TopTools_DataMapOfShapeShape&);
#ifdef DEB
static void VerifGluedFaces(const TopoDS_Face& theSkface,
const TopoDS_Shape& thePbase,
Handle(Geom_Curve)& theBCurve,
TColGeom_SequenceOfCurve& theCurves,
LocOpe_Prism& thePrism,
TopTools_DataMapOfShapeShape& theMap);
#endif
static Standard_Real HeightMax(const TopoDS_Shape& theSbase, static Standard_Real HeightMax(const TopoDS_Shape& theSbase,
const TopoDS_Face& theSkface, const TopoDS_Face& theSkface,
const TopoDS_Shape& theSFrom, const TopoDS_Shape& theSFrom,
@ -301,7 +284,6 @@ void BRepFeat_MakePrism::Perform(const Standard_Real Length)
if(ToFuse(ff, FFace)) { if(ToFuse(ff, FFace)) {
TopTools_DataMapOfShapeListOfShape sl; TopTools_DataMapOfShapeListOfShape sl;
if(!FFace.IsSame(myPbase) && BRepFeat::IsInside(ff, FFace)) if(!FFace.IsSame(myPbase) && BRepFeat::IsInside(ff, FFace))
// SetGluedFaces(ff, mySbase, FFace, sl, thePrism, myGluedF);
break; break;
} }
} }
@ -309,9 +291,7 @@ void BRepFeat_MakePrism::Perform(const Standard_Real Length)
// management of faces of gluing given by the user // management of faces of gluing given by the user
// SetGluedFaces(mySkface, mySbase, myPbase, mySlface, thePrism, myGluedF);
GluedFacesValid(); GluedFacesValid();
// VerifGluedFaces(mySkface, myPbase, myBCurve, myCurves, thePrism, myGluedF);
if(!myGluedF.IsEmpty()) { // case gluing if(!myGluedF.IsEmpty()) { // case gluing
myJustGluer = Standard_True; myJustGluer = Standard_True;
@ -393,11 +373,7 @@ void BRepFeat_MakePrism::Perform(const TopoDS_Shape& Until)
MajMap(myPbase,thePrism,myMap,myFShape,myLShape); MajMap(myPbase,thePrism,myMap,myFShape,myLShape);
myGShape = VraiPrism; myGShape = VraiPrism;
GeneratedShapeValid(); GeneratedShapeValid();
//SetGluedFaces(mySkface, mySbase, myPbase, mySlface, thePrism, myGluedF);
GluedFacesValid(); GluedFacesValid();
// VerifGluedFaces(mySkface, myPbase, myBCurve, myCurves, thePrism, myGluedF);
thePrism.Curves(myCurves); thePrism.Curves(myCurves);
myBCurve = thePrism.BarycCurve(); myBCurve = thePrism.BarycCurve();
GlobalPerform(); GlobalPerform();
@ -584,12 +560,7 @@ void BRepFeat_MakePrism::Perform(const TopoDS_Shape& From,
myGShape = VraiPrism; myGShape = VraiPrism;
GeneratedShapeValid(); GeneratedShapeValid();
//SetGluedFaces(TopoDS_Face(), // on ne veut pas binder mySkface
// mySbase, myPbase, mySlface, thePrism, myGluedF);
GluedFacesValid(); GluedFacesValid();
//// VerifGluedFaces(mySkface, myPbase, myBCurve, myCurves, thePrism, myGluedF);
thePrism.Curves(myCurves); thePrism.Curves(myCurves);
myBCurve = thePrism.BarycCurve(); myBCurve = thePrism.BarycCurve();
GlobalPerform(); GlobalPerform();
@ -1017,11 +988,7 @@ void BRepFeat_MakePrism::PerformUntilHeight(const TopoDS_Shape& Until,
myGShape = VraiPrism; myGShape = VraiPrism;
GeneratedShapeValid(); GeneratedShapeValid();
//SetGluedFaces(mySkface, mySbase, myPbase, mySlface, thePrism, myGluedF);
GluedFacesValid(); GluedFacesValid();
// VerifGluedFaces(mySkface, myPbase, myBCurve, myCurves, thePrism, myGluedF);
thePrism.Curves(myCurves); thePrism.Curves(myCurves);
myBCurve = thePrism.BarycCurve(); myBCurve = thePrism.BarycCurve();
GlobalPerform(); GlobalPerform();
@ -1198,125 +1165,6 @@ Standard_Integer SensOfPrism(const Handle(Geom_Curve) C,
return sens; return sens;
} }
//=======================================================================
//function : SetGluedFaces
//purpose : management of gluing faces
//=======================================================================
static void SetGluedFaces(const TopoDS_Face& theSkface,
const TopoDS_Shape& theSbase,
const TopoDS_Shape& thePbase,
const TopTools_DataMapOfShapeListOfShape& theSlmap,
LocOpe_Prism& thePrism,
TopTools_DataMapOfShapeShape& theMap)
{
TopExp_Explorer exp;
if (!theSkface.IsNull() && thePbase.ShapeType() == TopAbs_FACE) {
for (exp.Init(theSbase,TopAbs_FACE); exp.More(); exp.Next()) {
if (exp.Current().IsSame(theSkface)) {
theMap.Bind(thePbase,theSkface);
break;
}
}
}
else {
for (exp.Init(theSbase,TopAbs_FACE); exp.More(); exp.Next()) {
if (exp.Current().IsSame(theSkface)) {
TopExp_Explorer exp2;
for (exp2.Init(thePbase,TopAbs_FACE);exp2.More();exp2.Next()) {
theMap.Bind(exp2.Current(),theSkface);
}
break;
}
}
}
// Sliding
TopTools_DataMapIteratorOfDataMapOfShapeListOfShape itm(theSlmap);
if(!theSlmap.IsEmpty()) {
for (; itm.More(); itm.Next()) {
const TopoDS_Face& fac = TopoDS::Face(itm.Key());
const TopTools_ListOfShape& ledg = itm.Value();
TopTools_ListIteratorOfListOfShape it;
for (it.Initialize(ledg); it.More(); it.Next()) {
const TopTools_ListOfShape& gfac = thePrism.Shapes(it.Value());
if (gfac.Extent() != 1) {
#ifdef DEB
Standard_Boolean trc = BRepFeat_GettraceFEAT();
if (trc) cout << " BRepFeat_MakePrism : Pb SetGluedFace" << endl;
#endif
}
theMap.Bind(gfac.First(),fac);
}
}
}
}
//=======================================================================
//function : VerifGluedFaces
//purpose : Verification intersection Tool/theSkface = thePbase
// If yes -> OK otherwise -> case without gluing
//=======================================================================
#ifdef DEB
static void VerifGluedFaces(const TopoDS_Face& theSkface,
const TopoDS_Shape& thePbase,
Handle(Geom_Curve)& theBCurve,
TColGeom_SequenceOfCurve& theCurves,
LocOpe_Prism& thePrism,
TopTools_DataMapOfShapeShape& theMap)
{
Standard_Boolean GluedFaces = Standard_True;
TopoDS_Shape VraiPrism = thePrism.Shape();
TColGeom_SequenceOfCurve scur;
thePrism.Curves(theCurves);
theBCurve = thePrism.BarycCurve();
scur.Clear();
scur.Append(theBCurve);
LocOpe_CSIntersector ASI(theSkface);
ASI.Perform(scur);
if (ASI.IsDone() && ASI.NbPoints(1) >=1) {
TopAbs_Orientation Or = ASI.Point(1,1).Orientation();
TopoDS_Face FSk = ASI.Point(1,1).Face();
TopoDS_Shape Comp;
BRep_Builder B;
B.MakeCompound(TopoDS::Compound(Comp));
TopoDS_Solid S = BRepFeat::Tool(theSkface, FSk, Or);
if (!S.IsNull()) B.Add(Comp,S);
//modified by NIZNHY-PKV Thu Mar 21 18:07:35 2002 f
//BRepAlgo_Cut trP(VraiPrism,Comp);
BRepAlgoAPI_Cut trP(VraiPrism,Comp);
//modified by NIZNHY-PKV Thu Mar 21 18:07:39 2002 t
TopoDS_Shape Cutsh = trP.Shape();
TopExp_Explorer ex(Cutsh, TopAbs_SOLID);
for(; ex.More(); ex.Next()) {
TopExp_Explorer ex1(ex.Current(), TopAbs_FACE);
for(; ex1.More(); ex1.Next()) {
const TopoDS_Face& fac1 = TopoDS::Face(ex1.Current());
TopExp_Explorer ex2(thePbase, TopAbs_FACE);
for(; ex2.More(); ex2.Next()) {
const TopoDS_Face& fac2 = TopoDS::Face(ex2.Current());
if(fac1.IsSame(fac2)) break;
}
if (ex2.More()) break;
}
if (ex1.More()) continue;
GluedFaces = Standard_False;
break;
}
if (!GluedFaces) {
#ifdef DEB
Standard_Boolean trc = BRepFeat_GettraceFEAT();
if (trc) cout << " Intersection Prism/skface : no gluing" << endl;
#endif
theMap.Clear();
}
}
}
#endif
//======================================================================= //=======================================================================
//function : MajMap //function : MajMap
//purpose : management of descendants //purpose : management of descendants

View File

@ -90,14 +90,6 @@ static void MajMap(const TopoDS_Shape&, // base
TopoDS_Shape&); // myLShape TopoDS_Shape&); // myLShape
static void SetGluedFaces(const TopoDS_Face& theSkface,
const TopoDS_Shape& theSbase,
const TopoDS_Shape& thePbase,
const TopTools_DataMapOfShapeListOfShape& theSlmap,
LocOpe_Revol&,
TopTools_DataMapOfShapeShape&);
static void VerifGluedFaces(const TopoDS_Face& theSkface, static void VerifGluedFaces(const TopoDS_Face& theSkface,
const TopoDS_Shape& thePbase, const TopoDS_Shape& thePbase,
Handle(Geom_Curve)& theBCurve, Handle(Geom_Curve)& theBCurve,
@ -307,13 +299,10 @@ void BRepFeat_MakeRevol::Perform(const Standard_Real Angle)
if(ToFuse(ff, FFace)) { if(ToFuse(ff, FFace)) {
TopTools_DataMapOfShapeListOfShape sl; TopTools_DataMapOfShapeListOfShape sl;
if(!FFace.IsSame(myPbase) && BRepFeat::IsInside(ff, FFace)) if(!FFace.IsSame(myPbase) && BRepFeat::IsInside(ff, FFace))
//SetGluedFaces(ff, mySbase, FFace, sl, theRevol, myGluedF);
break; break;
} }
} }
} }
//SetGluedFaces(mySkface, mySbase, theBase, mySlface, theRevol, myGluedF);
GluedFacesValid(); GluedFacesValid();
if (!mySkface.IsNull()) { if (!mySkface.IsNull()) {
VerifGluedFaces(mySkface, theBase, myBCurve, myCurves, theRevol, myGluedF); VerifGluedFaces(mySkface, theBase, myBCurve, myCurves, theRevol, myGluedF);
@ -417,8 +406,6 @@ void BRepFeat_MakeRevol::Perform(const TopoDS_Shape& Until)
myStatusError = BRepFeat_InvFirstShape; myStatusError = BRepFeat_InvFirstShape;
return; return;
} }
//SetGluedFaces(mySkface, mySbase, theBase, mySlface, theRevol, myGluedF);
GluedFacesValid(); GluedFacesValid();
//VerifGluedFaces(mySkface, theBase, myBCurve, myCurves, theRevol, myGluedF); //VerifGluedFaces(mySkface, theBase, myBCurve, myCurves, theRevol, myGluedF);
@ -588,8 +575,6 @@ void BRepFeat_MakeRevol::Perform(const TopoDS_Shape& From,
if(!Trff) { if(!Trff) {
myGShape = VraiRevol; myGShape = VraiRevol;
GeneratedShapeValid(); GeneratedShapeValid();
//SetGluedFaces(TopoDS_Face(), mySbase, myPbase, mySlface, theRevol, myGluedF);
GluedFacesValid(); GluedFacesValid();
// VerifGluedFaces(mySkface, theBase, myBCurve, myCurves, theRevol, myGluedF); // VerifGluedFaces(mySkface, theBase, myBCurve, myCurves, theRevol, myGluedF);
@ -763,8 +748,6 @@ void BRepFeat_MakeRevol::PerformUntilAngle(const TopoDS_Shape& Until,
myStatusError = BRepFeat_InvFirstShape; myStatusError = BRepFeat_InvFirstShape;
return; return;
} }
//SetGluedFaces(mySkface, mySbase, theBase, mySlface, theRevol, myGluedF);
GluedFacesValid(); GluedFacesValid();
//VerifGluedFaces(mySkface, theBase, myBCurve, myCurves, theRevol, myGluedF); //VerifGluedFaces(mySkface, theBase, myBCurve, myCurves, theRevol, myGluedF);
@ -854,62 +837,6 @@ Handle(Geom_Curve) BRepFeat_MakeRevol::BarycCurve()
return myBCurve; return myBCurve;
} }
//=======================================================================
//function : SetGluedFaces
//purpose : management of gluing faces
//=======================================================================
static void SetGluedFaces(const TopoDS_Face& theSkface,
const TopoDS_Shape& theSbase,
const TopoDS_Shape& thePbase,
const TopTools_DataMapOfShapeListOfShape& theSlmap,
LocOpe_Revol& theRevol,
TopTools_DataMapOfShapeShape& theMap)
{
TopExp_Explorer exp;
if (!theSkface.IsNull() && thePbase.ShapeType() == TopAbs_FACE) {
for (exp.Init(theSbase,TopAbs_FACE); exp.More(); exp.Next()) {
if (exp.Current().IsSame(theSkface)) {
theMap.Bind(thePbase,theSkface);
break;
}
}
}
else {
TopExp_Explorer exp2;
for (exp.Init(thePbase,TopAbs_FACE);exp.More();exp.Next()) {
const TopoDS_Face& fac = TopoDS::Face(exp.Current());
for (exp2.Init(theSbase,TopAbs_FACE);exp2.More();exp2.Next()) {
if (exp2.Current().IsSame(fac)) {
theMap.Bind(fac,fac);
break;
}
}
}
}
// Sliding
TopTools_DataMapIteratorOfDataMapOfShapeListOfShape itm(theSlmap);
if(!theSlmap.IsEmpty()) {
for (; itm.More(); itm.Next()) {
const TopoDS_Face& fac = TopoDS::Face(itm.Key());
const TopTools_ListOfShape& ledg = itm.Value();
TopTools_ListIteratorOfListOfShape it;
for (it.Initialize(ledg); it.More(); it.Next()) {
const TopTools_ListOfShape& gfac = theRevol.Shapes(it.Value());
if (gfac.Extent() != 1) {
#ifdef DEB
Standard_Boolean trc = BRepFeat_GettraceFEAT();
if (trc) cout << " BRepFeat_MakeRevol : Pb SetGluedFace" << endl;
#endif
}
theMap.Bind(gfac.First(),fac);
}
}
}
}
//======================================================================= //=======================================================================
//function : VerifGluedFaces //function : VerifGluedFaces
//purpose : Check intersection Tool/theSkface = thePbase //purpose : Check intersection Tool/theSkface = thePbase

View File

@ -69,7 +69,7 @@
#include <TColStd_Array1OfReal.hxx> #include <TColStd_Array1OfReal.hxx>
#include <TColStd_SequenceOfReal.hxx> #include <TColStd_SequenceOfReal.hxx>
#ifdef DEB_EFV
static void EdgesFromVertex (const TopoDS_Wire& W, static void EdgesFromVertex (const TopoDS_Wire& W,
const TopoDS_Vertex& V, const TopoDS_Vertex& V,
TopoDS_Edge& E1, TopoDS_Edge& E1,
@ -120,7 +120,7 @@ static void EdgesFromVertex (const TopoDS_Wire& W,
} }
} }
#endif
static void SeqOfVertices (const TopoDS_Wire& W, static void SeqOfVertices (const TopoDS_Wire& W,
TopTools_SequenceOfShape& S) TopTools_SequenceOfShape& S)
{ {
@ -1673,8 +1673,8 @@ void BRepFill_CompatibleWires::ComputeOrigin(const Standard_Boolean /*polar*/ )
newwire.Orientation( TopAbs_FORWARD ); newwire.Orientation( TopAbs_FORWARD );
myWork(i) = newwire; myWork(i) = newwire;
} }
#ifdef DEB_EFV
/*
for ( i=ideb; i<=myWork.Length(); i++) { for ( i=ideb; i<=myWork.Length(); i++) {
const TopoDS_Wire& wire = TopoDS::Wire(myWork(i)); const TopoDS_Wire& wire = TopoDS::Wire(myWork(i));
@ -1924,7 +1924,7 @@ void BRepFill_CompatibleWires::ComputeOrigin(const Standard_Boolean /*polar*/ )
if (!Vsuiv.IsNull()) Psuiv=BRep_Tool::Pnt(Vsuiv); if (!Vsuiv.IsNull()) Psuiv=BRep_Tool::Pnt(Vsuiv);
} }
} }
*/ #endif
// blocking sections ? // blocking sections ?
if (vClosed) myWork(myWork.Length()) = myWork(1); if (vClosed) myWork(myWork.Length()) = myWork(1);

View File

@ -71,12 +71,6 @@
#include <BOPCol_DataMapOfShapeListOfShape.hxx> #include <BOPCol_DataMapOfShapeListOfShape.hxx>
#include <BOPCol_ListOfShape.hxx> #include <BOPCol_ListOfShape.hxx>
static Standard_Boolean IsFromFirstToSecond(const TopoDS_Edge& theEdge,
const Standard_Real theParameterOnUEdge,
const TopoDS_Edge& theUEdge1,
const TopoDS_Edge& theUEdge2,
const TopoDS_Face& theFace);
static Standard_Boolean FindCommonVertex(const BOPDS_PDS& theDS, static Standard_Boolean FindCommonVertex(const BOPDS_PDS& theDS,
const Standard_Integer theEIndex1, const Standard_Integer theEIndex1,
const Standard_Integer theEIndex2, const Standard_Integer theEIndex2,
@ -205,12 +199,6 @@ static Standard_Boolean ChooseSection(const TopoDS_Shape& Comp,
gp_Pln& resPlane, gp_Pln& resPlane,
Standard_Boolean& IsSingular); Standard_Boolean& IsSingular);
static Standard_Boolean ChoosePlane(const TopoDS_Shape& Comp,
const gp_Ax2& bis,
gp_Pln& resPlane,
TopoDS_Compound& NewComp);
// =========================================================================================== // ===========================================================================================
// function: Constructor // function: Constructor
// purpose: // purpose:
@ -1008,53 +996,6 @@ Standard_Boolean FindCommonVertex(const BOPDS_PDS& theDS,
return bvertexfound; return bvertexfound;
} }
// ------------------------------------------------------------------------------------------
// static function: IsFromFirstToSecond
// purpose:
// ------------------------------------------------------------------------------------------
Standard_Boolean IsFromFirstToSecond(const TopoDS_Edge& theEdge,
const Standard_Real theParameterOnUEdge,
const TopoDS_Edge& theUEdge1,
const TopoDS_Edge& theUEdge2,
const TopoDS_Face& theFace) {
TopoDS_Face aFace = theFace;
aFace.Orientation(TopAbs_FORWARD);
TopoDS_Edge E1, E2;
TopExp_Explorer anExp(aFace, TopAbs_EDGE);
for(; anExp.More(); anExp.Next()) {
if(E1.IsNull() && theUEdge1.IsSame(anExp.Current())) {
E1 = TopoDS::Edge(anExp.Current());
}
else if(E2.IsNull() && theUEdge2.IsSame(anExp.Current())) {
E2 = TopoDS::Edge(anExp.Current());
}
}
if(E1.IsNull() || E2.IsNull())
return Standard_True;
gp_Pnt2d PU1, PU2, pf, pl;
Standard_Real f, l;
Handle(Geom2d_Curve) C1 = BRep_Tool::CurveOnSurface(E1, aFace, f, l);
Handle(Geom2d_Curve) C2 = BRep_Tool::CurveOnSurface(E2, aFace, f, l);
Handle(Geom2d_Curve) CC = BRep_Tool::CurveOnSurface(theEdge, aFace, f, l);
PU1 = C1->Value(theParameterOnUEdge);
PU2 = C2->Value(theParameterOnUEdge);
BRep_Tool::Range(theEdge, f, l);
pf = CC->Value(f);
pl = CC->Value(l);
Standard_Real aTolerance = Precision::Confusion();
if(pf.Distance(PU1) < aTolerance)
return Standard_True;
if(pl.Distance(PU2) < aTolerance)
return Standard_True;
return Standard_False;
}
// ---------------------------------------------------------------------------------------------------- // ----------------------------------------------------------------------------------------------------
// static function: GetUEdges // static function: GetUEdges
// purpose: // purpose:
@ -2221,174 +2162,3 @@ static Standard_Boolean ChooseSection(const TopoDS_Shape& Comp,
return Standard_False; return Standard_False;
//end of simplest case //end of simplest case
} }
//=======================================================================
//function : ChoosePlane
//purpose :
//=======================================================================
static Standard_Boolean ChoosePlane(const TopoDS_Shape& Comp,
const gp_Ax2& bis,
gp_Pln& resPlane,
TopoDS_Compound& NewComp)
{
Standard_Real TolConf = 1.e-4, TolAng = 1.e-5;
Standard_Integer N = 100;
Standard_Integer Eind, ind, i, j;
TopTools_SequenceOfShape Eseq;
TopExp_Explorer Explo( Comp, TopAbs_EDGE );
for (; Explo.More(); Explo.Next())
Eseq.Append( Explo.Current() );
Standard_Integer NumberOfEdges = Eseq.Length();
TColgp_Array2OfPnt Points( 0, NumberOfEdges*2-1, 1, N/4 );
for (Eind = 0; Eind < NumberOfEdges; Eind++)
{
TopoDS_Edge anEdge = TopoDS::Edge( Eseq(Eind+1) );
BRepAdaptor_Curve aCurve(anEdge);
GCPnts_UniformAbscissa Distribution( aCurve, N+1 );
for (i = 1; i <= N/4; i++)
{
Standard_Real par = Distribution.Parameter(i);
Points( Eind*2, i ) = aCurve.Value(par);
}
for (i = 3*N/4+2; i <= N+1; i++)
{
Standard_Real par = Distribution.Parameter(i);
Points( Eind*2+1, i-3*N/4-1 ) = aCurve.Value(par);
}
}
TColgp_Array1OfPnt Origins( 0, NumberOfEdges*2-1 );
TColgp_Array1OfDir Normals( 0, NumberOfEdges*2-1 );
TColStd_Array1OfBoolean IsSingular( 0, NumberOfEdges*2-1 );
Standard_Real MinAngle = M_PI/2;
Standard_Integer MinInd;
for (ind = 0; ind < NumberOfEdges*2; ind++)
{
TColgp_Array1OfPnt pnts( 1, N/4 );
for (i = 1; i <= N/4; i++)
pnts(i) = Points( ind, i );
gp_Ax2 Axe;
GeomLib::AxeOfInertia( pnts, Axe, IsSingular(ind) );
if (!IsSingular(ind))
{
Origins(ind) = Axe.Location();
Normals(ind) = Axe.Direction();
Standard_Real Angle = bis.Angle( Axe );
if (Angle > M_PI/2)
Angle = M_PI - Angle;
if (Angle < MinAngle)
{
MinAngle = Angle;
MinInd = ind;
}
}
}
gp_Ax2 TheAxe( Origins(MinInd), Normals(MinInd) );
Standard_Real MaxAngleWithPln = M_PI/16;
TColStd_SequenceOfInteger iseq;
TColgp_SequenceOfPnt Pseq;
for (ind = 0; ind < NumberOfEdges*2; ind++)
if (!IsSingular(ind))
{
Standard_Real Angle = Normals(ind).Angle( TheAxe.Direction() );
if (Angle > M_PI/2)
Angle = M_PI - Angle;
if (Angle <= MaxAngleWithPln)
{
iseq.Append(ind);
for (j = 1; j <= N/4; j++)
Pseq.Append( Points(ind,j) );
}
}
TColgp_Array1OfPnt Parray( 1, Pseq.Length() );
for (i = 1; i <= Parray.Length(); i++)
Parray(i) = Pseq(i);
Standard_Boolean issing;
GeomLib::AxeOfInertia( Parray, TheAxe, issing );
resPlane = gp_Pln( TheAxe );
i = 1;
BRep_Builder B;
B.MakeCompound(NewComp);
while (i <= iseq.Length())
{
Standard_Integer ind0 = iseq(i);
if (IsEven(ind0) && i < iseq.Length() && iseq(i+1) == ind0+1) //the whole edge
{
B.Add( NewComp, Eseq(ind0/2+1) );
i += 2;
}
else
i++;
}
Standard_Integer slen = Pseq.Length();
for (ind = 0; ind < NumberOfEdges*2; ind += 2)
{
Standard_Integer IndSing = -1, IndNotSing = -1;
gp_Lin aLine;
if (IsSingular(ind) && IsSingular(ind+1))
{
Standard_Boolean OnPlane0 = Standard_False, OnPlane1 = Standard_False;
aLine = gce_MakeLin( Points(ind, 1), Points(ind, N/4) );
if (resPlane.Contains( aLine, TolConf, TolAng ))
{
for (j = 1; j <= N/4; j++)
Pseq.Append( Points(ind,j) );
OnPlane0 = Standard_True;
}
aLine = gce_MakeLin( Points(ind+1, 1), Points(ind+1, N/4) );
if (resPlane.Contains( aLine, TolConf, TolAng ))
{
for (j = 1; j <= N/4; j++)
Pseq.Append( Points(ind+1,j) );
OnPlane1 = Standard_True;
}
if (OnPlane0 && OnPlane1)
B.Add( NewComp, Eseq(ind/2+1) );
}
else if (IsSingular(ind))
{
IndSing = ind;
IndNotSing = ind+1;
}
else if (IsSingular(ind+1))
{
IndNotSing = ind;
IndSing = ind+1;
}
if (IndSing != -1 && IndNotSing != -1)
{
aLine = gce_MakeLin( Points(IndSing, 1), Points(IndSing, N/4) );
if (resPlane.Contains( aLine, TolConf, TolAng ))
{
for (j = 1; j <= N/4; j++)
Pseq.Append( Points(IndSing,j) );
for (i = 1; i <= iseq.Length(); i++)
if (iseq(i) == IndNotSing)
break;
if (i <= iseq.Length())
B.Add( NewComp, Eseq(ind/2+1) );
}
}
}
//Recompute the axe of plane
if (Pseq.Length() > slen)
{
TColgp_Array1OfPnt Parray2( 1, Pseq.Length() );
for (i = 1; i <= Parray2.Length(); i++)
Parray2(i) = Pseq(i);
GeomLib::AxeOfInertia( Parray2, TheAxe, issing );
resPlane = gp_Pln( TheAxe );
}
//Temporary
return Standard_True;
}

View File

@ -600,131 +600,6 @@ static void GetCurveKnots(const Standard_Real theMin,
} }
} }
//=======================================================================
//function : GetIntervalNbr
//purpose :
//=======================================================================
static Standard_Integer GetIntervalNbr
(const Standard_Real theParam,
const Handle(TColStd_HArray1OfReal) &theSurfKnots,
const Standard_Integer theIndStart,
const Standard_Integer theIndEnd)
{
Standard_Integer i;
Standard_Real aTol = Precision::Confusion();
for (i = theIndStart + 1; i < theIndEnd; i++) {
if (theSurfKnots->Value(i) > theParam + aTol)
return i - 1;
}
return Min(theIndStart, theIndEnd - 1);
}
//=======================================================================
//function : GetRealCurveKnots
//purpose :
//=======================================================================
static void GetRealCurveKnots
(const Handle(TColStd_HArray1OfReal) &theCurveKnots,
const Handle(TColStd_HArray1OfReal) &theSurfKnots,
const Geom2dAdaptor_Curve &theCurve,
Handle(TColStd_HArray1OfReal) &theTKnots)
{
Standard_Integer i = theCurveKnots->Lower();
Standard_Integer iU = theCurveKnots->Upper();
Standard_Integer aNbIntPnt = 23;
TColStd_SequenceOfReal aSeqKnot;
Standard_Real aTol = Precision::Confusion();
Standard_Real aTParam;
while (i < iU) {
Standard_Real aT1 = theCurveKnots->Value(i++);
Standard_Real aT2 = theCurveKnots->Value(i);
Standard_Real aStep = (aT2 - aT1)/(aNbIntPnt + 1.);
Standard_Integer j;
gp_Pnt2d aValue;
gp_Vec2d aDir;
Standard_Integer aSurfLInd = theSurfKnots->Lower();
Standard_Integer aSurfUInd = theSurfKnots->Upper();
Standard_Integer anIntrvlInd;
Standard_Real aTParamOld;
Standard_Real aVParam;
Standard_Real aVParamOld;
Standard_Real aDiffOld;
Standard_Real aDiff;
// Append the first curve knot of each interval in the sequence of knots.
aSeqKnot.Append(aT1);
aTParamOld = aT1;
theCurve.D0(aTParamOld, aValue);
aVParamOld = aValue.Y();
anIntrvlInd = GetIntervalNbr(aVParamOld, theSurfKnots,
aSurfLInd, aSurfUInd);
aDiffOld = Min(Abs(aVParamOld - theSurfKnots->Value(anIntrvlInd)),
Abs(aVParamOld - theSurfKnots->Value(anIntrvlInd + 1)));
for (j = 1; j <= aNbIntPnt; j++) {
aTParam = aT1 + j*aStep;
theCurve.D1(aTParam, aValue, aDir);
aVParam = aValue.Y();
aDiff = Min(Abs(aVParam - theSurfKnots->Value(anIntrvlInd)),
Abs(aVParam - theSurfKnots->Value(anIntrvlInd + 1)));
// Skip points if the curve goes along V isoline.
if (Abs(aDir.Y()) > aTol) {
Standard_Boolean isLower =
(aVParam - aTol < theSurfKnots->Value(anIntrvlInd));
Standard_Boolean isUpper =
(aVParam + aTol > theSurfKnots->Value(anIntrvlInd + 1));
if (isLower || isUpper) {
if (isLower) {
aSurfLInd = theSurfKnots->Lower();
aSurfUInd = anIntrvlInd - 1;
} else if (isUpper) {
aSurfLInd = anIntrvlInd + 1;
aSurfUInd = theSurfKnots->Upper();
}
// The V interval is changed. Find new interval.
anIntrvlInd = GetIntervalNbr(aVParam, theSurfKnots,
aSurfLInd, aSurfUInd);
// Add the value that is closer to surface knots.
// Check if the previous value is already added.
if (aDiff < aDiffOld)
aSeqKnot.Append(aTParam);
else if (Abs(aSeqKnot.Last() - aTParamOld) > aTol)
aSeqKnot.Append(aTParamOld);
}
}
// Prepare data for the next iteration.
aTParamOld = aTParam;
aVParamOld = aVParam;
aDiffOld = aDiff;
}
}
// Add the last curve knot to the sequence.
aSeqKnot.Append(theCurveKnots->Value(iU));
// Fill the array of knots.
Standard_Integer aKnotsLen = aSeqKnot.Length();
theTKnots = new TColStd_HArray1OfReal(1, aKnotsLen);
for (i = 1; i <= aKnotsLen; i++) {
aTParam = aSeqKnot.Value(i);
theTKnots->SetValue(i, aTParam);
}
}
//======================================================================= //=======================================================================
//function : GetUKnots //function : GetUKnots
//purpose : //purpose :

View File

@ -54,13 +54,6 @@
#include <GeomLib.hxx> #include <GeomLib.hxx>
#include <GeomAPI_Interpolate.hxx> #include <GeomAPI_Interpolate.hxx>
static Standard_Boolean IsClosed(const TopoDS_Wire& aWire)
{
TopoDS_Vertex V1, V2;
TopExp::Vertices(aWire, V1, V2);
return (V1.IsSame(V2));
}
static Standard_Boolean IsLinear(const TopoDS_Edge& anEdge, static Standard_Boolean IsLinear(const TopoDS_Edge& anEdge,
gp_Lin& aLine) gp_Lin& aLine)
{ {

View File

@ -44,11 +44,6 @@ static Standard_CString name = tname ;
static Standard_Integer nbb = 0; static Standard_Integer nbb = 0;
*/ */
#ifdef DEB
static Standard_Boolean PointIsOnCurve(const Handle(Geom2d_Curve)& C,
const gp_Pnt2d& P,
Standard_Real& U);
#endif
static Standard_Boolean IsMaxRC (const Handle(Geom2d_Curve)& C, static Standard_Boolean IsMaxRC (const Handle(Geom2d_Curve)& C,
Standard_Real U, Standard_Real U,
Standard_Real& R); Standard_Real& R);
@ -543,26 +538,6 @@ const Handle(Geom2d_TrimmedCurve)& Bisector_Bisec::ChangeValue()
return thebisector; return thebisector;
} }
//=============================================================================
//function : PointIsOnCurve
// purpose :
//=============================================================================
#ifdef DEB
static Standard_Boolean PointIsOnCurve(const Handle(Geom2d_Curve)& C,
const gp_Pnt2d& P,
Standard_Real& U)
{
if (C->Value(C->FirstParameter()).IsEqual(P,Precision::Confusion())) {
U = C->FirstParameter();
return Standard_True;
}
if (C->Value(C->LastParameter()).IsEqual(P,Precision::Confusion())) {
U = C->LastParameter();
return Standard_True;
}
return Standard_False;
}
#endif
//============================================================================= //=============================================================================
//function : ReplaceByLineIfIsToSmall //function : ReplaceByLineIfIsToSmall
//purpose : If the size of an algorithmic bissectrice is negligeable it is //purpose : If the size of an algorithmic bissectrice is negligeable it is

View File

@ -432,7 +432,7 @@ void Bisector_BisecPC::Values(const Standard_Real U,
//purpose : //purpose :
//============================================================================= //=============================================================================
// Unused : // Unused :
#ifdef DEB #ifdef DEB_CUR
static Standard_Real Curvature (const Handle(Geom2d_Curve)& C, static Standard_Real Curvature (const Handle(Geom2d_Curve)& C,
Standard_Real U, Standard_Real U,
Standard_Real Tol) Standard_Real Tol)
@ -493,15 +493,17 @@ Standard_Real Bisector_BisecPC::Distance (const Standard_Real U) const
else { else {
Standard_Real A = 0.5*SquareMagPPC/Prosca; Standard_Real A = 0.5*SquareMagPPC/Prosca;
Standard_Real Dist = A*A*NorNor; Standard_Real Dist = A*A*NorNor;
#ifdef DEB_CUR
//---------------------------------------- //----------------------------------------
// Test Curvature if the curve is concave. // Test Curvature if the curve is concave.
//---------------------------------------- //----------------------------------------
// if (!isConvex){ if (!isConvex){
// Standard_Real K = Curvature(curve,UOnCurve,Precision::Confusion()); Standard_Real K = Curvature(curve,UOnCurve,Precision::Confusion());
// if (K != 0.) { if (K != 0.) {
// if (Dist > 1/(K*K)) { Dist = Precision::Infinite();} if (Dist > 1/(K*K)) { Dist = Precision::Infinite();}
// } }
// } }
#endif
return Dist; return Dist;
} }
} }

View File

@ -23,28 +23,6 @@
#include <CDF.ixx> #include <CDF.ixx>
#include <Standard_Failure.hxx> #include <Standard_Failure.hxx>
// Unused :
#ifdef DEB
static void CDF_CheckStatus(int LicenseStatus) {
if (LicenseStatus != 0) {
switch (LicenseStatus) {
case 1: Standard_Failure::Raise("LICENSE_unauthorized"); break;
case 2: Standard_Failure::Raise("LICENSE_wrong_data"); break;
case 3: Standard_Failure::Raise("LICENSE_max_users"); break;
case 4: Standard_Failure::Raise("LICENSE_unspecified"); break;
case 5: Standard_Failure::Raise("LICENSE_pb_init"); break;
case 6: Standard_Failure::Raise("LICENSE_unspecified"); break;
case 7: Standard_Failure::Raise("LICENSE_cantopenfile"); break;
case 8: Standard_Failure::Raise("LICENSE_connexion"); break;
case 9: Standard_Failure::Raise("LICENSE_syntaxe"); break;
default: Standard_Failure::Raise("LICENSE_unspecified"); break;
}
}
}
#endif
void static CDF_InitApplication () { void static CDF_InitApplication () {
static Standard_Boolean FirstApplication = Standard_True; static Standard_Boolean FirstApplication = Standard_True;

View File

@ -74,19 +74,6 @@ static inline void D13d(const Standard_Address C, const Standard_Real U,
((Adaptor3d_Curve*)C)->D1(U,P,V1); ((Adaptor3d_Curve*)C)->D1(U,P,V1);
} }
// Unused :
#ifdef DEB
static void D12d(const Standard_Address C, const Standard_Real U,
gp_Pnt& PP, gp_Vec& VV1)
{
gp_Pnt2d P;
gp_Vec2d V1;
((Adaptor2d_Curve2d*)C)->D1(U,P,V1);
PP.SetCoord(P.X(),P.Y(),0.);
VV1.SetCoord(V1.X(),V1.Y(),0.);
}
#endif
static inline void D23d(const Standard_Address C, const Standard_Real U, static inline void D23d(const Standard_Address C, const Standard_Real U,
gp_Pnt& P, gp_Vec& V1, gp_Vec& V2) gp_Pnt& P, gp_Vec& V1, gp_Vec& V2)
{ {

View File

@ -91,30 +91,6 @@
#include <ChFiKPart_ComputeData_Rotule.hxx> #include <ChFiKPart_ComputeData_Rotule.hxx>
#include <ChFiKPart_ComputeData_Sphere.hxx> #include <ChFiKPart_ComputeData_Sphere.hxx>
//=======================================================================
//function : ComputeAbscissa
//purpose :
//=======================================================================
// Unused :
#ifdef DEB
static Standard_Real ComputeAbscissa(const BRepAdaptor_Curve& C,
const Standard_Real UFirst)
{
Standard_Real fp = fp = C.FirstParameter();
switch (C.GetType()) {
case GeomAbs_Line:
return UFirst - fp;
case GeomAbs_Circle:
return C.Circle().Radius()*(UFirst-fp);
default:
break;
}
Standard_NotImplemented::Raise("calcul abscisse not processed");
return 0.;
}
#endif
//======================================================================= //=======================================================================
//function : Compute //function : Compute
//purpose : //purpose :

View File

@ -85,23 +85,6 @@ static Standard_Integer DDataStd_PNT (Draw_Interpretor& di,
di << "DDataStd_PNT : Error : not done" << "\n"; di << "DDataStd_PNT : Error : not done" << "\n";
return 1; return 1;
} }
//=======================================================================
//function : DDataStd_DrawStdDriver
//purpose : DrawStdDriver
//=======================================================================
// Unused :
#ifdef DEB
static Standard_Integer DDataStd_DrawStdDriver (Draw_Interpretor& /*di*/,
Standard_Integer /*nb*/,
const char** /*arg*/)
{
DDataStd_DrawDriver::Set(new DDataStd_DrawDriver());
return 0;
}
#endif
//======================================================================= //=======================================================================
//function : DDataStd_Rmdraw //function : DDataStd_Rmdraw

View File

@ -91,10 +91,6 @@ Standard_IMPORT Standard_Boolean Draw_Interprete(const char* command); //for C30
// necessary for WNT in C21 only // necessary for WNT in C21 only
static FDraw_InitAppli theDraw_InitAppli; //pointer to the Draw_InitAppli static FDraw_InitAppli theDraw_InitAppli; //pointer to the Draw_InitAppli
static void Draw_InitAppli(Draw_Interpretor& theCommands)
{
theDraw_InitAppli (theCommands);
}
#endif #endif
#ifdef WNT #ifdef WNT

View File

@ -184,21 +184,6 @@ static Handle(DrawTrSurf_BSplineSurface) GetBSplineSurface(Standard_CString& Nam
return Dr; return Dr;
} }
#ifdef DEB
//=======================================================================
//function : GetCurve
//purpose :
//=======================================================================
static Handle(DrawTrSurf_Curve) GetCurve(Standard_CString& Name)
{
Handle(Draw_Drawable3D) D = Draw::Get(Name);
Handle(DrawTrSurf_Curve) Dr;
if (!D.IsNull())
Dr = Handle(DrawTrSurf_Curve)::DownCast(D);
return Dr;
}
#endif
//======================================================================= //=======================================================================
//function : GetBezierCurve //function : GetBezierCurve
//purpose : //purpose :

View File

@ -281,52 +281,6 @@ Processing:
- update table TbSel. - update table TbSel.
-----------------------------------------------------------------------------*/ -----------------------------------------------------------------------------*/
static Standard_Boolean IsoIsDeg (const Adaptor3d_Surface& S,
const Standard_Real Param,
const GeomAbs_IsoType IT,
const Standard_Real TolMin,
const Standard_Real TolMax)
{
Standard_Real U1=0.,U2=0.,V1=0.,V2=0.,T;
Standard_Boolean Along = Standard_True;
U1 = S.FirstUParameter();
U2 = S.LastUParameter();
V1 = S.FirstVParameter();
V2 = S.LastVParameter();
gp_Vec D1U,D1V;
gp_Pnt P;
Standard_Real Step,D1NormMax;
if (IT == GeomAbs_IsoV)
{
Step = (U2 - U1)/10;
D1NormMax=0.;
for (T=U1;T<=U2;T=T+Step)
{
S.D1(T,Param,P,D1U,D1V);
D1NormMax=Max(D1NormMax,D1U.Magnitude());
}
if (D1NormMax >TolMax || D1NormMax < TolMin )
Along = Standard_False;
}
else
{
Step = (V2 - V1)/10;
D1NormMax=0.;
for (T=V1;T<=V2;T=T+Step)
{
S.D1(Param,T,P,D1U,D1V);
D1NormMax=Max(D1NormMax,D1V.Magnitude());
}
if (D1NormMax >TolMax || D1NormMax < TolMin )
Along = Standard_False;
}
return Along;
}
//----------------------------------------------------------
Extrema_GenExtPS::Extrema_GenExtPS() Extrema_GenExtPS::Extrema_GenExtPS()
{ {
myDone = Standard_False; myDone = Standard_False;

View File

@ -634,9 +634,6 @@ Standard_Real GeomFill_CorrectedFrenet::CalcAngleAT(const gp_Vec& Tangent, const
// Function : ... (OCC78) // Function : ... (OCC78)
// Purpose : This family of functions produce conversion of angle utility // Purpose : This family of functions produce conversion of angle utility
//=============================================================== //===============================================================
static Standard_Real corrPI_2PI(Standard_Real Ang){
return Ang = (Ang >= 0.0? Ang: 2*M_PI+Ang);
};
static Standard_Real corr2PI_PI(Standard_Real Ang){ static Standard_Real corr2PI_PI(Standard_Real Ang){
return Ang = (Ang < M_PI? Ang: Ang-2*M_PI); return Ang = (Ang < M_PI? Ang: Ang-2*M_PI);
}; };

View File

@ -464,31 +464,10 @@ public:
} }
} }
}; };
//-- ================================================================================ //-- ================================================================================
//=======================================================================
//function : FindInList
//purpose :
//=======================================================================
// Unused :
#ifdef DEB
static Standard_Boolean FindInList (const TColStd_ListOfInteger& L,
const Standard_Integer V)
{
for (TColStd_ListIteratorOfListOfInteger ILV(L);
ILV.More();
ILV.Next()) {
if (V == ILV.Value())
return Standard_True;
}
return Standard_False;
}
#endif
//======================================================================= //=======================================================================
//function : AdjustParameter //function : AdjustParameter
//purpose : //purpose :

View File

@ -53,6 +53,7 @@ AddInterference(HLRAlgo_InterferenceList& IL,
//function : ProcessComplex //function : ProcessComplex
//purpose : //purpose :
//======================================================================= //=======================================================================
#ifdef DEB_SI
static Standard_Boolean SimilarInterference(const HLRAlgo_Interference& I1, static Standard_Boolean SimilarInterference(const HLRAlgo_Interference& I1,
const HLRAlgo_Interference& I2) const HLRAlgo_Interference& I2)
{ {
@ -73,6 +74,7 @@ static Standard_Boolean SimilarInterference(const HLRAlgo_Interference& I1,
return IsSimilar; return IsSimilar;
} }
#endif
void HLRBRep_EdgeIList:: void HLRBRep_EdgeIList::
ProcessComplex(HLRAlgo_InterferenceList& IL, ProcessComplex(HLRAlgo_InterferenceList& IL,
const HLRBRep_EdgeInterferenceTool& T) const HLRBRep_EdgeInterferenceTool& T)
@ -87,9 +89,12 @@ ProcessComplex(HLRAlgo_InterferenceList& IL,
HLRAlgo_ListIteratorOfInterferenceList It2(It1); HLRAlgo_ListIteratorOfInterferenceList It2(It1);
It2.Next(); It2.Next();
if (It2.More()) { if (It2.More()) {
if (T.SameInterferences(It1.Value(),It2.Value())/* || if (T.SameInterferences(It1.Value(),It2.Value())
SimilarInterference(It1.Value(),It2.Value())*/) { #ifdef DEB_SI
|| SimilarInterference(It1.Value(),It2.Value())
#endif
)
{
T.EdgeGeometry(T.ParameterOfInterference(It1.Value()), T.EdgeGeometry(T.ParameterOfInterference(It1.Value()),
TgtE, NormE, CurvE); TgtE, NormE, CurvE);
transTool.Reset(TgtE,NormE,CurvE); transTool.Reset(TgtE,NormE,CurvE);
@ -101,8 +106,11 @@ ProcessComplex(HLRAlgo_InterferenceList& IL,
It1.Value().BoundaryTransition()); It1.Value().BoundaryTransition());
while (It2.More()) { while (It2.More()) {
if (!(T.SameInterferences(It1.Value(),It2.Value())/* || if (!(T.SameInterferences(It1.Value(),It2.Value())
SimilarInterference(It1.Value(),It2.Value())*/)) break; #ifdef DEB_SI
|| SimilarInterference(It1.Value(),It2.Value())
#endif
)) break;
T.InterferenceBoundaryGeometry(It2.Value(),TgtI,NormI,CurvI); T.InterferenceBoundaryGeometry(It2.Value(),TgtI,NormI,CurvI);
transTool.AddInterference(TolAng, transTool.AddInterference(TolAng,

View File

@ -149,25 +149,6 @@ static
Standard_Real& u, Standard_Real& u,
Standard_Real& v); Standard_Real& v);
static
Standard_Boolean DoTrim(const TheCurve& curve,
const TheSurface& surface);
static
void DoCurve(const TheCurve& curve,
Bnd_Box& boxCurve);
static
void DoCommon(TColStd_Array1OfReal& Coords,
Standard_Real& Cmin,
Standard_Real& Cmax);
static
void DoCommonBox(const Bnd_Box& boxSurface,
const Bnd_Box& boxCurve,
TColStd_Array1OfReal& X,
TColStd_Array1OfReal& Y,
TColStd_Array1OfReal& Z);
static static
void ProjectIntersectAndEstLim(const gp_Lin& theLine, void ProjectIntersectAndEstLim(const gp_Lin& theLine,
const gp_Pln& thePln, const gp_Pln& thePln,
@ -231,91 +212,6 @@ void IntCurveSurface_Inter::DoSurface(const TheSurface& surface,
gap = Max(Ures,Vres); gap = Max(Ures,Vres);
} }
//=======================================================================
//function : DoCurve
//purpose :
//=======================================================================
void DoCurve(const TheCurve& curve,
Bnd_Box& boxCurve)
{
Standard_Real CF = TheCurveTool::FirstParameter(curve);
Standard_Real CL = TheCurveTool::LastParameter(curve);
Standard_Real C = 0., dC = fabs(CL-CF)/50.;
Standard_Integer iC = 0;
gp_Pnt aPnt;
for(iC = 0; iC < 50; iC++) {
if(iC == 0)
C = CF;
else if(iC == 49)
C = CL;
else
C = CF + dC *((Standard_Real)iC);
TheCurveTool::D0(curve,C,aPnt);
boxCurve.Add(aPnt);
}
}
//=======================================================================
//function : DoCommon
//purpose :
//=======================================================================
void DoCommon(TColStd_Array1OfReal& Coords,
Standard_Real& Cmin,
Standard_Real& Cmax)
{
Standard_Integer i = 0, j = 0;
for(i = 1; i <= 4; i++) {
for(j = i+1; j <= 4; j++) {
if(Coords(j) > Coords(i)) {
Standard_Real c = Coords(i);
Coords.SetValue(i,Coords(j));
Coords.SetValue(j,c);
}
}
}
Cmax = Coords(2);
Cmin = Coords(3);
}
//=======================================================================
//function : DoCommonBox
//purpose :
//=======================================================================
static void DoCommonBox(const Bnd_Box& boxSurface,
const Bnd_Box& boxCurve,
TColStd_Array1OfReal& X,
TColStd_Array1OfReal& Y,
TColStd_Array1OfReal& Z)
{
Standard_Real SBXmin = 0., SBYmin = 0., SBZmin = 0.;
Standard_Real SBXmax = 0., SBYmax = 0., SBZmax = 0.;
boxSurface.Get(SBXmin,SBYmin,SBZmin,SBXmax,SBYmax,SBZmax);
Standard_Real CBXmin = 0., CBYmin = 0., CBZmin = 0.;
Standard_Real CBXmax = 0., CBYmax = 0., CBZmax = 0.;
boxCurve.Get(CBXmin,CBYmin,CBZmin,CBXmax,CBYmax,CBZmax);
TColStd_Array1OfReal Coord(1,4);
Coord(1) = SBXmin; Coord(2) = SBXmax; Coord(3) = CBXmin; Coord(4) = CBXmax;
Standard_Real CXmin = SBXmin, CXmax = SBXmax;
DoCommon(Coord,CXmin,CXmax);
Coord(1) = SBYmin; Coord(2) = SBYmax; Coord(3) = CBYmin; Coord(4) = CBYmax;
Standard_Real CYmin = SBYmin, CYmax = SBYmax;
DoCommon(Coord,CYmin,CYmax);
Coord(1) = SBZmin; Coord(2) = SBZmax; Coord(3) = CBZmin; Coord(4) = CBZmax;
Standard_Real CZmin = SBZmin, CZmax = SBZmax;
DoCommon(Coord,CZmin,CZmax);
X.SetValue(1,CXmin); X.SetValue(2,CXmax);
Y.SetValue(1,CYmin); Y.SetValue(2,CYmax);
Z.SetValue(1,CZmin); Z.SetValue(2,CZmax);
}
//======================================================================= //=======================================================================
//function : DoNewBounds //function : DoNewBounds
//purpose : //purpose :
@ -2329,77 +2225,3 @@ void EstLimForInfSurf(Standard_Real& U1new,
V1new = Max(V1new, -1.e10); V1new = Max(V1new, -1.e10);
V2new = Min(V2new, 1.e10); V2new = Min(V2new, 1.e10);
} }
//=======================================================================
//function : DoTrim
//purpose :
//=======================================================================
Standard_Boolean DoTrim(const TheCurve& curve,
const TheSurface& surface)
{
Standard_Boolean isAnaCurve, isAnaSurface, result;
GeomAbs_CurveType aCT;
GeomAbs_SurfaceType aST;
isAnaCurve = Standard_False;
isAnaSurface = Standard_False;
//
aCT=TheCurveTool::GetType(curve);
//
isAnaCurve= (aCT==GeomAbs_Line ||
aCT==GeomAbs_Circle ||
aCT==GeomAbs_Ellipse ||
aCT==GeomAbs_Hyperbola ||
aCT==GeomAbs_Parabola);
//
aST=TheSurfaceTool::GetType(surface);
isAnaSurface=(aST==GeomAbs_Plane ||
aST==GeomAbs_Cylinder ||
aST==GeomAbs_Cone ||
aST==GeomAbs_Sphere ||
aST==GeomAbs_Torus);
//
result = !(isAnaCurve && isAnaSurface);
//
if(result) {
Standard_Boolean isUClosed, isVClosed;
isUClosed=(TheSurfaceTool::IsUClosed(surface) ||
TheSurfaceTool::IsUPeriodic(surface));
isVClosed=(TheSurfaceTool::IsVClosed(surface)
|| TheSurfaceTool::IsVPeriodic(surface));
if(isUClosed && isVClosed) {
result =!result;
}
}
//modified by NIZNHY-PKV Wed Apr 04 12:11:01 2012f
if (result) {
Standard_Real aU0,aU1,aV0,aV1, dU, dV, dA, dB, aR, aTresh;
//
aTresh=100.;
aV0 = TheSurfaceTool::FirstVParameter(surface);
aV1 = TheSurfaceTool::LastVParameter(surface);
aU0 = TheSurfaceTool::FirstUParameter(surface);
aU1 = TheSurfaceTool::LastUParameter(surface);
dU=aU1-aU0;
dV=aV1-aV0;
//
dA=dU;
dB=dV;
if (dV>dU) {
dA=dV;
dB=dU;
}
//
aR=dA/dB;
if (dB<Precision::PConfusion()) {
result=!result;
return result;
}
if (aR>aTresh) {
result=!result;
}
}
//modified by NIZNHY-PKV Wed Apr 04 12:11:03 2012t
return result;
}

View File

@ -1398,25 +1398,6 @@ static Standard_Real AdjustUFirst(Standard_Real U1,Standard_Real U2)
return u; return u;
} }
// adjust U parameters on Quadric
static Standard_Real AdjustUNext(Standard_Real Un,Standard_Real Up)
{
Standard_Real u = Un;
if( Un < 0. )
while(u < 0.)
u += (2.*M_PI);
else if( Un > (2.*M_PI) )
while( u > (2.*M_PI) )
u -= (2.*M_PI);
else if(Un == 0. || fabs(Un) <= 1.e-9)
u = (fabs(Up) < fabs(2.*M_PI-Up)) ? 0. : (2.*M_PI);
else if(Un == (2.*M_PI) || fabs(Un-(2.*M_PI)) <= 1.e-9)
u = (fabs(Up) < fabs(2.*M_PI-Up)) ? 0. : (2.*M_PI);
else //( Un > 0. && Un < (2.*M_PI) )
return u;
return u;
}
// collect vertices, reject equals // collect vertices, reject equals
static Handle(IntSurf_LineOn2S) GetVertices(const Handle(IntPatch_WLine)& WLine, static Handle(IntSurf_LineOn2S) GetVertices(const Handle(IntPatch_WLine)& WLine,
const Standard_Boolean ,//IsReversed, const Standard_Boolean ,//IsReversed,

View File

@ -3973,47 +3973,3 @@ void EnlargeZone(const Handle(Adaptor3d_HSurface)& MaSurface,
} }
} }
} }
#ifdef DEB
#include <TopoDS_Shape.hxx>
#include <Poly_Triangulation.hxx>
#include <TColgp_Array1OfPnt.hxx>
#include <Poly_Array1OfTriangle.hxx>
#include <BRep_TFace.hxx>
#include <TopoDS_Face.hxx>
//=======================================================================
//function : TriangleShape
//purpose : shape with triangulation containing triangles
//=======================================================================
static TopoDS_Shape TriangleShape(const IntPolyh_ArrayOfTriangles & TTriangles,
const IntPolyh_ArrayOfPoints & TPoints)
{
TopoDS_Face aFace;
if (TPoints.NbItems() < 1 || TTriangles.NbItems() < 1) return aFace;
Handle(Poly_Triangulation) aPTriangulation =
new Poly_Triangulation(TPoints.NbItems(),TTriangles.NbItems(),Standard_False);
TColgp_Array1OfPnt & aPNodes = aPTriangulation->ChangeNodes();
Poly_Array1OfTriangle & aPTrialgles = aPTriangulation->ChangeTriangles();
Standard_Integer i;
for (i=0; i<TPoints.NbItems(); i++) {
const IntPolyh_Point& P = TPoints[i];
aPNodes(i+1).SetCoord(P.X(), P.Y(), P.Z());
}
for (i=0; i<TTriangles.NbItems(); i++) {
const IntPolyh_Triangle& T = TTriangles[i];
aPTrialgles(i+1).Set(T.FirstPoint()+1, T.SecondPoint()+1, T.ThirdPoint()+1);
}
Handle(BRep_TFace) aTFace = new BRep_TFace;
aTFace->Triangulation(aPTriangulation);
aFace.TShape(aTFace);
return aFace;
}
#endif
//#define MyTolerance 10.0e-7
//#define MyConfusionPrecision 10.0e-12
//#define SquareMyConfusionPrecision 10.0e-24

View File

@ -58,16 +58,6 @@ static
const Standard_Integer NumTri, const Standard_Integer NumTri,
const Standard_Integer NewTriNum, const Standard_Integer NewTriNum,
IntPolyh_ArrayOfEdges & TEdges) ; IntPolyh_ArrayOfEdges & TEdges) ;
static
void TestOldEdgeB(const Standard_Integer NumTA,
const Standard_Integer numPtT1,
const Standard_Integer numPtT2,
const Standard_Integer T1,
const Standard_Integer T2,
const IntPolyh_ArrayOfTriangles & TTriangles,
const Standard_Integer Edge1,
const Standard_Integer Edge3,
IntPolyh_ArrayOfEdges & TEdges );
//======================================================================= //=======================================================================
//function : IntPolyh_Triangle //function : IntPolyh_Triangle
@ -603,42 +593,6 @@ void OldEdge(const Standard_Integer EdgeN,
} }
} }
//=======================================================================
//function : TestOldEdgeB
//purpose :
//=======================================================================
void TestOldEdgeB(const Standard_Integer NumTA,
const Standard_Integer numPtT1,
const Standard_Integer /*numPtT2*/,
const Standard_Integer T1,
const Standard_Integer T2,
const IntPolyh_ArrayOfTriangles & /*TTriangles*/,
const Standard_Integer Edge1,
const Standard_Integer Edge3,
IntPolyh_ArrayOfEdges & TEdges )
{
if( (TEdges[Edge1].FirstPoint() == numPtT1)
||(TEdges[Edge1].SecondPoint()== numPtT1) ) {
/// L'edge1 est commun aux triangles NumTA et T1
if(TEdges[Edge1].FirstTriangle()==NumTA)
TEdges[Edge1].SetFirstTriangle(T1);
else TEdges[Edge1].SetSecondTriangle(T1);
if(TEdges[Edge3].FirstTriangle()==NumTA)
TEdges[Edge3].SetFirstTriangle(T2);
else TEdges[Edge3].SetSecondTriangle(T2);
}
else {
/// L'edge3 est commun aux triangles NumTA et T1
if(TEdges[Edge3].FirstTriangle()==NumTA)
TEdges[Edge3].SetFirstTriangle(T1);
else TEdges[Edge3].SetSecondTriangle(T1);
if(TEdges[Edge1].FirstTriangle()==NumTA)
TEdges[Edge1].SetFirstTriangle(T2);
else TEdges[Edge1].SetSecondTriangle(T2);
}
}
//======================================================================= //=======================================================================
//function : MiddleRefinement //function : MiddleRefinement
//purpose : //purpose :

View File

@ -122,9 +122,10 @@
static static
void RefineVector(gp_Vec2d& aV2D); void RefineVector(gp_Vec2d& aV2D);
#ifdef DEB_DUMPWLINE
static static
void DumpWLine(const Handle(IntPatch_WLine)& aWLine); void DumpWLine(const Handle(IntPatch_WLine)& aWLine);
#endif
// //
static static
void TolR3d(const TopoDS_Face& , void TolR3d(const TopoDS_Face& ,
@ -1118,22 +1119,18 @@ void IntTools_FaceFace::SetList(IntSurf_ListOfPntOn2S& aListOfPnts)
// //
const Handle(IntPatch_WLine)& aWLine= const Handle(IntPatch_WLine)& aWLine=
Handle(IntPatch_WLine)::DownCast(L); Handle(IntPatch_WLine)::DownCast(L);
//DEBf #ifdef DEB_DUMPWLINE
//DumpWLine(aWLine); DumpWLine(aWLine);
//DEBt #endif
anewL = ComputePurgedWLine(aWLine); anewL = ComputePurgedWLine(aWLine);
if(anewL.IsNull()) { if(anewL.IsNull()) {
return; return;
} }
L = anewL; L = anewL;
//DEBf #ifdef DEB_DUMPWLINE
/* const Handle(IntPatch_WLine)& aWLineX = Handle(IntPatch_WLine)::DownCast(L);
{ const Handle(IntPatch_WLine)& aWLineX=
Handle(IntPatch_WLine)::DownCast(L);
DumpWLine(aWLineX); DumpWLine(aWLineX);
} #endif
*/
//DEBt
// //
if(!myListOfPnts.IsEmpty()) { if(!myListOfPnts.IsEmpty()) {
bAvoidLineConstructor = Standard_True; bAvoidLineConstructor = Standard_True;
@ -4754,6 +4751,7 @@ Standard_Integer IndexType(const GeomAbs_SurfaceType aType)
} }
return aIndex; return aIndex;
} }
#ifdef DEB_DUMPWLINE
//======================================================================= //=======================================================================
//function : DumpWLine //function : DumpWLine
//purpose : //purpose :
@ -4776,6 +4774,7 @@ void DumpWLine(const Handle(IntPatch_WLine)& aWLine)
// i, aX, aY, aZ, aU1, aV1, aU2, aV2); // i, aX, aY, aZ, aU1, aV1, aU2, aV2);
} }
} }
#endif
//======================================================================= //=======================================================================
//function : RefineVector //function : RefineVector
//purpose : //purpose :

View File

@ -526,75 +526,6 @@ static Standard_Boolean LocAfter (const LocOpe_SequenceOfPntFace& Spt,
return RetVal; return RetVal;
} }
//=======================================================================
//function : LocBefore
//purpose :
//=======================================================================
#ifdef DEB
static Standard_Boolean LocBefore (const LocOpe_SequenceOfPntFace& Spt,
const Standard_Integer FromInd,
const Standard_Real Tol,
TopAbs_Orientation& Or,
Standard_Integer& IndFrom,
Standard_Integer& IndTo)
{
Standard_Integer nbpoints = Spt.Length();
if (FromInd <= 1) {
return Standard_False;
}
Standard_Real param,FPEPS;
Standard_Integer i,ifirst;
if (FromInd <= nbpoints) {
FPEPS = Spt(FromInd).Parameter() + Tol;
for (ifirst=FromInd-1; ifirst>=1; ifirst--) {
if (Spt(ifirst).Parameter() <= FPEPS) {
break;
}
}
}
else {
ifirst = nbpoints;
}
Standard_Boolean RetVal = Standard_False;
if (ifirst >= 1) {
i = ifirst;
IndTo = ifirst;
Standard_Boolean found = Standard_False;
while (!found) {
Or = Spt(i).Orientation();
param = Spt(i).Parameter();
i = i-1;
while (i>=1) {
if (param - Spt(i).Parameter() <= Tol) {
if (Or != TopAbs_EXTERNAL && Or != Spt(i).Orientation()) {
Or = TopAbs_EXTERNAL;
}
i--;
}
else {
break;
}
}
if (Or == TopAbs_EXTERNAL) {
found = (i < 1);
IndTo = i;
}
else { // on a une intersection franche
IndFrom = i+1;
found = Standard_True;
RetVal = Standard_True;
}
}
}
return RetVal;
}
#endif
//======================================================================= //=======================================================================
//function : AddPoints //function : AddPoints
//purpose : //purpose :

View File

@ -82,13 +82,6 @@ static Standard_Real NewParameter(const TopoDS_Edge&,
const TopoDS_Edge&, const TopoDS_Edge&,
const TopoDS_Vertex&); const TopoDS_Vertex&);
#ifdef DEB
static Standard_Boolean Contains(const TopTools_ListOfShape&,
const TopoDS_Shape&);
#endif
//======================================================================= //=======================================================================
//function : Perform //function : Perform
@ -1277,26 +1270,3 @@ Standard_Real NewParameter(const TopoDS_Edge& Edg,
} }
return 0; return 0;
} }
//=======================================================================
//function : Contains
//purpose :
//=======================================================================
// Unused :
#ifdef DEB
Standard_Boolean Contains(const TopTools_ListOfShape& L,
const TopoDS_Shape& S)
{
TopTools_ListIteratorOfListOfShape itl;
for (itl.Initialize(L); itl.More(); itl.Next()) {
// for (TopTools_ListIteratorOfListOfShape itl(L); itl.More(); itl.Next()) {
if (itl.Value().IsSame(S)) {
return Standard_True;
}
}
return Standard_False;
}
#endif

View File

@ -47,13 +47,6 @@
#include <TopExp.hxx> #include <TopExp.hxx>
#include <Precision.hxx> #include <Precision.hxx>
#ifdef DEB
static Standard_Boolean FindCircle(const gp_Ax1&,
const gp_Pnt&,
gp_Circ&);
#endif
//======================================================================= //=======================================================================
//function : LocOpe_Revol //function : LocOpe_Revol
//purpose : //purpose :
@ -235,31 +228,3 @@ const TopTools_ListOfShape& LocOpe_RevolutionForm::Shapes (const TopoDS_Shape& S
{ {
return myMap(S); return myMap(S);
} }
//=======================================================================
//function : FincCircle
//purpose :
//=======================================================================
#ifdef DEB
static Standard_Boolean FindCircle(const gp_Ax1& Ax,
const gp_Pnt& Pt,
gp_Circ& Ci)
{
const gp_Dir& Dax = Ax.Direction();
gp_Vec OP(Ax.Location(),Pt);
Standard_Real prm = OP.Dot(Dax);
gp_Pnt prj(Ax.Location().XYZ().Added(prm*Dax.XYZ()));
gp_Vec axx(prj,Pt);
Standard_Real Radius = axx.Magnitude();
if (Radius < Precision::Confusion()) {
return Standard_False;
}
Ci.SetRadius(Radius);
Ci.SetPosition(gp_Ax2(prj,Dax,axx));
return Standard_True;
}
#endif

View File

@ -757,39 +757,6 @@ static Standard_Integer triangle (Draw_Interpretor&, Standard_Integer n, const c
return 0; return 0;
} }
//=======================================================================
//function : printdegree
//purpose :
//=======================================================================
static void printdegree(BRepMesh_DegreeOfFreedom dof, Draw_Interpretor& di)
{
switch (dof) {
case BRepMesh_InVolume :
di << "InVolume";
break;
case BRepMesh_OnSurface :
di << "OnSurface";
break;
case BRepMesh_OnCurve :
di << "OnCurve";
break;
case BRepMesh_Fixed :
di << "Fixed";
break;
case BRepMesh_Frontier :
di << "Frontier";
break;
case BRepMesh_Deleted :
di << "Deleted";
break;
case BRepMesh_Free :
di << "Free";
break;
}
}
//======================================================================= //=======================================================================
//function : dumpvertex //function : dumpvertex
//purpose : //purpose :

View File

@ -187,33 +187,6 @@ Handle(Draw_Drawable3D) MeshTest_DrawableMesh::Copy() const
//purpose : //purpose :
//======================================================================= //=======================================================================
static void printdegree(BRepMesh_DegreeOfFreedom dof)
{
switch (dof) {
case BRepMesh_InVolume :
cout << "InVolume";
break;
case BRepMesh_OnSurface :
cout << "OnSurface";
break;
case BRepMesh_OnCurve :
cout << "OnCurve";
break;
case BRepMesh_Fixed :
cout << "Fixed";
break;
case BRepMesh_Frontier :
cout << "Frontier";
break;
case BRepMesh_Deleted :
cout << "Deleted";
break;
case BRepMesh_Free :
cout << "Free";
break;
}
}
void MeshTest_DrawableMesh::Dump(Standard_OStream&) const void MeshTest_DrawableMesh::Dump(Standard_OStream&) const
{ {
// Should be reimplemented // Should be reimplemented

View File

@ -84,31 +84,6 @@ static Handle(PColgp_HArray1OfPnt2d) ArrayCopy
return PArray; return PArray;
} }
//=======================================================================
//function : ArrayCopy
//purpose : Copy the gp_Pnt2d
// from an Array2 from TColgp (TCollection)
// to an HArray2 from PColgp (PCollection)
//=======================================================================
#ifdef DEB
static Handle(PColgp_HArray2OfPnt2d) ArrayCopy
(const TColgp_Array2OfPnt2d& TArray)
{
Standard_Integer LowerRow = TArray.LowerRow();
Standard_Integer UpperRow = TArray.UpperRow();
Standard_Integer LowerCol = TArray.LowerCol();
Standard_Integer UpperCol = TArray.UpperCol();
Standard_Integer IndexRow, IndexCol;
Handle(PColgp_HArray2OfPnt2d) PArray =
new PColgp_HArray2OfPnt2d(LowerRow, UpperRow, LowerCol, UpperCol);
for (IndexRow = LowerRow; IndexRow <= UpperRow; IndexRow++) {
for (IndexCol = LowerCol; IndexCol <= UpperCol; IndexCol++) {
PArray->SetValue(IndexRow, IndexCol, TArray(IndexRow, IndexCol));
}
}
return PArray;
}
#endif
//======================================================================= //=======================================================================
//function : ArrayCopy //function : ArrayCopy
//purpose : Copy the Standard_Real //purpose : Copy the Standard_Real
@ -130,31 +105,6 @@ static Handle(PColStd_HArray1OfReal) ArrayCopy
return PArray; return PArray;
} }
//=======================================================================
//function : ArrayCopy
//purpose : Copy the Standard_Real
// from an Array2 from TColStd (TCollection)
// to an DoubleArray from PCollection
//=======================================================================
#ifdef DEB
static Handle(PColStd_HArray2OfReal) ArrayCopy
(const TColStd_Array2OfReal& TArray)
{
Standard_Integer LowerRow = TArray.LowerRow();
Standard_Integer UpperRow = TArray.UpperRow();
Standard_Integer LowerCol = TArray.LowerCol();
Standard_Integer UpperCol = TArray.UpperCol();
Standard_Integer IndexRow, IndexCol;
Handle(PColStd_HArray2OfReal) PArray =
new PColStd_HArray2OfReal(LowerRow, UpperRow, LowerCol, UpperCol);
for (IndexRow = LowerRow; IndexRow <= UpperRow; IndexRow++) {
for (IndexCol = LowerCol; IndexCol <= UpperCol; IndexCol++) {
PArray->SetValue(IndexRow, IndexCol, TArray(IndexRow, IndexCol));
}
}
return PArray;
}
#endif
//======================================================================= //=======================================================================
//function : ArrayCopy //function : ArrayCopy
//purpose : Copy the Standard_Integer //purpose : Copy the Standard_Integer
@ -199,32 +149,6 @@ static void ArrayCopy
} }
} }
//=======================================================================
//function : ArrayCopy
//purpose : Copy the gp_Pnt2d
// from an HArray2 from PColgp (PCollection)
// to an Array2 from TColgp (TCollection)
//=======================================================================
// Unused :
#ifdef DEB
static void ArrayCopy
(const Handle(PColgp_HArray2OfPnt2d)& PArray,
TColgp_Array2OfPnt2d& TArray)
{
Standard_Integer LowerRow = TArray.LowerRow();
Standard_Integer UpperRow = TArray.UpperRow();
Standard_Integer LowerCol = TArray.LowerCol();
Standard_Integer UpperCol = TArray.UpperCol();
Standard_Integer IndexRow, IndexCol;
for (IndexRow = LowerRow; IndexRow <= UpperRow; IndexRow++) {
for (IndexCol = LowerCol; IndexCol <= UpperCol; IndexCol++) {
TArray(IndexRow, IndexCol) = PArray->Value(IndexRow, IndexCol);
}
}
}
#endif
//======================================================================= //=======================================================================
//function : ArrayCopy //function : ArrayCopy
//purpose : Copy the Standard_Real //purpose : Copy the Standard_Real
@ -244,32 +168,6 @@ static void ArrayCopy
} }
} }
//=======================================================================
//function : ArrayCopy
//purpose : Copy the Standard_Real
// from an DoubleArray from PCollection
// to an Array2 from TColStd (TCollection)
//=======================================================================
// Unused :
#ifdef DEB
static void ArrayCopy
(const Handle(PColStd_HArray2OfReal)& PArray,
TColStd_Array2OfReal& TArray)
{
Standard_Integer LowerRow = TArray.LowerRow();
Standard_Integer UpperRow = TArray.UpperRow();
Standard_Integer LowerCol = TArray.LowerCol();
Standard_Integer UpperCol = TArray.UpperCol();
Standard_Integer IndexRow, IndexCol;
for (IndexRow = LowerRow; IndexRow <= UpperRow; IndexRow++) {
for (IndexCol = LowerCol; IndexCol <= UpperCol; IndexCol++) {
TArray(IndexRow, IndexCol) = PArray->Value(IndexRow, IndexCol);
}
}
}
#endif
//======================================================================= //=======================================================================
//function : ArrayCopy //function : ArrayCopy
//purpose : Copy the Standard_Integer //purpose : Copy the Standard_Integer

View File

@ -88,36 +88,6 @@ void ProjLib_Cone::Init(const gp_Cone& Co)
isDone = Standard_False; isDone = Standard_False;
} }
//=======================================================================
//function : EvalPnt2d / EvalDir2d
//purpose : returns the Projected Pnt / Dir in the parametrization range
// of myPlane.
//=======================================================================
#ifdef DEB
static gp_Pnt2d EvalPnt2d( const gp_Pnt& P, const gp_Cone& C)
{
gp_Vec OP( C.Location(),P);
Standard_Real X = OP.Dot(gp_Vec(C.Position().XDirection()));
Standard_Real Y = OP.Dot(gp_Vec(C.Position().YDirection()));
Standard_Real Z = OP.Dot(gp_Vec(C.Position().Direction()));
Standard_Real U,V;
if ( Abs(X) > Precision::PConfusion() ||
Abs(Y) > Precision::PConfusion() ) {
U = ATan2(Y,X);
}
else {
U = 0.;
}
V = Z / Cos(C.SemiAngle());
return gp_Pnt2d( U, Z);
}
#endif
//======================================================================= //=======================================================================
//function : Project //function : Project
//purpose : //purpose :

View File

@ -117,247 +117,6 @@ static Standard_Boolean IsoIsDeg (const Adaptor3d_Surface& S,
return Along; return Along;
} }
//=======================================================================
//function : Interpolate
//purpose :
//=======================================================================
static Handle(Geom2d_BSplineCurve) Interpolate(const Handle(TColgp_HArray1OfPnt2d)& myPoints,
const Handle(TColStd_HArray1OfReal)& myParameters,
const gp_Vec2d& InitialTangent,
const gp_Vec2d& FinalTangent)
{
Handle(Geom2d_BSplineCurve) myCurve = NULL;
// This code is extraction from Geom2dAPI_Interpolate with small correction
// This is done to avoid of cyclic dependency if Geom2dAPI is used in ProjLib
Standard_Integer degree,
ii,
jj,
index,
index1,
index2,
index3,
mult_index,
inversion_problem,
num_points,
num_distinct_knots,
num_poles ;
gp_Pnt2d a_point ;
Standard_Boolean myTangentRequest = Standard_True;
Handle(TColgp_HArray1OfVec2d) myTangents =
new TColgp_HArray1OfVec2d(myPoints->Lower(),
myPoints->Upper()) ;
Handle(TColStd_HArray1OfBoolean) myTangentFlags =
new TColStd_HArray1OfBoolean(myPoints->Lower(),
myPoints->Upper()) ;
myTangentFlags->Init(Standard_False);
myTangentFlags->SetValue(1,Standard_True) ;
myTangentFlags->SetValue(myPoints->Length(),Standard_True) ;
myTangents->SetValue(1,InitialTangent) ;
myTangents->SetValue(myPoints->Length(),FinalTangent);
num_points =
num_distinct_knots =
num_poles = myPoints->Length() ;
if (num_poles == 2 && !myTangentRequest) {
degree = 1 ;
}
else if (num_poles == 3 && !myTangentRequest) {
degree = 2 ;
num_distinct_knots = 2 ;
}
else {
degree = 3 ;
num_poles += 2 ;
//if (myTangentRequest)
//for (ii = myTangentFlags->Lower() + 1 ;
// ii < myTangentFlags->Upper() ; ii++) {
//if (myTangentFlags->Value(ii)) {
//num_poles += 1 ;
//}
//}
}
TColStd_Array1OfReal parameters(1,num_poles) ;
TColStd_Array1OfReal flatknots(1,num_poles + degree + 1) ;
TColStd_Array1OfInteger mults(1,num_distinct_knots) ;
TColStd_Array1OfReal knots(1,num_distinct_knots) ;
TColStd_Array1OfInteger contact_order_array(1, num_poles) ;
TColgp_Array1OfPnt2d poles(1,num_poles) ;
for (ii = 1 ; ii <= degree + 1 ; ii++) {
flatknots.SetValue(ii,myParameters->Value(1)) ;
flatknots.SetValue(ii + num_poles,
myParameters->Value(num_points)) ;
}
for (ii = 1 ; ii <= num_poles ; ii++) {
contact_order_array.SetValue(ii,0) ;
}
for (ii = 2 ; ii < num_distinct_knots ; ii++) {
mults.SetValue(ii,1) ;
}
mults.SetValue(1,degree + 1) ;
mults.SetValue(num_distinct_knots ,degree + 1) ;
switch (degree) {
case 1:
for (ii = 1 ; ii <= num_poles ; ii++) {
poles.SetValue(ii ,myPoints->Value(ii)) ;
}
myCurve =
new Geom2d_BSplineCurve(poles,
myParameters->Array1(),
mults,
degree) ;
//myIsDone = Standard_True ;
break ;
case 2:
knots.SetValue(1,myParameters->Value(1)) ;
knots.SetValue(2,myParameters->Value(3)) ;
for (ii = 1 ; ii <= num_poles ; ii++) {
poles.SetValue(ii,myPoints->Value(ii)) ;
}
BSplCLib::Interpolate(degree,
flatknots,
myParameters->Array1(),
contact_order_array,
poles,
inversion_problem) ;
if (!inversion_problem) {
myCurve =
new Geom2d_BSplineCurve(poles,
knots,
mults,
degree) ;
//myIsDone = Standard_True ;
}
break ;
case 3:
//
// check if the boundary conditions are set
//
//if (num_points >= 3) {
//
// cannot build the tangents with degree 3 with only 2 points
// if those where not given in advance
//
//BuildTangents(myPoints->Array1(),
//myTangents->ChangeArray1(),
//myTangentFlags->ChangeArray1(),
//myParameters->Array1()) ;
//}
contact_order_array.SetValue(2,1) ;
parameters.SetValue(1,myParameters->Value(1)) ;
parameters.SetValue(2,myParameters->Value(1)) ;
poles.SetValue(1,myPoints->Value(1)) ;
for (jj = 1 ; jj <= 2 ; jj++) {
a_point.SetCoord(jj,myTangents->Value(1).Coord(jj)) ;
}
poles.SetValue(2,a_point) ;
mult_index = 2 ;
index = 3 ;
index1 = 2 ;
index2 = myPoints->Lower() + 1 ;
index3 = degree + 2 ;
if (myTangentRequest) {
for (ii = myParameters->Lower() + 1 ;
ii < myParameters->Upper() ; ii++) {
parameters.SetValue(index,myParameters->Value(ii)) ;
poles.SetValue(index,myPoints->Value(index2)) ;
flatknots.SetValue(index3,myParameters->Value(ii)) ;
index += 1 ;
index3 += 1 ;
if (myTangentFlags->Value(index1)) {
//
// set the multiplicities, the order of the contact, the
// the flatknots,
//
mults.SetValue(mult_index,mults.Value(mult_index) + 1) ;
contact_order_array(index) = 1 ;
flatknots.SetValue(index3, myParameters->Value(ii)) ;
parameters.SetValue(index,
myParameters->Value(ii)) ;
for (jj = 1 ; jj <= 2 ; jj++) {
a_point.SetCoord(jj,myTangents->Value(ii).Coord(jj)) ;
}
poles.SetValue(index,a_point) ;
index += 1 ;
index3 += 1 ;
}
mult_index += 1 ;
index1 += 1 ;
index2 += 1 ;
}
}
else {
index1 = 2 ;
for(ii = myParameters->Lower() ; ii <= myParameters->Upper() ; ii++) {
parameters.SetValue(index1,
myParameters->Value(ii)) ;
index1 += 1 ;
}
index = 3 ;
for (ii = myPoints->Lower() + 1 ; ii <= myPoints->Upper() - 1 ; ii++) {
poles.SetValue(index,
myPoints->Value(ii)) ;
index += 1 ;
}
index = degree + 1 ;
for(ii = myParameters->Lower() ; ii <= myParameters->Upper() ; ii++) {
flatknots.SetValue(index,
myParameters->Value(ii)) ;
index += 1 ;
}
}
for (jj = 1 ; jj <= 2 ; jj++) {
a_point.SetCoord(jj,
myTangents->Value(num_points).Coord(jj)) ;
}
poles.SetValue(num_poles-1 ,a_point) ;
contact_order_array.SetValue(num_poles - 1,1) ;
parameters.SetValue(num_poles,
myParameters->Value(myParameters->Upper())) ;
parameters.SetValue(num_poles -1,
myParameters->Value(myParameters->Upper())) ;
poles.SetValue(num_poles,
myPoints->Value(num_points)) ;
BSplCLib::Interpolate(degree,
flatknots,
parameters,
contact_order_array,
poles,
inversion_problem) ;
if (!inversion_problem) {
myCurve =
new Geom2d_BSplineCurve(poles,
myParameters->Array1(),
mults,
degree) ;
//myIsDone = Standard_True ;
}
break ;
}
return myCurve;
}
//======================================================================= //=======================================================================
//function : TrimC3d //function : TrimC3d
//purpose : //purpose :
@ -469,53 +228,7 @@ static void ExtendC2d (Handle(Geom2d_BSplineCurve)& aRes,
aCompCurve.Add(aSegment, aTol); aCompCurve.Add(aSegment, aTol);
aRes = aCompCurve.BSplineCurve(); aRes = aCompCurve.BSplineCurve();
}
/*
gp_Pnt2d P0;
gp_Vec2d V01, V02;
aRes->D2(t, P0, V01, V02);
gp_XY XYP1 = P0.XY() + V01.XY()*dt + .5*V02.XY()*dt*dt;
gp_Vec2d V11 = V01 + V02*dt;
if(XYP1.X() < u1) XYP1.SetX(u1);
if(XYP1.X() > u2) XYP1.SetX(u2);
if(XYP1.Y() < v1) XYP1.SetY(v1);
if(XYP1.Y() > v2) XYP1.SetY(v2);
Handle(TColgp_HArray1OfPnt2d) aPnts = new TColgp_HArray1OfPnt2d(1, 2);
Handle(TColStd_HArray1OfReal) aPars = new TColStd_HArray1OfReal(1, 2);
if(dt < 0.) {
aPnts->SetValue(1, gp_Pnt2d(XYP1));
aPnts->SetValue(2, P0);
aPars->SetValue(1, t + dt);
aPars->SetValue(2, t);
}
else {
aPnts->SetValue(2, gp_Pnt2d(XYP1));
aPnts->SetValue(1, P0);
aPars->SetValue(2, t + dt);
aPars->SetValue(1, t);
}
Handle(Geom2d_BSplineCurve) aC;
if(dt < 0.) {
aC = Interpolate(aPnts, aPars, V11, V01);
}
else {
aC = Interpolate(aPnts, aPars, V01, V11);
}
Geom2dConvert_CompCurveToBSplineCurve aConcat(aRes);
aConcat.Add(aC, Precision::PConfusion());
aRes = aConcat.BSplineCurve();
*/
}
//======================================================================= //=======================================================================
//function : Project //function : Project

View File

@ -57,25 +57,6 @@
#define DEFAULT_COLOR Quantity_NOC_GOLDENROD #define DEFAULT_COLOR Quantity_NOC_GOLDENROD
static Quantity_NameOfColor GetColorFromName( const char *name, Standard_Boolean& Found)
{
Quantity_NameOfColor ret = DEFAULT_COLOR;
Found = Standard_False;
Standard_CString colstring;
for(Standard_Integer i=0;i<=514 && !Found;i++)
{
colstring = Quantity_Color::StringName(Quantity_NameOfColor(i));
if (!strcasecmp(name,colstring)) {
ret = (Quantity_NameOfColor)i;
Found = Standard_True;
break;
}
}
return ret;
}
static Standard_Integer BUC60851 (Draw_Interpretor& /*di*/, Standard_Integer /*argc*/, const char ** /*argv*/) static Standard_Integer BUC60851 (Draw_Interpretor& /*di*/, Standard_Integer /*argc*/, const char ** /*argv*/)
{ {
Handle(AIS_InteractiveContext) context= ViewerTest_Tool::MakeContext ("buc60851"); Handle(AIS_InteractiveContext) context= ViewerTest_Tool::MakeContext ("buc60851");

View File

@ -75,23 +75,6 @@ static void ModDbgTools_Write(const TopoDS_Shape& shape,
save.close(); save.close();
} }
static void ModDbgTools_WriteCurrentShape(const Handle(TNaming_NamedShape) & NS)
{
TCollection_AsciiString entry;
TDF_Tool::Entry(NS->Label(), entry);
if (!NS.IsNull())
{
TopoDS_Shape Sh = TNaming_Tool::CurrentShape (NS);
if(!Sh.IsNull()) {
TCollection_AsciiString Entry = entry.Cat("_Cur.brep");
ModDbgTools_Write(Sh, Entry.ToCString());
}
else
cout << "ModDbgTools::Write>>> TopoDS_Shape IS NULL on Entry = "<< entry << endl;
}
else
cout << "ModDbgTools::Write>>> CurrentShape of TNaming_NamedShape IS NULL on Entry = "<< entry << endl;
}
#endif #endif
//======================================================================= //=======================================================================

View File

@ -52,9 +52,6 @@
#include <BOPDS_CommonBlock.hxx> #include <BOPDS_CommonBlock.hxx>
#include <BOPTools_AlgoTools3D.hxx> #include <BOPTools_AlgoTools3D.hxx>
static Standard_Boolean CheckSameDomainFaceInside(const TopoDS_Face& theFace1,
const TopoDS_Face& theFace2);
static Standard_Boolean AddShapeToHistoryMap(const TopoDS_Shape& theOldShape, static Standard_Boolean AddShapeToHistoryMap(const TopoDS_Shape& theOldShape,
const TopoDS_Shape& theNewShape, const TopoDS_Shape& theNewShape,
TopTools_IndexedDataMapOfShapeListOfShape& theHistoryMap); TopTools_IndexedDataMapOfShapeListOfShape& theHistoryMap);
@ -741,59 +738,6 @@ Standard_Boolean QANewModTopOpe_Tools::BoolOpe(const TopoDS_Shape& theFace1,
return Standard_True; return Standard_True;
} }
// -----------------------------------------------------------------
// static function: CheckSameDomainFaceInside
// purpose: Check if distance between several points of theFace1 and
// theFace2 is not more than sum of maximum of tolerances of
// theFace1's edges and tolerance of theFace2
// -----------------------------------------------------------------
Standard_Boolean CheckSameDomainFaceInside(const TopoDS_Face& theFace1,
const TopoDS_Face& theFace2) {
Standard_Real umin = 0., umax = 0., vmin = 0., vmax = 0.;
BRepTools::UVBounds(theFace1, umin, umax, vmin, vmax);
Handle(BOPInt_Context) aContext;
Handle(Geom_Surface) aSurface = BRep_Tool::Surface(theFace1);
Standard_Real aTolerance = BRep_Tool::Tolerance(theFace1);
aContext = new BOPInt_Context;
TopExp_Explorer anExpE(theFace1, TopAbs_EDGE);
for(; anExpE.More(); anExpE.Next()) {
const TopoDS_Edge& anEdge = TopoDS::Edge(anExpE.Current());
Standard_Real anEdgeTol = BRep_Tool::Tolerance(anEdge);
aTolerance = (aTolerance < anEdgeTol) ? anEdgeTol : aTolerance;
}
aTolerance += BRep_Tool::Tolerance(theFace2);
Standard_Integer nbpoints = 5;
Standard_Real adeltau = (umax - umin) / (nbpoints + 1);
Standard_Real adeltav = (vmax - vmin) / (nbpoints + 1);
Standard_Real U = umin + adeltau;
GeomAPI_ProjectPointOnSurf& aProjector = aContext->ProjPS(theFace2);
for(Standard_Integer i = 1; i <= nbpoints; i++, U+=adeltau) {
Standard_Real V = vmin + adeltav;
for(Standard_Integer j = 1; j <= nbpoints; j++, V+=adeltav) {
gp_Pnt2d aPoint(U,V);
if(aContext->IsPointInFace(theFace1, aPoint)) {
gp_Pnt aP3d = aSurface->Value(U, V);
aProjector.Perform(aP3d);
if(aProjector.IsDone()) {
if(aProjector.LowerDistance() > aTolerance)
return Standard_False;
}
}
}
}
return Standard_True;
}
// -------------------------------------------------------------------------------------------- // --------------------------------------------------------------------------------------------
// static function: AddShapeToHistoryMap // static function: AddShapeToHistoryMap
// purpose: // purpose:

View File

@ -56,19 +56,6 @@ static Standard_Integer SMSearch(const SelectMgr_SequenceOfSelector& seq,
} }
// Unused :
#ifdef DEB
static Standard_Boolean SMListContains(const TColStd_ListOfInteger& LL,
const Standard_Integer aMode)
{
TColStd_ListIteratorOfListOfInteger LIt;
for (LIt.Initialize(LL);LIt.More();LIt.Next())
{if(LIt.Value()==aMode) return Standard_True;}
return Standard_False;
}
#endif
//================================================== //==================================================
// Function: Create // Function: Create
// Purpose : // Purpose :

View File

@ -1965,29 +1965,6 @@ Standard_Boolean ShapeFix_Face::FixLoopWire(TopTools_SequenceOfShape& aResWires)
return isDone; return isDone;
} }
//=======================================================================
//function : GetPointOnEdge
//purpose : auxiliary
//:h0 abv 29 May 98: PRO10105 1949: like in BRepCheck, point is to be taken
// from 3d curve (but only if edge is SameParameter)
//=======================================================================
static gp_Pnt GetPointOnEdge ( const TopoDS_Edge &edge,
const Handle(ShapeAnalysis_Surface) &surf,
const Handle(Geom2d_Curve) &Crv2d,
const Standard_Real param )
{
if ( BRep_Tool::SameParameter ( edge ) ) {
Standard_Real f,l;
TopLoc_Location L;
const Handle(Geom_Curve) ConS = BRep_Tool::Curve ( edge, L, f, l );
if ( ! ConS.IsNull() )
return ConS->Value ( param ).Transformed ( L.Transformation() );
}
return surf->Value ( Crv2d->Value ( param ) );
}
//======================================================================= //=======================================================================
//function : SplitEdge //function : SplitEdge
//purpose : //purpose :

View File

@ -110,8 +110,9 @@ ShapeFix_Solid::ShapeFix_Solid(const TopoDS_Solid& solid)
// B.Add(mySolid,TopoDS::Shell(iter.Value())); // B.Add(mySolid,TopoDS::Shell(iter.Value()));
myShape = solid; myShape = solid;
} }
#ifdef DEB_GET_MIDDLE_POINT
//======================================================================= //=======================================================================
//function : CollectSolids //function : GetMiddlePoint
//purpose : //purpose :
//======================================================================= //=======================================================================
static void GetMiddlePoint(const TopoDS_Shape& aShape, gp_Pnt& pmid) static void GetMiddlePoint(const TopoDS_Shape& aShape, gp_Pnt& pmid)
@ -137,6 +138,11 @@ static void GetMiddlePoint(const TopoDS_Shape& aShape, gp_Pnt& pmid)
center /= numpoints; center /= numpoints;
pmid.SetXYZ(center); pmid.SetXYZ(center);
} }
#endif
//=======================================================================
//function : CollectSolids
//purpose :
//=======================================================================
static void CollectSolids(const TopTools_SequenceOfShape& aSeqShells , static void CollectSolids(const TopTools_SequenceOfShape& aSeqShells ,
TopTools_DataMapOfShapeListOfShape& aMapShellHoles, TopTools_DataMapOfShapeListOfShape& aMapShellHoles,
TopTools_DataMapOfShapeInteger& theMapStatus) TopTools_DataMapOfShapeInteger& theMapStatus)
@ -205,9 +211,11 @@ static void CollectSolids(const TopTools_SequenceOfShape& aSeqShells ,
} }
if(numon == 3 && pointstatus ==TopAbs_ON) { if(numon == 3 && pointstatus ==TopAbs_ON) {
//gp_Pnt pmid; #ifdef DEB_GET_MIDDLE_POINT
//GetMiddlePoint(aShell2,pmid); gp_Pnt pmid;
//bsc3d.Perform(pmid,Precision::Confusion()); GetMiddlePoint(aShell2,pmid);
bsc3d.Perform(pmid,Precision::Confusion());
#endif
pointstatus = /*(bsc3d.State() == TopAbs_IN ? TopAbs_IN :*/TopAbs_OUT; pointstatus = /*(bsc3d.State() == TopAbs_IN ? TopAbs_IN :*/TopAbs_OUT;
} }
if(pointstatus != infinstatus) { if(pointstatus != infinstatus) {

View File

@ -75,22 +75,23 @@
#define BUC60925 #define BUC60925
#define OCC352 #define OCC352
#ifdef DEB_DBGTOOLS_WRITE
//#define OCC355 //#define OCC355
//#define MDTV_DEB #define MDTV_DEB
//#define MDTV_DEB_OR #define MDTV_DEB_OR
//#define MDTV_DEB_UNN #define MDTV_DEB_UNN
//#define MDTV_DEB_INT #define MDTV_DEB_INT
//#define MDTV_DEB_GEN #define MDTV_DEB_GEN
//#define MDTV_DEB_MODUN #define MDTV_DEB_MODUN
//#define MDTV_DEB_FNB #define MDTV_DEB_FNB
//#define MDTV_DEB_WIN #define MDTV_DEB_WIN
//#define MDTV_DEB_ARG #define MDTV_DEB_ARG
//#define MDTV_DEB_SHELL #define MDTV_DEB_SHELL
#endif
#ifdef MDTV_DEB #ifdef MDTV_DEB
#include <TCollection_AsciiString.hxx> #include <TCollection_AsciiString.hxx>
#include <TDF_Tool.hxx> #include <TDF_Tool.hxx>
#include <BRepTools.hxx> #include <BRepTools.hxx>
#include <DbgTools.hxx>
#endif #endif
#ifdef DEB #ifdef DEB
#include <TCollection_AsciiString.hxx> #include <TCollection_AsciiString.hxx>
@ -115,7 +116,7 @@ void PrintEntries(const TDF_LabelMap& map)
cout << "LabelEntry = "<< entry << endl; cout << "LabelEntry = "<< entry << endl;
} }
} }
#ifdef DEB_DBGTOOLS_WRITE
//======================================================================= //=======================================================================
static void DbgTools_Write(const TopoDS_Shape& shape, static void DbgTools_Write(const TopoDS_Shape& shape,
const Standard_CString filename) const Standard_CString filename)
@ -172,8 +173,7 @@ static void DbgTools_WriteNSOnLabel (const Handle(TNaming_NamedShape)& NS,
} }
} }
#endif #endif
#endif
//=======================================================================
// //
//==================================================================== //====================================================================
static Standard_Boolean ValidArgs(const TNaming_ListOfNamedShape& Args) static Standard_Boolean ValidArgs(const TNaming_ListOfNamedShape& Args)
@ -1078,95 +1078,6 @@ static Standard_Boolean Union (const TDF_Label& L,
return Standard_True; return Standard_True;
} }
//=======================================================================
// function: FindShape
//
//=======================================================================
static TopoDS_Shape FindShape(const TopTools_ListOfShape& theList)
{
Standard_Integer anUp = theList.Extent();
TopoDS_Shape aShape;
if(anUp < 1) return aShape;
if(anUp == 1) return theList.First();
Standard_Integer aLow = 1;
TColStd_Array1OfInteger Ar1(aLow, anUp);
TopTools_Array1OfShape Ars(aLow, anUp);
TopTools_ListIteratorOfListOfShape it(theList);
Standard_Integer i=0;
for(i=aLow;it.More();it.Next(), i++) {
Ars.SetValue(i, it.Value());
Ar1.SetValue(i, 0);
}
// for(i = aLow;i<= anUp;i++) {
// const TopoDS_Shape& aS = Ars.Value(i);
// for(Standard_Integer j=i;j<=anUp;j++)
// if(aS.IsSame(Ars.Value(j)))
// Ar1.SetValue(i, Ar1.Value(i)+1);
// }
for(i = aLow;i<= anUp;i++) {
const TopoDS_Shape& aS = Ars.Value(i);
for(Standard_Integer j=i+1;j<=anUp;j++)
if(aS.IsSame(Ars.Value(j)))
return aS;
}
// Standard_Integer aNum = Ar1.Value(1);
// Standard_Integer indx = -1;
// for(i = aLow;i<= anUp;i++) {
// if(aNum < Ar1.Value(i)) {
// aNum = Ar1.Value(i);
// indx = i;
// }
// }
// if(indx == -1) return aShape;
// return Ars.Value(indx);
return aShape;
}
//=======================================================================
/*
static TopoDS_Shape FindShape(const TopTools_DataMapOfShapeListOfShape& DM)
{
TopoDS_Shape aResult;
Standard_Integer aNum = DM.Extent();
if(aNum < 1) return aResult;
// cout <<" DM Keys Nb = " << aNum <<endl;
TopTools_ListOfShape List;
TopTools_DataMapIteratorOfDataMapOfShapeListOfShape it(DM);
for (;it.More();it.Next()) {
const TopoDS_Shape& aKey1 = it.Key();
const TopTools_ListOfShape& aList = it.Value();
TopTools_ListIteratorOfListOfShape itl(aList);
for (;itl.More();itl.Next()) {
const TopoDS_Shape& aS = itl.Value();
TopTools_DataMapIteratorOfDataMapOfShapeListOfShape it2(DM);
for (;it2.More();it2.Next()) {
const TopoDS_Shape& aKey2 = it2.Key();
if(aKey2 == aKey1) continue;
else {
const TopTools_ListOfShape& aList2 = it2.Value();
TopTools_ListIteratorOfListOfShape itl2(aList2);
for(;itl2.More();itl2.Next()) {
if(aS.IsSame(itl2.Value()))
List.Append(itl2.Value());
}
}
}
}
break;
}
if(List.IsEmpty()) return aResult;
if(List.Extent() == 1) return List.First();
TopTools_ListIteratorOfListOfShape itl (List);
TopoDS_Compound Compound;
BRep_Builder B;
B.MakeCompound(Compound);
for (; itl.More(); itl.Next()){
B.Add(Compound,itl.Value());
}
return Compound;
}
*/
//======================================================================= //=======================================================================
static TopoDS_Shape FindShape(const TNaming_DataMapOfShapeMapOfShape& DM) static TopoDS_Shape FindShape(const TNaming_DataMapOfShapeMapOfShape& DM)
{ {
@ -1323,7 +1234,6 @@ static Standard_Boolean Generated (const TDF_Label& L,
if(!aList2.Extent()) return Standard_False; // Empty if(!aList2.Extent()) return Standard_False; // Empty
Standard_Boolean found = Standard_False; Standard_Boolean found = Standard_False;
//TopoDS_Shape aShape = FindShape(aList2);
TopoDS_Shape aShape = FindShape(aDM); TopoDS_Shape aShape = FindShape(aDM);
#ifdef MDTV_DEB_GEN #ifdef MDTV_DEB_GEN
if(!aShape.IsNull()) if(!aShape.IsNull())

View File

@ -137,19 +137,6 @@ void WriteNSOnLabel(const Handle(TNaming_NamedShape) & NS, const TCollection_Asc
else else
cout << "WriteNSOnLabel >>> NamedShape IS NULL" << endl; cout << "WriteNSOnLabel >>> NamedShape IS NULL" << endl;
} }
//=======================================================================
static void Write(const TopTools_MapOfShape& MS, const Standard_CString filename)
{
if (!MS.IsEmpty ()) {
TCollection_AsciiString aNam (filename);
Standard_Integer i(0);
TopTools_MapIteratorOfMapOfShape it(MS);
for(;it.More();it.Next(),i++) {
TCollection_AsciiString aName = aNam + "_" + i + ".brep";
Write ( it.Key(), aName.ToCString());
}
}
}
#endif #endif
//========================================================================================== //==========================================================================================

View File

@ -101,22 +101,6 @@ Standard_IMPORT TopoDS_Vertex FUN_tool_getv(const Standard_Integer Index,const T
#define oneINtwo ( 1) #define oneINtwo ( 1)
#define twoINone ( 2) #define twoINone ( 2)
#ifdef DEB
static void FUN_coutsta(const Standard_Integer& sta, const Standard_Integer& i1, const Standard_Integer& i2, Draw_Interpretor& di)
{
switch (sta) {
case SAME:
di<<i1<<" gives SAME bnd with "<<i2<<"\n"; break;
case DIFF:
di<<i1<<" gives OUT bnd with "<<i2<<"\n"; break;
case oneINtwo:
di<<i1<<" is IN "<<i2<<"\n"; break;
case twoINone:
di<<i2<<" is IN "<<i1<<"\n"; break;
}
}
#endif
static void FUN_test_draw(TCollection_AsciiString aa, static void FUN_test_draw(TCollection_AsciiString aa,
const TopoDS_Edge& E, const TopoDS_Face& F, const TopoDS_Edge& E, const TopoDS_Face& F,
const Standard_Integer ie, const Standard_Integer ie,

View File

@ -322,53 +322,6 @@ static const TopoDS_Shape& GetShape(const Standard_Integer IS)
return S; return S;
} }
#ifdef DEB
static const TopoDS_Shape& GetShapeSameDomain
(const Standard_Integer IS,const TopAbs_ShapeEnum TS,const TCollection_AsciiString& pre = "");
//-----------------------------------------------------------------------
// GetShapeSameDomain IS = shape index,TS = shape kind
//-----------------------------------------------------------------------
static const TopoDS_Shape& GetShapeSameDomain(const Standard_Integer IS,const TopAbs_ShapeEnum TS,const TCollection_AsciiString& pre)
{
Standard_Boolean TypeControl = Standard_True;
if ( !PHDSD ) return bidbid;
static TopoDS_Shape ShapeNull;
const Handle(TopOpeBRepDS_HDataStructure)& HDS = PHDSD->CurrentHDS();
const TopOpeBRepDS_DataStructure& BDS = PHDSD->CurrentBDS();
// check on shape index and on shape kind if kind differs from TopAbs_SHAPE
Standard_Integer ns = BDS.NbShapes();
if ( IS < 1 || IS > ns) {
TopAbs::Print(TS,cout);cout<<" "<<IS<<" does not exist in DS"<<endl;
return ShapeNull;
}
else if ( !PHDSD->ShapeKind(IS,TS) ) {
if ( TypeControl ) {
cout<<"Shape "<<IS<<" is not a ";TopAbs::Print(TS,cout);
cout<<" but a ";TopAbs::Print(BDS.Shape(IS,SFindKeep).ShapeType(),cout);
cout<<endl;
}
return ShapeNull;
}
else if ( !HDS->HasSameDomain(HDS->Shape(IS,SFindKeep)) ) {
if ( TypeControl ) cout<<"Shape "<<IS<<" is not HasSameDomain"<<endl;
return ShapeNull;
}
// shape index <IS> ok : get shape <S> of index <IS>
const TopoDS_Shape& S = BDS.Shape(IS,SFindKeep);
TopOpeBRepDS_Dumper Dumper(HDS);
TCollection_AsciiString sse = Dumper.SPrintShape(S);
TCollection_AsciiString sor = TopOpeBRepDS::SPrint(S.Orientation());
TCollection_AsciiString str;str=str+pre+sse+" is "+sor+"\n";
cout<<str;cout.flush();
return S;
}
#endif
//----------------------------------------------------------------------- //-----------------------------------------------------------------------
// SeeSectionEdge // SeeSectionEdge
//----------------------------------------------------------------------- //-----------------------------------------------------------------------
@ -525,18 +478,6 @@ static Standard_Integer SeeGeometry(const Standard_Integer IG,const TopOpeBRepDS
return 0; return 0;
} }
//-----------------------------------------------------------------------
// SeeGeometry
//-----------------------------------------------------------------------
// Unused :
#ifdef DEB
static Standard_Integer SeeGeometry(const tsee_entity& E)
{
if (!E.myEOK) return 0;
return SeeGeometry(E.myEindex,E.myETK);
}
#endif
//----------------------------------------------------------------------- //-----------------------------------------------------------------------
// SeeGeometry // SeeGeometry
//----------------------------------------------------------------------- //-----------------------------------------------------------------------
@ -575,15 +516,6 @@ Standard_Integer TOPOPE_SeeShape(char* name)
return res; return res;
} }
//-----------------------------------------------------------------------
// decalargs : shift a[*] from <-d>,modify na = na - deca
//-----------------------------------------------------------------------
// Unused :
#ifdef DEB
static void decalargs(Standard_Integer& na,const char** a,const Standard_Integer d)
{for(Standard_Integer i=1;i<na;i++)a[i]=a[i+d];na-=d;}
#endif
//----------------------------------------------------------------------- //-----------------------------------------------------------------------
// suppressarg : remove a[d],modify na-- // suppressarg : remove a[d],modify na--
//----------------------------------------------------------------------- //-----------------------------------------------------------------------
@ -611,14 +543,6 @@ Standard_EXPORT void suppressargs(Standard_Integer& na,const char** a,const Stan
na -= l-f+1; na -= l-f+1;
} }
//-----------------------------------------------------------------------
// SetTolFlag
//-----------------------------------------------------------------------
// Unused :
#ifdef DEB
static Standard_Boolean SetTolFlag(Standard_Integer& na,const char** a) { decalargs(na,a,1); return Standard_True; }
#endif
//----------------------------------------------------------------------- //-----------------------------------------------------------------------
// tsee_flags // tsee_flags
//----------------------------------------------------------------------- //-----------------------------------------------------------------------

View File

@ -64,17 +64,6 @@ static Standard_Integer SetName(const Standard_Character *C, Draw_Interpretor& d
return NbMES; return NbMES;
} }
// Unused :
#ifdef DEB
//-----------------------------------------------
static void SeemMesure(const Handle(TestTopOpeDraw_DrawableMesure) DM,const Standard_Integer CMES)
//-----------------------------------------------
{
char *pname = (char *)(*PNAME).Value(CMES).ToCString();
Draw::Set(pname,DM);
}
#endif
static void Mes_help(Draw_Interpretor& di) static void Mes_help(Draw_Interpretor& di)
{ {
di<<"\n"; di<<"\n";

View File

@ -136,36 +136,6 @@ static Standard_CString makename2(const gp_Pnt& P)
return temp; return temp;
} }
#ifdef DEB
static Handle(Geom_Curve) DrawAxe1(const TColgp_Array1OfPnt& T)
{
Standard_Integer up = T.Upper();
TColgp_Array1OfPnt *AOP = new TColgp_Array1OfPnt(1, up);
for(Standard_Integer i= 1; i <= up; i++) {
gp_Pnt pnt(T.Value(i).Coord(1), 0, 0);
(*AOP).SetValue(i, pnt);
}
Handle(Geom_Curve) C;
C = TopOpeBRepTool_CurveTool::MakeBSpline1fromPnt(*AOP);
return C;
}
#endif
#ifdef DEB
static Handle(Geom_Curve) DrawAxe2(const TColgp_Array1OfPnt& T)
{
Standard_Integer up = T.Upper();
TColgp_Array1OfPnt *AOP = new TColgp_Array1OfPnt(1, up);
for(Standard_Integer i= 1; i <= up; i++) {
gp_Pnt pnt(0, T.Value(i).Coord(2), 0);
(*AOP).SetValue(i, pnt);
}
Handle(Geom_Curve) C;
C = TopOpeBRepTool_CurveTool::MakeBSpline1fromPnt(*AOP);
return C;
}
#endif
static Handle(Geom_Curve) DrawAxe1(const TColgp_Array1OfPnt& T, static Handle(Geom_Curve) DrawAxe1(const TColgp_Array1OfPnt& T,
const Standard_Real ScaleX) const Standard_Real ScaleX)
{ {

View File

@ -78,19 +78,6 @@ static void FUN_MakeERL(TopOpeBRep_FacesIntersector& FI,TopTools_ListOfShape& ER
} }
} }
// Unused :
#ifdef DEB
static void FUN_MakeERL(const TopTools_MapOfShape& mapES,TopTools_ListOfShape& ERL)
{
ERL.Clear();
TopTools_MapIteratorOfMapOfShape itES;
for (itES.Initialize(mapES);itES.More();itES.Next()) {
const TopoDS_Shape& E = itES.Key();
ERL.Append(E);
}
}
#endif
//======================================================================= //=======================================================================
//function : TopOpeBRep_FacesFiller //function : TopOpeBRep_FacesFiller
//purpose : //purpose :

View File

@ -74,13 +74,6 @@ extern Standard_Boolean GLOBAL_bvpr;
extern void debvprmess(Standard_Integer f1,Standard_Integer f2,Standard_Integer il,Standard_Integer vp,Standard_Integer si); extern void debvprmess(Standard_Integer f1,Standard_Integer f2,Standard_Integer il,Standard_Integer vp,Standard_Integer si);
extern Standard_Boolean TopOpeBRep_GetcontextNOPUNK(); extern Standard_Boolean TopOpeBRep_GetcontextNOPUNK();
static void SSAVFF(const TopoDS_Shape& F1, const TopoDS_Shape& F2)
{
TCollection_AsciiString aname_1("ffbug_1"), aname_2("ffbug_2");
Standard_CString name_1=aname_1.ToCString(),name_2=aname_2.ToCString();
cout<<"FacesFiller : "<<name_1<<","<<name_2<<endl;
BRepTools::Write(F1,name_1); BRepTools::Write(F2,name_2);
}
#ifdef DRAW #ifdef DRAW
static void FUN_traceRLine(const TopOpeBRep_LineInter& L) static void FUN_traceRLine(const TopOpeBRep_LineInter& L)
{ {
@ -545,18 +538,6 @@ static Standard_Boolean FUN_brep_ONfirstP(const TopOpeBRep_VPointInter& vpf, con
return ONfirstP; return ONfirstP;
} }
#ifdef DEB
static void FUN_remove(TopOpeBRepDS_ListOfInterference& lI, const Handle(TopOpeBRepDS_Interference)& I)
{
TopOpeBRepDS_ListIteratorOfListOfInterference itI(lI);
while (itI.More()) {
const Handle(TopOpeBRepDS_Interference)& Icur = itI.Value();
if (Icur == I) lI.Remove(itI);
else itI.Next();
}
}
#endif
//======================================================================= //=======================================================================
//function : ProcessRLine //function : ProcessRLine
//purpose : //purpose :

View File

@ -69,7 +69,6 @@ void debvprmess(Standard_Integer f1,Standard_Integer f2,Standard_Integer il,Stan
{cout<<"f1,f2,il,vp,si : "<<f1<<","<<f2<<","<<il<<","<<vp<<","<<si<<endl;cout.flush();debvpr();} {cout<<"f1,f2,il,vp,si : "<<f1<<","<<f2<<","<<il<<","<<vp<<","<<si<<endl;cout.flush();debvpr();}
void debpoint(Standard_Integer i) {cout<<"+ debpoint"<<i<<endl;} void debpoint(Standard_Integer i) {cout<<"+ debpoint"<<i<<endl;}
void debvertex(Standard_Integer i){cout<<"+ debvertex"<<i<<endl;} void debvertex(Standard_Integer i){cout<<"+ debvertex"<<i<<endl;}
static void FUN_Raise() {cout <<"FAILURE IN TopOpeBRep_FacesFiller::ProcessVPonR"<<endl;}
Standard_EXPORT void debarc(const Standard_Integer i) {cout<<"+ debarc "<<i<<endl;} Standard_EXPORT void debarc(const Standard_Integer i) {cout<<"+ debarc "<<i<<endl;}
Standard_EXPORT void debooarc(const Standard_Integer i) {cout<<"+ debooarc "<<i<<endl;} Standard_EXPORT void debooarc(const Standard_Integer i) {cout<<"+ debooarc "<<i<<endl;}

View File

@ -66,8 +66,6 @@ static Standard_Boolean local_FindVertex(const TopOpeBRep_VPointInter& theVP,
// modified by NIZHNY-MKK Tue Nov 21 17:30:27 2000.END // modified by NIZHNY-MKK Tue Nov 21 17:30:27 2000.END
#ifdef DEB #ifdef DEB
void static FUN_debdegeneR() {}
void static FUN_debdegeneF() {}
extern Standard_Boolean TopOpeBRepDS_GettraceDEGEN(); extern Standard_Boolean TopOpeBRepDS_GettraceDEGEN();
extern Standard_Boolean TopOpeBRepDS_GettraceDSF(); extern Standard_Boolean TopOpeBRepDS_GettraceDSF();
Standard_EXPORT Standard_Boolean FUN_debnull(const TopoDS_Shape& s); Standard_EXPORT Standard_Boolean FUN_debnull(const TopoDS_Shape& s);
@ -660,8 +658,6 @@ static Standard_Integer FUN_putInterfonDegenEd
if (FUN_debnull(Ed)) cout<<"Ed is null"<<endl; if (FUN_debnull(Ed)) cout<<"Ed is null"<<endl;
if (trace) { if (trace) {
TopAbs_Orientation Edori = Ed.Orientation(); TopAbs_Orientation Edori = Ed.Orientation();
if (Edori == TopAbs_FORWARD) FUN_debdegeneF();
if (Edori == TopAbs_REVERSED) FUN_debdegeneR();
} }
Standard_Boolean trace3d = Standard_False; Standard_Boolean trace3d = Standard_False;
#ifdef DRAW #ifdef DRAW

View File

@ -306,55 +306,6 @@ static Standard_Real FUN_getx(const TopoDS_Edge& ,
return x; return x;
} }
/*static void FUN_getinfsupx(const TopoDS_Edge& E, const TopOpeBRepTool_C2DF& c2df,
const Standard_Boolean uiso,
Standard_Real& xf, Standard_Real& xl)
{ // prequesitory : E is uviso
// 2drep(E) describes [xf,xl]*[yf,yl];
// if (uiso) x = upar
// if (viso) x = vpar
Standard_Real f,l; FUN_tool_bounds(E, f,l);
Standard_Real parf = FUN_getx(E,c2df,uiso, f);
Standard_Real parl = FUN_getx(E,c2df,uiso, l);
if (parf < parl) {xf = parf; xl = parl;}
else {xf = parl; xl = parf;}
}*/
#ifdef DEB
static Standard_Boolean FUN_isonOcE(const TopOpeBRepTool_CORRISO CO, const TopoDS_Edge& cE)
{
TopTools_Array1OfShape vcE(1,2); TopOpeBRepTool_TOOL::Vertices(cE,vcE);
TopAbs_Orientation ocE = cE.Orientation();
Standard_Real tttolcE = BRep_Tool::Tolerance(cE);
Standard_Real tttuvcE = Max(CO.Tol(1,tttolcE),CO.Tol(2,tttolcE));
TopOpeBRepTool_C2DF cE2d; Standard_Boolean isb = CO.UVRep(cE,cE2d);
if (!isb) return Standard_False; // NYIRAISE
// isonOcE2d :
Standard_Boolean isonOcE2d = Standard_False;
{
// OcE (closing edge with complemented orientation):
TopAbs_Orientation oOcE = TopAbs::Complement(ocE);
TopoDS_Shape aLocalShape = cE.Oriented(oOcE);
TopoDS_Edge OcE = TopoDS::Edge(aLocalShape);
// TopoDS_Edge OcE = TopoDS::Edge(cE.Oriented(oOcE));
TopTools_Array1OfShape vOcE(1,2); TopOpeBRepTool_TOOL::Vertices(OcE,vOcE);
Standard_Real tttolOcE = BRep_Tool::Tolerance(OcE);
Standard_Real tttuvOcE = Max(CO.Tol(1,tttolOcE),CO.Tol(2,tttolOcE));
TopOpeBRepTool_C2DF OcE2d; Standard_Boolean isOb = CO.UVRep(OcE,OcE2d);
if (!isOb) return Standard_False; // NYIRAISE
Standard_Real parvce1 = TopOpeBRepTool_TOOL::ParE(1,cE); gp_Pnt2d UVvce1 = TopOpeBRepTool_TOOL::UVF(parvce1,cE2d);
Standard_Real parvOcE2 = TopOpeBRepTool_TOOL::ParE(2,OcE); gp_Pnt2d UVvOcE2 = TopOpeBRepTool_TOOL::UVF(parvOcE2,OcE2d);
Standard_Real tol = Max(tttuvcE,tttuvOcE);
isonOcE2d = (UVvce1.Distance(UVvOcE2) < tol);
}
return isonOcE2d;
}
#endif
//======================================================================= //=======================================================================
//function : PurgeFyClosingE //function : PurgeFyClosingE
//purpose : //purpose :

View File

@ -57,26 +57,6 @@ extern Standard_Boolean TopOpeBRepTool_GettraceCORRISO();
#endif #endif
// DEB // DEB
// Unused :
#ifdef DEB
static void FUN_RaiseError()
{
#ifdef DEB
Standard_Boolean trc = TopOpeBRepTool_GettracePURGE();
// Standard_Failure::Raise("TopOpeBRepTool::PurgeClosingEdges");
FUN_REINIT();
if (trc) cout <<"*********failure in TopOpeBRepTool::PurgeClosingEdges***********\n";
#endif
}
static void FUN_Raise()
{
#ifdef DEB
// cout <<"*********failure in TopOpeBRepTool::CorrectONUVISO***********\n";
// Standard_Failure::Raise("TopOpeBRepTool::CorrectONUVISO");
#endif
}
#endif
#define SPLITEDGE (0) #define SPLITEDGE (0)
#define INCREASE (1) #define INCREASE (1)
#define DECREASE (-1) #define DECREASE (-1)
@ -760,7 +740,6 @@ Standard_Boolean TopOpeBRepTool::CorrectONUVISO(const TopoDS_Face& Fin, TopoDS_F
Standard_Boolean ok = ::FUN_correctClosingE(fyisoe,Fsp); Standard_Boolean ok = ::FUN_correctClosingE(fyisoe,Fsp);
if (!ok) { if (!ok) {
FUN_Raise();
continue; continue;
} }
} }
@ -785,7 +764,6 @@ Standard_Boolean TopOpeBRepTool::CorrectONUVISO(const TopoDS_Face& Fin, TopoDS_F
Standard_Boolean ok = ::FUN_correctDegeneratedE(mve,fydege,Fsp); Standard_Boolean ok = ::FUN_correctDegeneratedE(mve,fydege,Fsp);
if (!ok) { if (!ok) {
FUN_Raise();
continue; continue;
} }
} // itdeg } // itdeg

View File

@ -69,14 +69,6 @@
#define EXTERNAL (4) #define EXTERNAL (4)
#define CLOSING (5) #define CLOSING (5)
// Unused :
#ifdef DEB
static Standard_Real FUN_nullcurv(const Standard_Real curv)
{
Standard_Real tol = Precision::Confusion()*1.e+2; // NYI
return (curv < tol);
}
#endif
static Standard_Boolean FUN_nullprodv(const Standard_Real prodv) static Standard_Boolean FUN_nullprodv(const Standard_Real prodv)
{ {
// Standard_Real tola = Precision::Angular()*1.e+1; // NYI // Standard_Real tola = Precision::Angular()*1.e+1; // NYI

View File

@ -43,17 +43,11 @@ extern TopTools_IndexedMapOfShape STATIC_PURGE_mapv;
extern TopTools_IndexedMapOfOrientedShape STATIC_PURGE_mapeds; extern TopTools_IndexedMapOfOrientedShape STATIC_PURGE_mapeds;
extern Standard_Boolean TopOpeBRepTool_GettracePURGE(); extern Standard_Boolean TopOpeBRepTool_GettracePURGE();
Standard_EXPORT void FUN_REINIT() Standard_EXPORT void FUN_REINIT()
{STATIC_PURGE_mapv.Clear(); STATIC_PURGE_mapeds.Clear();}
static void FUN_RaiseError()
{ {
#ifdef DEB STATIC_PURGE_mapv.Clear(); STATIC_PURGE_mapeds.Clear();
Standard_Boolean trc = TopOpeBRepTool_GettracePURGE();
// Standard_Failure::Raise("TopOpeBRepTool::PurgeClosingEdges");
FUN_REINIT();
if (trc) cout <<"*********failure in TopOpeBRepTool::PurgeClosingEdges***********\n";
#endif
} }
Standard_EXPORT Standard_Integer FUN_addepc(const TopoDS_Shape& ed,const TopoDS_Shape& /*f*/){ Standard_EXPORT Standard_Integer FUN_addepc(const TopoDS_Shape& ed,const TopoDS_Shape&)
{
Standard_Integer ie = STATIC_PURGE_mapeds.Add(ed); Standard_Integer ie = STATIC_PURGE_mapeds.Add(ed);
#ifdef DRAW #ifdef DRAW
// TCollection_AsciiString aa = TCollection_AsciiString("pc_"); FUN_tool_draw(aa,TopoDS::Edge(ed),TopoDS::Face(f),ie); // TCollection_AsciiString aa = TCollection_AsciiString("pc_"); FUN_tool_draw(aa,TopoDS::Edge(ed),TopoDS::Face(f),ie);
@ -61,23 +55,15 @@ Standard_EXPORT Standard_Integer FUN_addepc(const TopoDS_Shape& ed,const TopoDS_
#endif #endif
return ie; return ie;
} }
Standard_EXPORT Standard_Integer FUN_addcheckepc(const TopoDS_Shape& ed,const TopoDS_Shape& f) { Standard_EXPORT Standard_Integer FUN_addcheckepc(const TopoDS_Shape& ed,const TopoDS_Shape& f) {
Standard_Integer ie = 0; Standard_Integer ie = 0;
ie = STATIC_PURGE_mapeds.FindIndex(ed); ie = STATIC_PURGE_mapeds.FindIndex(ed);
if (ie == 0) ie = FUN_addepc(ed,f); if (ie == 0) ie = FUN_addepc(ed,f);
return ie; return ie;
} }
/*Standard_EXPORT Standard_Integer FUN_adds(const TopoDS_Shape& s) {
TopAbs_ShapeEnum typ = s.ShapeType();
TCollection_AsciiString aa; Standard_Integer is;
if (typ == TopAbs_VERTEX) {aa = TCollection_AsciiString("v_"); is = STATIC_PURGE_mapv.Add(s);}
#ifdef DRAW
Standard_Boolean trc = TopOpeBRepTool_GettracePURGE();
if (trc) FUN_tool_draw(aa,s,is);
#endif
return is;
}*/
Standard_IMPORT Standard_Integer FUN_adds(const TopoDS_Shape& s); Standard_IMPORT Standard_Integer FUN_adds(const TopoDS_Shape& s);
Standard_EXPORT void FUN_tool_tori(const TopAbs_Orientation Or) Standard_EXPORT void FUN_tool_tori(const TopAbs_Orientation Or)
{ {
switch (Or) { switch (Or) {
@ -94,374 +80,11 @@ Standard_EXPORT void FUN_tool_tori(const TopAbs_Orientation Or)
#endif #endif
Standard_EXPORT void FUN_tool_trace(const Standard_Integer Index) Standard_EXPORT void FUN_tool_trace(const Standard_Integer Index)
{if (Index == 1) cout <<"FORWARD ";
if (Index == 2) cout <<"REVERSED ";}
Standard_EXPORT void FUN_tool_trace(const gp_Pnt2d p2d)
{cout<<" = ("<<p2d.X()<<" "<<p2d.Y()<<")"<<endl;}
/*Standard_IMPORT Standard_Real FUN_tool_parOnE(const Standard_Integer Index,const TopoDS_Edge& E,const TopoDS_Face& F);
Standard_IMPORT void FUN_tool_addTomap
(const TopoDS_Shape& key,const TopoDS_Shape& elementOfitem,TopTools_DataMapOfShapeListOfShape& map,const Standard_Integer check);
Standard_IMPORT void FUN_tool_addTomap(const TopoDS_Shape& key,const TopoDS_Shape& elementOfitem,
TopTools_IndexedDataMapOfShapeListOfShape& map,const Standard_Integer check);
// ----------------------------------------------------------------------
Standard_EXPORT gp_Pnt2d FUN_GetVParonF(const TopoDS_Edge& E, const TopoDS_Face& F, const Standard_Integer Index)
// ----------------------------------------------------------------------
{ {
Standard_Real par = FUN_tool_parOnE(Index, E, F); if (Index == 1) cout <<"FORWARD ";
Standard_Real pf,pl,tol; Handle(Geom2d_Curve) PC = FUNTOOLC2D_CurveOnSurface(E,F,pf,pl,tol); if (Index == 2) cout <<"REVERSED ";
if (PC.IsNull()) Standard_Failure::Raise(" FUN_GetVParonF : no 2d curve");
gp_Pnt2d p2d; PC->D0(par,p2d);
return p2d;
} }
Standard_EXPORT void FUN_tool_trace(const gp_Pnt2d p2d)
// ----------------------------------------------------------------------
Standard_EXPORT Standard_Real FUN_toluv(const GeomAdaptor_Surface& GAS, const Standard_Real& tol3d)
// ----------------------------------------------------------------------
{ {
Standard_Real tolu = GAS.UResolution(tol3d); cout<<" = ("<<p2d.X()<<" "<<p2d.Y()<<")"<<endl;
Standard_Real tolv = GAS.VResolution(tol3d);
Standard_Real toluv = Max(tolu,tolv);
return toluv;
} }
// ----------------------------------------------------------------------
Standard_EXPORT void FUN_tool_Vertices(const TopoDS_Edge& E, TopTools_Array1OfShape& vertices)
// ----------------------------------------------------------------------
{
// Returns vertices (F,R) if E is FORWARD
// (R,V) if E is REVERSED
TopAbs_Orientation oriE = E.Orientation();
TopoDS_Vertex vF, vR; TopExp::Vertices(E,vF,vR);
Standard_Integer iF, iR;
if (oriE == TopAbs_FORWARD) {iF = 1; iR = 2;}
else {iF = 2; iR = 1;}
vertices.ChangeValue(iF) = vF;
vertices.ChangeValue(iR) = vR;
}
// ----------------------------------------------------------------------
Standard_EXPORT void FUN_mapVloe(const TopoDS_Shape& F, TopTools_IndexedDataMapOfShapeListOfShape& mapVloe)
// ----------------------------------------------------------------------
{
mapVloe.Clear();
// TopExp::MapShapesAndAncestors(F,TopAbs_VERTEX,TopAbs_EDGE,mapVloe);
TopExp_Explorer exe(F, TopAbs_EDGE);
for (; exe.More(); exe.Next()){
const TopoDS_Shape e = exe.Current();
TopExp_Explorer exv(e, TopAbs_VERTEX);
for (; exv.More(); exv.Next()){
const TopoDS_Shape& v = exv.Current();
FUN_tool_addTomap(v, e, mapVloe, 0);
}
}
}*/
//======================================================================
/*Standard_EXPORT Standard_Boolean FUN_DetectEdgeswithfaultyUV
(const TopoDS_Face& Fin, const TopoDS_Shape& fF, const TopTools_ListOfShape& ISOEds,
const Standard_Boolean has2fybounds, TopTools_ListOfShape& lfyE, Standard_Integer& Ivfaulty,
const Standard_Boolean& stopatfirst=Standard_False)
// purpose : finding out edges <lfyE> / its UV rep. on <Fin>
// is unconnected to the other pcurves.
// if (has2fybounds), the 2 bounds of the pcurve are faulty.
// else : Ivfaulty is index of faulty vertex.
// return True if at least one edge is faulty
{
// <ISOEds> : list of pcurves to check among <fF>'s 2d rep. edges.
// <ISOEds> are edges of <fF>
lfyE.Clear();
Ivfaulty = 0; // dummy if has2faultybounds
TopTools_ListOfShape Eds;
TopExp_Explorer exe(fF, TopAbs_EDGE);
for (; exe.More(); exe.Next()) Eds.Append(exe.Current());
// <mapVloe> :
// ----------
// key = a vertex boundary of a closing edge,
// item = the list of edges connexed to the vertex.
TopTools_IndexedDataMapOfShapeListOfShape mapVloe; ::FUN_mapVloe(fF,mapVloe);
const Handle(Geom_Surface)& SU = BRep_Tool::Surface(Fin);
GeomAdaptor_Surface GAS(SU);
Standard_Real tttol = 1.e-8;
Standard_Real tttolF = BRep_Tool::Tolerance(Fin);
Standard_Real tttuvF = FUN_toluv(GAS,tttolF);
// fF's checking :
// -----------------
// An edge is valid if the first and last vertices are valid:
// vertex <vISOe> is valid if there is an edge with bound <ve> such that :
// <vISOe> and <ve> share same UV geometry
// <vISOe> and <ve> are of opposite orientation.
TopTools_ListIteratorOfListOfShape itISOEd(ISOEds);
for (; itISOEd.More(); itISOEd.Next()) {
const TopoDS_Edge& ISOe = TopoDS::Edge(itISOEd.Value());
TopAbs_Orientation oriISO = ISOe.Orientation();
if (M_INTERNAL(oriISO) || M_EXTERNAL(oriISO)) continue;
Standard_Real tttolISOe = BRep_Tool::Tolerance(ISOe);
Standard_Real tttuvISOe = FUN_toluv(GAS,tttolISOe);
TopTools_Array1OfShape vISOE(1,2); FUN_tool_Vertices(ISOe, vISOE);
Standard_Boolean closed = vISOE(1).IsSame(vISOE(2));
if (closed) continue; // closed edge is ass
Standard_Integer nfyv = 0;
for (Standard_Integer ivISOe = 1; ivISOe <=2; ivISOe++) {
// <vISOe> (boundary of <ISOe>):
const TopoDS_Vertex& vISOe = TopoDS::Vertex(vISOE(ivISOe));
gp_Pnt2d UVvISOe = FUN_GetVParonF(ISOe, Fin, ivISOe);
Standard_Real tttolvISOe = BRep_Tool::Tolerance(vISOe);
Standard_Real tttuvvISOe = FUN_toluv(GAS,tttolvISOe);
Standard_Boolean isbound = mapVloe.Contains(vISOe);
if (!isbound) {FUN_RaiseError(); return Standard_False;}
// <vISOeok> :
Standard_Boolean vISOeok = Standard_False;
const TopTools_ListOfShape& loe = mapVloe.FindFromKey(vISOe);
Standard_Integer nloe = loe.Extent();
for (TopTools_ListIteratorOfListOfShape ite(loe); ite.More(); ite.Next()) {
const TopoDS_Edge& E = TopoDS::Edge(ite.Value());
if (E.IsSame(ISOe)) continue;
Standard_Real tttolE = BRep_Tool::Tolerance(E);
Standard_Real tttuvE = FUN_toluv(GAS,tttolE);
TopTools_Array1OfShape vE(1,2); FUN_tool_Vertices(E,vE);
for (Standard_Integer ive = 1; ive <=2; ive++) {
const TopoDS_Vertex& ve = TopoDS::Vertex(vE(ive));
Standard_Boolean samev = ve.IsSame(vISOe);
if (!samev) continue;
if (ive == ivISOe) continue;
gp_Pnt2d UVve = FUN_GetVParonF(E, Fin, ive);
Standard_Real tttolve = BRep_Tool::Tolerance(ve);
Standard_Real tttuvve = FUN_toluv(GAS,tttolve);
tttol = Max(tttol,Max(tttuvF,Max(tttuvE,Max(tttuvISOe,Max(tttuvve,tttuvvISOe)))));
Standard_Boolean isequal = UVvISOe.IsEqual(UVve,tttol);
if (isequal) {vISOeok = Standard_True; break;}
} // ive
if (vISOeok) break;
} // ite(loe)
if (!vISOeok) nfyv++;
Standard_Boolean stop = (!has2fybounds && (nfyv > 0));
if (stop) {
if (Ivfaulty == 0) Ivfaulty = ivISOe;//xpu121098 (cto900J4,f4ou) : first faulty edge
break;
}
} // ivISOe = 1..2
Standard_Boolean found = has2fybounds && (nfyv == 2);
found = found || (!has2fybounds && (nfyv == 1));
if (found) {
lfyE.Append(ISOe);
}
}
Standard_Integer n = lfyE.Extent();
Standard_Boolean det = (n != 0);
return det;
} // FUN_DetectEdgeswithfaultyUV
Standard_EXPORT Standard_Boolean FUN_DetectEdgewithfaultyUV
(const TopoDS_Face& Fin, const TopoDS_Shape& fF, const TopTools_ListOfShape& ISOEds,
const Standard_Boolean has2fybounds, TopoDS_Shape& fyE, Standard_Integer& Ivfaulty)
// purpose : finding out first edge <fyE> / its UV rep. on <Fin>
// is unconnected to the other pcurves.
// if (has2fybounds), the 2 bounds of the pcurve are faulty.
// else : Ivfaulty is index of faulty vertex.
// return True if at least one edge is faulty
{
// <ISOEds> : list of pcurves to check among <fF>'s 2d rep. edges.
// <ISOEds> are edges of <fF>
TopTools_ListOfShape lfyE;
Standard_Boolean det = FUN_DetectEdgeswithfaultyUV(Fin,fF,ISOEds,has2fybounds,lfyE,Ivfaulty);
if (det) fyE = lfyE.First();
return det;
}
// ----------------------------------------------------------------------
Standard_EXPORT Standard_Boolean FUN_DetectFaultyClosingEdge
(const TopoDS_Face& Fin,const TopTools_ListOfShape& Eds,const TopTools_ListOfShape& cEds,TopTools_ListOfShape& fyE)
// ----------------------------------------------------------------------
{
#ifdef DEB
Standard_Boolean trc = TopOpeBRepTool_GettracePURGE();
for (TopTools_ListIteratorOfListOfShape it(Eds); it.More(); it.Next()){
const TopoDS_Shape& ed = it.Value();
TopExp_Explorer ex;
for (ex.Init(ed, TopAbs_VERTEX); ex.More(); ex.Next())
// for (TopExp_Explorer ex(ed, TopAbs_VERTEX); ex.More(); ex.Next())
FUN_adds(ex.Current());}
#endif
// <cEds> and <Eds> are the lists of closed and non-"closing" edges
// describing a wire boundary on face <Fin>.
// ("closing" edge = edge built on the geometry of a closing edge of <Fin> )
// If <W> has UV non-connexed edges, returns <True> if <fyE> is the list of faulty cEds
// fyE = {e / e has its 2 bounds non-UVconnexed}
// Returns <False> elsewhere.
// prequesitory : wire <W> is 3d-connexed, so a faulty edge must be a
// closing edge.
// <mapVloe> :
// ----------
// key = a vertex boundary of a closing edge,
// item = the list of edges connexed to the vertex.
TopTools_DataMapOfShapeListOfShape mapVloe;
for (TopTools_ListIteratorOfListOfShape itEd(Eds); itEd.More(); itEd.Next()) {
const TopoDS_Edge& E = TopoDS::Edge(itEd.Value());
TopExp_Explorer ex;
for (ex.Init(E, TopAbs_VERTEX); ex.More(); ex.Next()) {
// for (TopExp_Explorer ex(E, TopAbs_VERTEX); ex.More(); ex.Next()) {
const TopoDS_Shape& v = ex.Current();
FUN_tool_addTomap(v, E, mapVloe, 0);
}
}
const Handle(Geom_Surface)& SU = BRep_Tool::Surface(TopoDS::Face(Fin));
GeomAdaptor_Surface GAS(SU);
Standard_Real tttol = 1.e-8;
Standard_Real tttolF = BRep_Tool::Tolerance(TopoDS::Face(Fin));
Standard_Real tttuvF = FUN_toluv(GAS,tttolF);
Standard_Boolean uclosed,vclosed; Standard_Real uperiod,vperiod;
Standard_Boolean uvclosed = FUN_tool_closedS(Fin,uclosed,uperiod,vclosed,vperiod);
// wire's checking :
// -----------------
// An edge is valid if the first and last vertices are valid:
// vertex <vce> is valid if there is an edge with bound <ve> verifying :
// <vce> and <ve> share same UV geometry
// <vce> and <ve> are of opposite orientation.
TopTools_ListIteratorOfListOfShape itCEd(cEds);
for (; itCEd.More(); itCEd.Next()) {
const TopoDS_Edge& cE = TopoDS::Edge(itCEd.Value());
Standard_Boolean isou,isov; gp_Pnt2d o2d; gp_Dir2d d2d;
Standard_Real f,l,tol; Handle(Geom2d_Curve) PC = FUNTOOLC2D_CurveOnSurface(cE,Fin,f,l,tol);
Standard_Boolean isouv = FUN_tool_IsUViso(PC,isou,isov,d2d,o2d);
#ifdef DEB
Standard_Integer icE = FUN_addcheckepc(cE,Fin);
if (trc) {cout<<"closing edge "<<icE<<" "; TopAbs::Print(cE.Orientation(),cout);
cout<<" : \n";}
#endif
Standard_Real tttolcE = BRep_Tool::Tolerance(cE);
Standard_Real tttuvcE = FUN_toluv(GAS,tttolcE);
Standard_Boolean cEKO = Standard_True;
TopTools_Array1OfShape vcE(1,2); FUN_tool_Vertices(cE, vcE);
for (Standard_Integer ivce = 1; ivce <=2; ivce++) {
// <vce> (boundary of <cE>):
const TopoDS_Vertex& vce = TopoDS::Vertex(vcE(ivce));
gp_Pnt2d UVvce = FUN_GetVParonF(cE, Fin, ivce);
#ifdef DEB
// recall in one wire, there are 2 vertices for one non-degenerated closing edge
Standard_Integer ivmapv = STATIC_PURGE_mapv.Add(vce);
if (trc) {
cout<<"v"<<ivmapv<<" ";FUN_tool_trace(ivce);cout<<" in closing edge "<<icE;
FUN_tool_trace(UVvce);
#ifdef DRAW
TCollection_AsciiString bb("uv_");bb += TCollection_AsciiString(ivmapv);FUN_tool_draw(bb,UVvce);
#endif
}
#endif
Standard_Real tttolvce = BRep_Tool::Tolerance(vce);
Standard_Real tttuvvce = FUN_toluv(GAS,tttolvce);
Standard_Boolean isbound = mapVloe.IsBound(vce);
if (!isbound) continue; //xpu201198 cto016E2 (e3on)
// <vceok> :
Standard_Boolean vceok = Standard_False;
const TopTools_ListOfShape& loe = mapVloe.Find(vce);
Standard_Integer nloe = loe.Extent();
#ifdef DRAW
Standard_Boolean tdr = Standard_False;
if (tdr) {
Standard_Integer inde = 1;
for (TopTools_ListIteratorOfListOfShape ite(loe); ite.More(); ite.Next()) {
const TopoDS_Shape& eee = ite.Value(); FUN_drawe(eee,inde); inde++;
}
}
#endif
for (TopTools_ListIteratorOfListOfShape ite(loe); ite.More(); ite.Next()) {
const TopoDS_Edge& E = TopoDS::Edge(ite.Value());
// if (E.IsSame(cE)) continue; // closing FORWARD and REVERSED EDGES are UV disjoint
#ifdef DEB
Standard_Integer iE = FUN_addcheckepc(E,Fin);
#endif
Standard_Real tttolE = BRep_Tool::Tolerance(E);
Standard_Real tttuvE = FUN_toluv(GAS,tttolE);
TopTools_Array1OfShape vE(1,2); FUN_tool_Vertices(E,vE);
for (Standard_Integer ive = 1; ive <=2; ive++) {
const TopoDS_Vertex& ve = TopoDS::Vertex(vE(ive));
Standard_Boolean samev = ve.IsSame(vce);
if (!samev) continue;
if (ive == ivce) continue;
gp_Pnt2d UVve = FUN_GetVParonF(E, Fin, ive);
Standard_Real tttolve = BRep_Tool::Tolerance(ve);
Standard_Real tttuvve = FUN_toluv(GAS,tttolve);
tttol = Max(tttol,Max(tttuvF,Max(tttuvE,Max(tttuvcE,Max(tttuvve,tttuvvce)))));
// Standard_Boolean isequal = UVvce.IsEqual(UVve,tttol);
Standard_Real dd=0., xperiod=0.;
if (uclosed && isou) {dd = UVve.X()-UVvce.X(); xperiod = uperiod;}
if (vclosed && isov) {dd = UVve.Y()-UVvce.Y(); xperiod = vperiod;}
Standard_Boolean xok = (Abs(dd)<tttol) || (Abs(Abs(dd)-xperiod)<tttol);
Standard_Boolean isequal = xok;
if (isequal) {
vceok = Standard_True;
#ifdef DEB
if (trc)
{cout<<"vertex ";FUN_tool_trace(ivce);cout<<" of closing edge "<<icE;
cout<<" is connexed to vertex ";FUN_tool_trace(ive);cout<<" of edge "<<iE<<endl;}
#endif
}
break;
} // ive
if (vceok) break;
} // ite(loe)
#ifdef DEB
if (trc && !vceok) {cout<<" vertex ";FUN_tool_trace(ivce);
cout<<"of closing edge "<<icE<<" is faulty"<<endl;}
#endif
cEKO = cEKO && (!vceok);
} // ivce
#ifdef DEB
if (trc) {if (!cEKO) cout<<"-> valid edge"<<endl;
else cout<<"-> faulty edge"<<endl;}
#endif
if (cEKO) {fyE.Append(cE);}
}
return (!fyE.IsEmpty());
}
Standard_EXPORT Standard_Boolean FUN_isUVClosed(const TopoDS_Face& Fin, const TopoDS_Face& fF)
// purpose : returns true is fF is UV connexed
{
TopTools_ListOfShape efF;
TopExp_Explorer ex(fF, TopAbs_EDGE);
for (; ex.More(); ex.Next()) efF.Append(ex.Current());
Standard_Integer Ivfaulty; TopTools_ListOfShape lfyE; Standard_Boolean stopatfirst = Standard_True;
Standard_Boolean foundfaulty = FUN_DetectEdgeswithfaultyUV(Fin,fF,efF,Standard_False,lfyE,Ivfaulty,stopatfirst);
return !foundfaulty;
}*/

View File

@ -237,30 +237,6 @@ void GetTypeAndSignfromString (const char* name,AIS_KindOfInteractive& TheType,S
#include <BRepOffsetAPI_MakeThickSolid.hxx> #include <BRepOffsetAPI_MakeThickSolid.hxx>
#include <BRepOffset.hxx> #include <BRepOffset.hxx>
//==============================================================================
//function : GetTypeNameFromShape
//purpose : get the shape type as a string from a shape
//==============================================================================
static const char* GetTypeNameFromShape( const TopoDS_Shape& aShape )
{ const char *ret = "????";
if ( aShape.IsNull() ) ret = "Null Shape";
switch ( aShape.ShapeType() ) {
case TopAbs_COMPOUND : ret = "COMPOUND" ; break;
case TopAbs_COMPSOLID : ret = "COMPSOLID" ; break;
case TopAbs_SOLID : ret = "SOLID" ; break;
case TopAbs_SHELL : ret = "SHELL" ; break;
case TopAbs_FACE : ret = "FACE" ; break;
case TopAbs_WIRE : ret = "WIRE" ; break;
case TopAbs_EDGE : ret = "EDGE" ; break;
case TopAbs_VERTEX : ret = "VERTEX" ; break;
case TopAbs_SHAPE : ret = "SHAPE" ; break;
}
return ret;
}
//============================================================================== //==============================================================================
// VIEWER OBJECT MANAGEMENT GLOBAL VARIABLES // VIEWER OBJECT MANAGEMENT GLOBAL VARIABLES
//============================================================================== //==============================================================================
@ -450,18 +426,7 @@ static TopoDS_Shape GetShapeFromName(const char* name)
return S; return S;
} }
//==============================================================================
//function : GetShapeFromName
//purpose : Compute an Shape from a draw variable or a file name
//==============================================================================
// Unused :
#ifdef DEB
static TopoDS_Shape GetShapeFromAIS(const AIS_InteractiveObject & TheAisIO )
{
TopoDS_Shape TheShape=((*(Handle(AIS_Shape)*)&TheAisIO))->Shape();
return TheShape;
}
#endif
//============================================================================== //==============================================================================
//function : GetAISShapeFromName //function : GetAISShapeFromName
//purpose : Compute an AIS_Shape from a draw variable or a file name //purpose : Compute an AIS_Shape from a draw variable or a file name
@ -2027,112 +1992,6 @@ static int VDisplay2 (Draw_Interpretor& di, Standard_Integer argc, const char**
return 0; return 0;
} }
//==============================================================================
//function : VMoveA
//purpose : Test the annimation of an object along a
// predifined trajectory
//Draw arg : vmove ShapeName
//==============================================================================
#ifdef DEB
static int VMoveA (Draw_Interpretor& di, Standard_Integer argc, const char** argv) {
OSD_Timer myTimer;
myTimer.Start();
if (TheAISContext()->HasOpenedContext())
TheAISContext()->CloseLocalContext();
Standard_Real Step=2*M_PI/180;
Standard_Real Angle=0;
// R est le rayon de l'hellicoide
Standard_Real R=50;
// D est la distance parcourue en translation en 1 tour
Standard_Real D=50;
Handle(AIS_InteractiveObject) aIO;
if (GetMapOfAIS().IsBound2(argv[1]))
aIO = Handle(AIS_InteractiveObject)::DownCast(GetMapOfAIS().Find2(argv[1]));
if (aIO.IsNull()) {
di<<" Syntaxe error: "<<argv[1]<<" doesn't exist"<<"\n";
return 1;
}
TheAISContext()->Deactivate(aIO);
// boucle generant le mouvement
if(argc==3) {
di<<" Transformations"<<"\n";
for (Standard_Real myAngle=0;Angle<5*2*M_PI; myAngle++) {
Angle=Step*myAngle;
gp_Ax3 newBase(gp_Pnt(R*cos(Angle), R*sin(Angle), D*Angle/(2*M_PI) ), gp_Vec(0,0,1), gp_Vec(1,0,0) );
gp_Trsf myTransfo;
myTransfo.SetTransformation(newBase.Rotated(gp_Ax1(gp_Pnt(R*cos(Angle),R*sin(Angle),0), gp_Dir(0,0,1) ),Angle ) );
TheAISContext()->SetLocation(aIO,myTransfo);
TheAISContext() ->UpdateCurrentViewer();
}
}
else {
di<<" Locations"<<"\n";
gp_Trsf myAngleTrsf;
myAngleTrsf.SetRotation(gp_Ax1(gp_Pnt(0,0,0),gp_Dir(0,0,1) ), Step );
TopLoc_Location myDeltaAngle (myAngleTrsf);
gp_Trsf myDistTrsf;
myDistTrsf.SetTranslation(gp_Dir(0,0,1) );
TopLoc_Location myDeltaDist (myDistTrsf);
TopLoc_Location myTrueLoc;
for (Standard_Real myAngle=0;Angle<5*2*M_PI; myAngle++) {
Angle=Step*myAngle;
myTrueLoc=myTrueLoc*myDeltaAngle*myDeltaDist;
TheAISContext()->SetLocation(aIO,myTrueLoc );
TheAISContext() ->UpdateCurrentViewer();
}
}
TopoDS_Shape ShapeBis=((*(Handle(AIS_Shape)*)&aIO)->Shape()).Located( aIO->Location() );
//TopLoc_Location Tempo=aIO->Location();
//TopoDS_Shape ShapeBis=((*(Handle(AIS_Shape)*)&aIO)->Shape());
//ShapeBis.Located(Tempo);
// On reset la location (origine) contenue dans l'AISInteractiveObject
TheAISContext() ->ResetLocation(aIO);
// On force aShape a devenir l'AIS IO propre a ShapeBis
// Pour cela on force aShape(AIS IO) a devenir une AISShape
// ->Set() est une methode de AIS_Shape
(*(Handle(AIS_Shape)*)& aIO)->Set(ShapeBis);
// On donne a ShapeBis le nom de l'AIS IO
//Rep::Set(argv[1],ShapeBis);
TheAISContext()->Redisplay(aIO,Standard_False);
// On reactive la selection des primitives sensibles
TheAISContext()->Activate(aIO,0);
TheAISContext() ->UpdateCurrentViewer();
a3DView() -> Redraw();
myTimer.Stop();
di<<" Temps ecoule "<<"\n";
myTimer.Show();
return 0;
}
#endif
//============================================================================== //==============================================================================
//function : VPerf //function : VPerf
//purpose : Test the annimation of an object along a //purpose : Test the annimation of an object along a
@ -3010,91 +2869,8 @@ static int VPickShape( Draw_Interpretor& di, Standard_Integer argc, const char**
} }
} }
return 0; return 0;
} }
//=======================================================================
//function : VPickObject
//purpose : filters can be set (type of Object to pick....
//
//=======================================================================
// Unused :
#ifdef DEB
static int VPickObject( Draw_Interpretor& , Standard_Integer /*argc*/, const char** /*argv*/)
{
// preparation de la nomination automatique
static TCollection_AsciiString ObjType[] ={"None","Datum","Shape","Object","Relation"};
// static char* DatumSig [8] ={"Point","Axis","Trih","PlTri","Line","Circle","Plane","UnK"};
/* TCollection_AsciiString name;
Standard_Integer NbToPick = argc>2 ? argc-2 : 1;
if(NbToPick==1){
PickSh = ViewerTest::PickObject(theType);
if(PickSh.IsNull())
return 1;
if(argc>2){
name += argv[2];
}
else{
if(!PickSh.IsNull()){
nbOfSub[Standard_Integer(theType)]++;
name += "Picked_";
name += nameType[Standard_Integer(theType)];
TCollection_AsciiString indxstring(nbOfSub[Standard_Integer(theType)]);
name +="_";
name+=indxstring;
}
}
// si on avait une petite methode pour voir si la shape
// est deja dans la Double map, ca eviterait de creer....
DBRep::Set(name.ToCString(),PickSh);
Handle(AIS_Shape) newsh = new AIS_Shape(PickSh);
GetMapOfAIS().Bind(newsh, name);
TheAISContext()->Display(newsh);
cout<<"Nom de la shape pickee : "<<name<<endl;
}
// Plusieurs objets a picker, vite vite vite....
//
else{
Standard_Boolean autonaming = !strcasecmp(argv[2],".");
Handle(TopTools_HArray1OfShape) arr = new TopTools_HArray1OfShape(1,NbToPick);
if(ViewerTest::PickShapes(theType,arr)){
for(Standard_Integer i=1;i<=NbToPick;i++){
PickSh = arr->Value(i);
if(!PickSh.IsNull()){
if(autonaming){
nbOfSub[Standard_Integer(theType)]++;
name.Clear();
name += "Picked_";
name += nameType[Standard_Integer(theType)];
TCollection_AsciiString indxstring(nbOfSub[Standard_Integer(theType)]);
name +="_";
name+=indxstring;
}
}
else
name = argv[1+i];
DBRep::Set(name.ToCString(),PickSh);
Handle(AIS_Shape) newsh = new AIS_Shape(PickSh);
GetMapOfAIS().Bind(newsh, name);
cout<<"display of picke shape #"<<i<<" - nom : "<<name<<endl;
TheAISContext()->Display(newsh);
}
}
}
*/
return 0;
}
#endif
//======================================================================= //=======================================================================
//function : list of known objects //function : list of known objects
//purpose : //purpose :

View File

@ -95,25 +95,6 @@ static void printtolblend(Draw_Interpretor& di)
di<<"tolblend "<<ta<<" "<<t3d<<" "<<t2d<<" "<<fl<<"\n"; di<<"tolblend "<<ta<<" "<<t3d<<" "<<t2d<<" "<<fl<<"\n";
} }
// Unused :
#ifdef DEB
static Standard_Integer tolblend(Draw_Interpretor& di, Standard_Integer narg, const char** a)
{
if(narg == 1){
printtolblend(di);
return 0;
}
else if(narg == 5){
ta = Draw::Atof(a[1]);
t3d = Draw::Atof(a[2]);
t2d = Draw::Atof(a[3]);
fl = Draw::Atof(a[4]);
return 0;
}
return 1;
}
#endif
static Standard_Integer VBLEND(Draw_Interpretor& di, Standard_Integer narg, const char** a) static Standard_Integer VBLEND(Draw_Interpretor& di, Standard_Integer narg, const char** a)
{ {
if(Rakk != 0) {delete Rakk; Rakk = 0;} if(Rakk != 0) {delete Rakk; Rakk = 0;}