mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-04 18:06:22 +03:00
0027959: BRepMesh_Delaun produces mesh with gaps on internal edges
Check both sides of internal link for adjusted triangle and process left and right polygons separately Small correction of test case for issue CR27959
This commit is contained in:
parent
caf231b050
commit
df18769ea6
@ -508,25 +508,56 @@ void BRepMesh_Delaun::createTrianglesOnNewVertices(
|
||||
createTriangles( aVertexIdx, aLoopEdges );
|
||||
}
|
||||
}
|
||||
// Check that internal edges are not crossed by triangles
|
||||
|
||||
insertInternalEdges();
|
||||
|
||||
// Adjustment of meshes to boundary edges
|
||||
frontierAdjust();
|
||||
}
|
||||
|
||||
//=======================================================================
|
||||
//function : insertInternalEdges
|
||||
//purpose :
|
||||
//=======================================================================
|
||||
void BRepMesh_Delaun::insertInternalEdges()
|
||||
{
|
||||
BRepMesh::HMapOfInteger anInternalEdges = InternalEdges();
|
||||
|
||||
// Destruction of triancles intersecting internal edges
|
||||
// and their replacement by makeshift triangles
|
||||
Standard_Integer e[3];
|
||||
Standard_Boolean o[3];
|
||||
BRepMesh::MapOfInteger::Iterator anInernalEdgesIt( *anInternalEdges );
|
||||
for ( ; anInernalEdgesIt.More(); anInernalEdgesIt.Next() )
|
||||
{
|
||||
Standard_Integer aNbC;
|
||||
aNbC = myMeshData->ElementsConnectedTo( anInernalEdgesIt.Key() ).Extent();
|
||||
if ( aNbC == 0 )
|
||||
const Standard_Integer aLinkIndex = anInernalEdgesIt.Key();
|
||||
const BRepMesh_PairOfIndex& aPair = myMeshData->ElementsConnectedTo(aLinkIndex);
|
||||
|
||||
// Check both sides of link for adjusted triangle.
|
||||
Standard_Boolean isGo[2] = { Standard_True, Standard_True };
|
||||
for (Standard_Integer aTriangleIt = 1; aTriangleIt <= aPair.Extent(); ++aTriangleIt)
|
||||
{
|
||||
meshLeftPolygonOf( anInernalEdgesIt.Key(), Standard_True );
|
||||
meshLeftPolygonOf( anInernalEdgesIt.Key(), Standard_False );
|
||||
GetTriangle(aPair.Index(aTriangleIt)).Edges(e, o);
|
||||
for (Standard_Integer i = 0; i < 3; ++i)
|
||||
{
|
||||
if (e[i] == aLinkIndex)
|
||||
{
|
||||
isGo[o[i] ? 0 : 1] = Standard_False;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (isGo[0])
|
||||
{
|
||||
meshLeftPolygonOf(aLinkIndex, Standard_True);
|
||||
}
|
||||
|
||||
if (isGo[1])
|
||||
{
|
||||
meshLeftPolygonOf(aLinkIndex, Standard_False);
|
||||
}
|
||||
}
|
||||
|
||||
// Adjustment of meshes to boundary edges
|
||||
frontierAdjust();
|
||||
}
|
||||
|
||||
//=======================================================================
|
||||
|
@ -320,6 +320,9 @@ private:
|
||||
const Standard_Integer theStartIndex,
|
||||
const Standard_Integer theEndIndex) const;
|
||||
|
||||
//! Performs insertion of internal edges into mesh.
|
||||
void insertInternalEdges();
|
||||
|
||||
private:
|
||||
|
||||
Handle(BRepMesh_DataStructureOfDelaun) myMeshData;
|
||||
|
21
tests/bugs/mesh/bug27959
Normal file
21
tests/bugs/mesh/bug27959
Normal file
@ -0,0 +1,21 @@
|
||||
puts "=========="
|
||||
puts "OCC27959"
|
||||
puts "=========="
|
||||
puts ""
|
||||
#######################################################################
|
||||
# BRepMesh_Delaun produces mesh with gaps on internal edges
|
||||
#######################################################################
|
||||
# test for #27959: check that resulting mesh does not contain gaps.
|
||||
|
||||
restore [locate_data_file bug27959_ms.brep] result
|
||||
|
||||
tclean result
|
||||
checkview -display result -3d -path ${imagedir}/${test_image}.png
|
||||
|
||||
set log [tricheck result]
|
||||
if { [llength $log] != 0 } {
|
||||
puts "Error : Mesh contains gaps"
|
||||
} else {
|
||||
puts "OK : Mesh produced without gaps"
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user