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

0023248: Wrong result done by solid classifier algorithm for infinite point

This commit is contained in:
pkv 2012-07-06 13:52:43 +04:00
parent c281a4a4a1
commit a15d6aceb6
2 changed files with 169 additions and 104 deletions

View File

@ -23,7 +23,32 @@
#include <Draw_Interpretor.hxx>
#include <DBRep.hxx>
#include <BRep_Builder.hxx>
#include <DrawTrSurf.hxx>
#include <string.h>
#include <stdio.h>
#include <Standard_ErrorHandler.hxx>
#include <Precision.hxx>
#include <TCollection_AsciiString.hxx>
#include <gp_Lin.hxx>
#include <gp_Pnt.hxx>
#include <gp_Dir.hxx>
#include <gp_Ax1.hxx>
#include <ElCLib.hxx>
#include <TColgp_SequenceOfPnt.hxx>
#include <GeomAbs_JoinType.hxx>
#include <Geom_Line.hxx>
#include <IntCurvesFace_Intersector.hxx>
#include <TopAbs.hxx>
#include <TopAbs_Orientation.hxx>
#include <TopoDS.hxx>
#include <TopoDS_Shape.hxx>
#include <TopoDS_Compound.hxx>
#include <TopoDS_CompSolid.hxx>
@ -33,29 +58,82 @@
#include <TopoDS_Wire.hxx>
#include <TopoDS_Edge.hxx>
#include <TopoDS_Vertex.hxx>
#include <TCollection_AsciiString.hxx>
#include <BRepIntCurveSurface_Inter.hxx>
#include <Geom_Line.hxx>
#include <DrawTrSurf.hxx>
#include <string.h>
#include <TopoDS_Iterator.hxx>
#include <BRep_Builder.hxx>
#include <BRep_Tool.hxx>
#include <TopExp_Explorer.hxx>
#include <TopTools_ListOfShape.hxx>
#include <TopTools_ListIteratorOfListOfShape.hxx>
#include <TopTools_MapOfShape.hxx>
#include <Standard_ErrorHandler.hxx>
#include <LocOpe_CSIntersector.hxx>
#include <LocOpe_SequenceOfLin.hxx>
#include <LocOpe_PntFace.hxx>
#include <BRepFeat_MakeDPrism.hxx>
//#ifdef WNT
#include <stdio.h>
//#endif
#include <BRepTools.hxx>
#include <BRepIntCurveSurface_Inter.hxx>
#include <BRepOffset.hxx>
#include <BRepOffset_MakeOffset.hxx>
#include <BRepClass3d_SolidClassifier.hxx>
static
void SampleEdges (const TopoDS_Shape& theShape,
TColgp_SequenceOfPnt& theSeq);
static
TopoDS_Face NextFaceForPrism (const TopoDS_Shape& shape,
const TopoDS_Shape& basis,
const gp_Ax1& ax1);
static
void PrintState (Draw_Interpretor& aDI,
const TopAbs_State& aState);
//
static Standard_Integer emptyshape(Draw_Interpretor&, Standard_Integer, const char** );
static Standard_Integer subshape (Draw_Interpretor&, Standard_Integer, const char** );
static Standard_Integer brepintcs (Draw_Interpretor&, Standard_Integer, const char** );
static Standard_Integer MakeBoss (Draw_Interpretor&, Standard_Integer, const char** );
static Standard_Integer MakeShell (Draw_Interpretor&, Standard_Integer, const char** );
static Standard_Integer xbounds (Draw_Interpretor&, Standard_Integer, const char** );
static Standard_Integer xclassify (Draw_Interpretor&, Standard_Integer, const char** );
//=======================================================================
// shape : shape name V/E/W/F/SH/SO/CS/C
//function : OtherCommands
//purpose :
//=======================================================================
void BRepTest::OtherCommands(Draw_Interpretor& theCommands)
{
static Standard_Boolean done = Standard_False;
if (done) return;
done = Standard_True;
static Standard_Integer emptyshape(Draw_Interpretor& , Standard_Integer n, const char** a)
const char* g = "TOPOLOGY other commands";
theCommands.Add("shape",
"shape name V/E/W/F/Sh/So/CS/C; make a empty shape",__FILE__,emptyshape,g);
theCommands.Add("subshape",
"subshape name V/E/W/F/Sh/So/CS/C index; get subsshape <index> of given type"
,__FILE__,subshape,g);
theCommands.Add("BRepIntCS",
"Calcul d'intersection entre face et curve : BRepIntCS curve shape"
,__FILE__,brepintcs,g);
theCommands.Add("makeboss", "create a boss on the shape myS", __FILE__, MakeBoss, g);
theCommands.Add("mksh", "create a shell on Shape", __FILE__, MakeShell, g);
theCommands.Add("xbounds", "xbounds face", __FILE__, xbounds, g);
theCommands.Add("xclassify", "use xclassify Solid [Tolerance=1.e-7]", __FILE__, xclassify, g);
}
//=======================================================================
//function : emptyshape
//purpose : shape : shape name V/E/W/F/SH/SO/CS/C
//=======================================================================
Standard_Integer emptyshape(Draw_Interpretor& , Standard_Integer n, const char** a)
{
if (n <= 1) return 1;
@ -101,10 +179,10 @@ static Standard_Integer emptyshape(Draw_Interpretor& , Standard_Integer n, const
}
//=======================================================================
// subshape
//function : subshape
//purpose :
//=======================================================================
static Standard_Integer subshape(Draw_Interpretor& di, Standard_Integer n, const char** a)
Standard_Integer subshape(Draw_Interpretor& di, Standard_Integer n, const char** a)
{
if (n <= 2) return 1;
@ -195,12 +273,11 @@ static Standard_Integer subshape(Draw_Interpretor& di, Standard_Integer n, const
}
return 0;
}
//=======================================================================
// subshape
//function : brepintcs
//purpose :
//=======================================================================
static Standard_Integer brepintcs(Draw_Interpretor& , Standard_Integer n, const char** a)
Standard_Integer brepintcs(Draw_Interpretor& , Standard_Integer n, const char** a)
{
if (n <= 2) return 1;
TopoDS_Shape S = DBRep::Get(a[n-1]);
@ -247,40 +324,12 @@ static Standard_Integer brepintcs(Draw_Interpretor& , Standard_Integer n, const
//POP pour NT
return 0;
}
#include <TopoDS.hxx>
#include <TopAbs.hxx>
#include <gp_Lin.hxx>
#include <gp_Pnt.hxx>
#include <gp_Dir.hxx>
#include <Precision.hxx>
#include <IntCurvesFace_Intersector.hxx>
#include <ElCLib.hxx>
#include <BRepFeat_MakeDPrism.hxx>
#include <BRepTools.hxx>
#include <TopoDS.hxx>
//#include <SaveShape.hxx>
#include <gp_Ax1.hxx>
#include <TColgp_SequenceOfPnt.hxx>
#include <LocOpe_CSIntersector.hxx>
#include <LocOpe_SequenceOfLin.hxx>
#include <TopAbs_Orientation.hxx>
#include <LocOpe_PntFace.hxx>
static void SampleEdges (const TopoDS_Shape& theShape, TColgp_SequenceOfPnt& theSeq);
static TopoDS_Face NextFaceForPrism (const TopoDS_Shape& shape,
const TopoDS_Shape& basis,
const gp_Ax1& ax1);
//=======================================================================
// intgo
//function : MakeBoss
//purpose :
//=======================================================================
static Standard_Integer MakeBoss(Draw_Interpretor& , Standard_Integer , const char** a)
Standard_Integer MakeBoss(Draw_Interpretor& , Standard_Integer , const char** a)
{
TopoDS_Shape myS = DBRep::Get( a[2] );
TopoDS_Shape myBasis = DBRep::Get( a[3] ) ;
@ -306,18 +355,11 @@ static Standard_Integer MakeBoss(Draw_Interpretor& , Standard_Integer , const ch
return 0;
}
#include <BRepOffset_MakeOffset.hxx>
#include <BRepOffset.hxx>
//#include <SaveShape.hxx>
#include <TopTools_ListOfShape.hxx>
#include <TopTools_ListIteratorOfListOfShape.hxx>
#include <GeomAbs_JoinType.hxx>
//=======================================================================
// Create a shell
//function : MakeShell
//purpose :
//=======================================================================
static Standard_Integer MakeShell(Draw_Interpretor& , Standard_Integer , const char** a)
Standard_Integer MakeShell(Draw_Interpretor& , Standard_Integer , const char** a)
{
TopoDS_Shape aShape = DBRep::Get( a[1] );
@ -342,7 +384,6 @@ static Standard_Integer MakeShell(Draw_Interpretor& , Standard_Integer , const c
}
return 0;
}
//=======================================================================
//function : xbounds
//purpose :
@ -387,51 +428,76 @@ Standard_Integer xbounds(Draw_Interpretor& di, Standard_Integer n, const char**
//
return 0;
}
//=======================================================================
//function : OtherCommands
//function : xclassify
//purpose :
//=======================================================================
void BRepTest::OtherCommands(Draw_Interpretor& theCommands)
Standard_Integer xclassify (Draw_Interpretor& aDI, Standard_Integer n, const char** a)
{
static Standard_Boolean done = Standard_False;
if (done) return;
done = Standard_True;
const char* g = "TOPOLOGY other commands";
theCommands.Add("shape",
"shape name V/E/W/F/Sh/So/CS/C; make a empty shape",__FILE__,emptyshape,g);
theCommands.Add("subshape",
"subshape name V/E/W/F/Sh/So/CS/C index; get subsshape <index> of given type"
,__FILE__,subshape,g);
theCommands.Add("BRepIntCS",
"Calcul d'intersection entre face et curve : BRepIntCS curve shape"
,__FILE__,brepintcs,g);
theCommands.Add("makeboss",
"create a boss on the shape myS", __FILE__, MakeBoss, g);
theCommands.Add("mksh",
"create a shell on Shape", __FILE__, MakeShell, g);
theCommands.Add("xbounds",
"xbounds face", __FILE__, xbounds, g);
char sbf[512];
if (n < 2) {
aDI<<" use xclassify Solid [Tolerance=1.e-7]\n";
return 1;
}
TopoDS_Shape aS = DBRep::Get(a[1]);
if (aS.IsNull()) {
aDI<<" Null Shape is not allowed here\n";
return 0;
}
if (aS.ShapeType()!=TopAbs_SOLID) {
aDI<< " Shape type must be SOLID\n";
return 0;
}
//
Standard_Real aTol=1.e-7;
TopAbs_State aState = TopAbs_UNKNOWN;
//
aTol=1.e-7;
if (n==3) {
aTol=atof(a[2]);
}
//
BRepClass3d_SolidClassifier aSC(aS);
aSC.PerformInfinitePoint(aTol);
aState = aSC.State();
PrintState(aDI, aState);
//
return 0;
}
//=======================================================================
//function : PrintState
//purpose :
//=======================================================================
void PrintState (Draw_Interpretor& aDI,
const TopAbs_State& aState)
{
aDI<<"state is: ";
switch (aState) {
case TopAbs_IN:
aDI<<"IN\n";
break;
case TopAbs_OUT:
aDI<<"OUT\n";
break;
case TopAbs_ON:
aDI<<"ON\n";
break;
case TopAbs_UNKNOWN:
default:
aDI<<"UNKNOWN\n";
break;
}
}
//=======================================================================
//function : NextFaceForPrism
//purpose : Search a face from <shape> which intersects with a line of
// direction <ax1> and location a point of <basis>.
//=======================================================================
static TopoDS_Face NextFaceForPrism (const TopoDS_Shape& shape,
TopoDS_Face NextFaceForPrism (const TopoDS_Shape& shape,
const TopoDS_Shape& basis,
const gp_Ax1& ax1)
{
@ -465,14 +531,13 @@ static TopoDS_Face NextFaceForPrism (const TopoDS_Shape& shape,
return nextFace;
}
#include <BRep_Tool.hxx>
//=======================================================================
//function : SampleEdges
//purpose : Sampling of <theShape>.
//design : Collect the vertices and points on the edges
//=======================================================================
static void SampleEdges (const TopoDS_Shape& theShape, TColgp_SequenceOfPnt& theSeq)
void SampleEdges (const TopoDS_Shape& theShape, TColgp_SequenceOfPnt& theSeq)
{
theSeq.Clear();

View File

@ -25,7 +25,7 @@
#define TOLTANGENCY 0.00000001
#define TOLERANCE_ANGULAIRE 0.00000001
#define TOLERANCE_ANGULAIRE 1.e-12//0.00000001
#define TOLERANCE 0.00000001
#define NBSAMPLESONCIRCLE 32