1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-03 17:56:21 +03:00

0032261: Mesh - some trivial improvements for mesher

BRepMesh_GeomTool::IntSegSeg misses one case, when the result is Glued
This commit is contained in:
Dzmitry Razmyslovich 2021-03-29 13:54:42 +02:00 committed by bugmaster
parent 0038de11f4
commit ccb3502a56

View File

@ -342,18 +342,26 @@ BRepMesh_GeomTool::IntFlag BRepMesh_GeomTool::IntSegSeg(
classifyPoint(theStartPnt2, theEndPnt2, theEndPnt1 )
};
Standard_Integer aPosHash =
aPointHash[0] + aPointHash[1] + aPointHash[2] + aPointHash[3];
// Consider case when edges have shared vertex
if ( aPointHash[0] < 0 || aPointHash[1] < 0 )
{
if ( isConsiderEndPointTouch )
return BRepMesh_GeomTool::EndPointTouch;
if (aPosHash == -1)
{
// -1 means, that 2 points are equal, and 1 point is on another curve
return BRepMesh_GeomTool::Glued;
}
else
{
if (isConsiderEndPointTouch)
return BRepMesh_GeomTool::EndPointTouch;
return BRepMesh_GeomTool::NoIntersection;
return BRepMesh_GeomTool::NoIntersection;
}
}
Standard_Integer aPosHash =
aPointHash[0] + aPointHash[1] + aPointHash[2] + aPointHash[3];
/*=========================================*/
/* 1) hash code == 1: