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_Delaun::decomposeSimplePolygon(): minor change to improve code readability;
Correct test case
This commit is contained in:
Dzmitry Razmyslovich 2021-05-26 17:03:42 +03:00 committed by bugmaster
parent 3326f9238c
commit 793d165af6
8 changed files with 38 additions and 21 deletions

View File

@ -994,7 +994,6 @@ Standard_Boolean BRepMesh_Delaun::meshLeftPolygonOf(
aPivotNode = aRefEdge.FirstNode();
}
const BRepMesh_Vertex& aStartEdgeVertexS = GetVertex( aStartNode );
BRepMesh_Vertex aPivotVertex = GetVertex( aPivotNode );
@ -1914,7 +1913,7 @@ void BRepMesh_Delaun::meshPolygon(IMeshData::SequenceOfInteger& thePolygon,
}
if (aPolyStack.IsEmpty())
return;
break;
aPolygon1 = &(*aPolyStack.ChangeFirst());
aPolyBoxes1 = &(*aPolyBoxStack.ChangeFirst());
@ -2019,6 +2018,10 @@ void BRepMesh_Delaun::decomposeSimplePolygon(
aNextEdge.FirstNode() :
aNextEdge.LastNode();
// We have end points touch case in the polygon - ignore it
if (aPivotNode == aNodes[1])
continue;
gp_Pnt2d aPivotVertex = GetVertex( aPivotNode ).Coord();
gp_Vec2d aDistanceDir( aRefVertices[1], aPivotVertex );
@ -2105,7 +2108,6 @@ void BRepMesh_Delaun::decomposeSimplePolygon(
myMeshData->AddLink( aNewEdges[0] ),
myMeshData->AddLink( aNewEdges[1] ) };
Standard_Integer anEdges[3];
Standard_Boolean anEdgesOri[3];
for ( Standard_Integer aTriEdgeIt = 0; aTriEdgeIt < 3; ++aTriEdgeIt )
@ -2116,27 +2118,38 @@ void BRepMesh_Delaun::decomposeSimplePolygon(
}
addTriangle( anEdges, anEdgesOri, aNodes );
// Create triangle and split the source polygon on two
// parts (if possible) and mesh each part as independent
// polygon.
if ( aUsedLinkId < aPolyLen )
if (aUsedLinkId == 3)
{
thePolygon.Split(aUsedLinkId, thePolygonCut);
thePolygonCut.Prepend( -aNewEdgesInfo[2] );
thePolyBoxes.Split(aUsedLinkId, thePolyBoxesCut);
thePolygon.Remove ( 1 );
thePolyBoxes.Remove( 1 );
thePolygon.SetValue( 1, -aNewEdgesInfo[2] );
Bnd_B2d aBox;
UpdateBndBox(aRefVertices[0].Coord(), aRefVertices[2].Coord(), aBox);
thePolyBoxesCut.Prepend( aBox );
thePolyBoxes.SetValue( 1, aBox );
}
else
{
thePolygon.Remove ( aPolyLen );
thePolyBoxes.Remove( aPolyLen );
}
// Create triangle and split the source polygon on two
// parts (if possible) and mesh each part as independent
// polygon.
if ( aUsedLinkId < aPolyLen )
{
thePolygon.Split(aUsedLinkId, thePolygonCut);
thePolygonCut.Prepend( -aNewEdgesInfo[2] );
thePolyBoxes.Split(aUsedLinkId, thePolyBoxesCut);
Bnd_B2d aBox;
UpdateBndBox(aRefVertices[0].Coord(), aRefVertices[2].Coord(), aBox);
thePolyBoxesCut.Prepend( aBox );
}
else
{
thePolygon.Remove ( aPolyLen );
thePolyBoxes.Remove( aPolyLen );
}
if ( aUsedLinkId > 3 )
{
thePolygon.SetValue( 1, -aNewEdgesInfo[1] );
Bnd_B2d aBox;

View File

@ -19,5 +19,5 @@ isos result 0
triangles result
fit
checktrinfo result -tri 10924 -nod 7869
checktrinfo result -tri 10917 -nod 7869
checkview -screenshot -2d -path ${imagedir}/${test_image}_axo.png

View File

@ -1,3 +1,5 @@
puts "TODO OCC30286 ALL: Error : The length of result shape is 1664.\\d+, expected 1664.48"
set viewname "vright"
set length 1664.48

View File

@ -1,3 +1,5 @@
puts "TODO OCC30286 ALL: Error : The length of result shape is 1723.\\d+, expected 1721.69"
set viewname "vright"
set length 1721.69

View File

@ -1,4 +1,4 @@
puts "TODO OCC30286 ALL: Error : The length of result shape is 3.53405, expected 3."
puts "TODO OCC30286 ALL: Error : The length of result shape is 3.\\d+, expected 3."
puts "========================================================================"
puts "OCC27979: Parasolid converted BREP shows weird lines on hidden line Algo"

View File

@ -1,4 +1,4 @@
puts "TODO OCC30286 ALL: Error : The length of result shape is 12.4883, expected 12."
puts "TODO OCC30286 ALL: Error : The length of result shape is 12.\\d+, expected 12."
puts "========================================================================"
puts "OCC27979: Parasolid converted BREP shows weird lines on hidden line Algo"

View File

@ -1,4 +1,4 @@
puts "TODO OCC30286 ALL: Error : The length of result shape is 11.4458, expected 11."
puts "TODO OCC30286 ALL: Error : The length of result shape is 11.\\d+, expected 11."
puts "========================================================================"
puts "OCC27979: Parasolid converted BREP shows weird lines on hidden line Algo"

View File

@ -1,4 +1,4 @@
puts "TODO OCC30286 ALL: Error : The length of result shape is 11.2065, expected 11."
puts "TODO OCC30286 ALL: Error : The length of result shape is 11.\\d+, expected 11."
puts "========================================================================"
puts "OCC27979: Parasolid converted BREP shows weird lines on hidden line Algo"