From 60e5b8994e356d0a497384d18d0bee4c413cf656 Mon Sep 17 00:00:00 2001 From: mzernova Date: Mon, 3 Mar 2025 13:44:30 +0000 Subject: [PATCH] Revert "0028500: Artifact in shaded view of the shape" This reverts commit f73592edf0ad5231c84e5332c8c47f54ed178780. --- src/BRepMesh/BRepMesh_CurveTessellator.cxx | 17 ++++++----------- src/BRepMesh/BRepMesh_CurveTessellator.hxx | 7 ++----- src/BRepMesh/BRepMesh_EdgeDiscret.cxx | 12 +++++------- src/BRepMesh/BRepMesh_EdgeDiscret.hxx | 6 ++---- src/BRepMesh/BRepMesh_ModelHealer.cxx | 20 +------------------- tests/bugs/mesh/bug25044_12 | 3 +++ tests/bugs/mesh/bug25044_13 | 3 +++ tests/bugs/mesh/bug25044_60 | 3 --- tests/bugs/mesh/bug28500 | 18 ++++++++++-------- tests/bugs/mesh/bug32692_1 | 2 +- tests/hlr/poly_hlr/bug23625_1 | 10 +++++++++- 11 files changed, 42 insertions(+), 59 deletions(-) diff --git a/src/BRepMesh/BRepMesh_CurveTessellator.cxx b/src/BRepMesh/BRepMesh_CurveTessellator.cxx index c8e942ec3a..1d293f0204 100644 --- a/src/BRepMesh/BRepMesh_CurveTessellator.cxx +++ b/src/BRepMesh/BRepMesh_CurveTessellator.cxx @@ -35,13 +35,11 @@ IMPLEMENT_STANDARD_RTTIEXT(BRepMesh_CurveTessellator, IMeshTools_CurveTessellato //======================================================================= BRepMesh_CurveTessellator::BRepMesh_CurveTessellator( const IMeshData::IEdgeHandle& theEdge, - const IMeshTools_Parameters& theParameters, - const Standard_Integer theMinPointsNb) + const IMeshTools_Parameters& theParameters) : myDEdge(theEdge), myParameters(theParameters), myEdge(theEdge->GetEdge()), - myCurve(myEdge), - myMinPointsNb (theMinPointsNb) + myCurve(myEdge) { init(); } @@ -54,13 +52,11 @@ BRepMesh_CurveTessellator::BRepMesh_CurveTessellator ( const IMeshData::IEdgeHandle& theEdge, const TopAbs_Orientation theOrientation, const IMeshData::IFaceHandle& theFace, - const IMeshTools_Parameters& theParameters, - const Standard_Integer theMinPointsNb) + const IMeshTools_Parameters& theParameters) : myDEdge(theEdge), myParameters(theParameters), myEdge(TopoDS::Edge(theEdge->GetEdge().Oriented(theOrientation))), - myCurve(myEdge, theFace->GetFace()), - myMinPointsNb (theMinPointsNb) + myCurve(myEdge, theFace->GetFace()) { init(); } @@ -101,21 +97,20 @@ void BRepMesh_CurveTessellator::init() myEdgeSqTol = BRep_Tool::Tolerance (myEdge); myEdgeSqTol *= myEdgeSqTol; - Standard_Integer aMinPntThreshold = 2; + Standard_Integer aMinPntNb = 2; switch (myCurve.GetType()) { case GeomAbs_Circle: case GeomAbs_Ellipse: case GeomAbs_Parabola: case GeomAbs_Hyperbola: - aMinPntThreshold = 4; + aMinPntNb = 4; break; default: break; } - const Standard_Integer aMinPntNb = Max (myMinPointsNb, aMinPntThreshold); //OCC287 myDiscretTool.Initialize (myCurve, myCurve.FirstParameter(), myCurve.LastParameter(), aPreciseAngDef, aPreciseLinDef, aMinPntNb, diff --git a/src/BRepMesh/BRepMesh_CurveTessellator.hxx b/src/BRepMesh/BRepMesh_CurveTessellator.hxx index d9406a8423..ddf3bcfa52 100644 --- a/src/BRepMesh/BRepMesh_CurveTessellator.hxx +++ b/src/BRepMesh/BRepMesh_CurveTessellator.hxx @@ -34,16 +34,14 @@ public: //! Constructor. Standard_EXPORT BRepMesh_CurveTessellator( const IMeshData::IEdgeHandle& theEdge, - const IMeshTools_Parameters& theParameters, - const Standard_Integer theMinPointsNb = 2); + const IMeshTools_Parameters& theParameters); //! Constructor. Standard_EXPORT BRepMesh_CurveTessellator ( const IMeshData::IEdgeHandle& theEdge, const TopAbs_Orientation theOrientation, const IMeshData::IFaceHandle& theFace, - const IMeshTools_Parameters& theParameters, - const Standard_Integer theMinPointsNb = 2); + const IMeshTools_Parameters& theParameters); //! Destructor. Standard_EXPORT virtual ~BRepMesh_CurveTessellator (); @@ -98,7 +96,6 @@ private: const IMeshTools_Parameters& myParameters; TopoDS_Edge myEdge; BRepAdaptor_Curve myCurve; - Standard_Integer myMinPointsNb; GCPnts_TangentialDeflection myDiscretTool; TopoDS_Vertex myFirstVertex; TopoDS_Vertex myLastVertex; diff --git a/src/BRepMesh/BRepMesh_EdgeDiscret.cxx b/src/BRepMesh/BRepMesh_EdgeDiscret.cxx index 31c7963c59..a68165a291 100644 --- a/src/BRepMesh/BRepMesh_EdgeDiscret.cxx +++ b/src/BRepMesh/BRepMesh_EdgeDiscret.cxx @@ -49,10 +49,9 @@ BRepMesh_EdgeDiscret::~BRepMesh_EdgeDiscret () //======================================================================= Handle(IMeshTools_CurveTessellator) BRepMesh_EdgeDiscret::CreateEdgeTessellator( const IMeshData::IEdgeHandle& theDEdge, - const IMeshTools_Parameters& theParameters, - const Standard_Integer theMinPointsNb) + const IMeshTools_Parameters& theParameters) { - return new BRepMesh_CurveTessellator(theDEdge, theParameters, theMinPointsNb); + return new BRepMesh_CurveTessellator(theDEdge, theParameters); } //======================================================================= @@ -63,12 +62,11 @@ Handle(IMeshTools_CurveTessellator) BRepMesh_EdgeDiscret::CreateEdgeTessellator( const IMeshData::IEdgeHandle& theDEdge, const TopAbs_Orientation theOrientation, const IMeshData::IFaceHandle& theDFace, - const IMeshTools_Parameters& theParameters, - const Standard_Integer theMinPointsNb) + const IMeshTools_Parameters& theParameters) { return theDEdge->GetSameParam() ? - new BRepMesh_CurveTessellator(theDEdge, theParameters, theMinPointsNb) : - new BRepMesh_CurveTessellator(theDEdge, theOrientation, theDFace, theParameters, theMinPointsNb); + new BRepMesh_CurveTessellator(theDEdge, theParameters) : + new BRepMesh_CurveTessellator(theDEdge, theOrientation, theDFace, theParameters); } //======================================================================= diff --git a/src/BRepMesh/BRepMesh_EdgeDiscret.hxx b/src/BRepMesh/BRepMesh_EdgeDiscret.hxx index 89b67eda39..c8db5ec342 100644 --- a/src/BRepMesh/BRepMesh_EdgeDiscret.hxx +++ b/src/BRepMesh/BRepMesh_EdgeDiscret.hxx @@ -38,16 +38,14 @@ public: //! Creates instance of free edge tessellator. Standard_EXPORT static Handle(IMeshTools_CurveTessellator) CreateEdgeTessellator( const IMeshData::IEdgeHandle& theDEdge, - const IMeshTools_Parameters& theParameters, - const Standard_Integer theMinPointsNb = 2); + const IMeshTools_Parameters& theParameters); //! Creates instance of edge tessellator. Standard_EXPORT static Handle(IMeshTools_CurveTessellator) CreateEdgeTessellator( const IMeshData::IEdgeHandle& theDEdge, const TopAbs_Orientation theOrientation, const IMeshData::IFaceHandle& theDFace, - const IMeshTools_Parameters& theParameters, - const Standard_Integer theMinPointsNb = 2); + const IMeshTools_Parameters& theParameters); //! Creates instance of tessellation extractor. Standard_EXPORT static Handle(IMeshTools_CurveTessellator) CreateEdgeTessellationExtractor( diff --git a/src/BRepMesh/BRepMesh_ModelHealer.cxx b/src/BRepMesh/BRepMesh_ModelHealer.cxx index 4c2eed209a..def938d41a 100644 --- a/src/BRepMesh/BRepMesh_ModelHealer.cxx +++ b/src/BRepMesh/BRepMesh_ModelHealer.cxx @@ -50,32 +50,14 @@ namespace void operator()(const IMeshData::IEdgePtr& theDEdge) const { const IMeshData::IEdgeHandle aDEdge = theDEdge; - - Standard_Integer aPointsNb = aDEdge->GetCurve()->ParametersNb(); - aDEdge->Clear(Standard_True); aDEdge->SetDeflection(Max(aDEdge->GetDeflection() / 3., Precision::Confusion())); - for (Standard_Integer aPCurveIt = 0; aPCurveIt < aDEdge->PCurvesNb(); ++aPCurveIt) - { - const IMeshData::IPCurveHandle& aPCurve = aDEdge->GetPCurve(aPCurveIt); - const IMeshData::IFaceHandle aDFace = aPCurve->GetFace(); - - // Check that outer wire contains 2 edges or less and add an additional point. - const IMeshData::IWireHandle& aDWire = aDFace->GetWire(0); - if (aDWire->EdgesNb() <= 2) - { - ++aPointsNb; - break; - } - } - const IMeshData::IPCurveHandle& aPCurve = aDEdge->GetPCurve(0); const IMeshData::IFaceHandle aDFace = aPCurve->GetFace(); Handle(IMeshTools_CurveTessellator) aTessellator = BRepMesh_EdgeDiscret::CreateEdgeTessellator( - aDEdge, aPCurve->GetOrientation(), aDFace, - myParameters, aPointsNb); + aDEdge, aPCurve->GetOrientation(), aDFace, myParameters); BRepMesh_EdgeDiscret::Tessellate3d(aDEdge, aTessellator, Standard_False); BRepMesh_EdgeDiscret::Tessellate2d(aDEdge, Standard_False); diff --git a/tests/bugs/mesh/bug25044_12 b/tests/bugs/mesh/bug25044_12 index 31d1c179ad..1ddf82927d 100644 --- a/tests/bugs/mesh/bug25044_12 +++ b/tests/bugs/mesh/bug25044_12 @@ -1,3 +1,6 @@ +puts "TODO 25044 ALL: SelfIntersectingWire" +puts "TODO 25044 ALL: Number of triangles is equal to 0" + puts "=======" puts "0025044: BRepMesh tweaks" puts "=======" diff --git a/tests/bugs/mesh/bug25044_13 b/tests/bugs/mesh/bug25044_13 index 12b8348b95..f02bc31f58 100644 --- a/tests/bugs/mesh/bug25044_13 +++ b/tests/bugs/mesh/bug25044_13 @@ -1,3 +1,6 @@ +puts "TODO 25044 ALL: SelfIntersectingWire" +puts "TODO 25044 ALL: Number of triangles is equal to 0" + puts "=======" puts "0025044: BRepMesh tweaks" puts "=======" diff --git a/tests/bugs/mesh/bug25044_60 b/tests/bugs/mesh/bug25044_60 index 6c89250587..78ae386109 100644 --- a/tests/bugs/mesh/bug25044_60 +++ b/tests/bugs/mesh/bug25044_60 @@ -3,9 +3,6 @@ puts "0025588: BRepMesh_ShapeTool::FindUV check for 2d points to be the same is puts "=======" puts "" -puts "TODO OCC25588 All: Not connected mesh inside face 893" -puts "TODO OCC25588 All: Not connected mesh inside face 1094" - pload XDE stepread [locate_data_file Median_cx-fs01_bicycle.stp] a * diff --git a/tests/bugs/mesh/bug28500 b/tests/bugs/mesh/bug28500 index 56e1699978..3bab0b6875 100644 --- a/tests/bugs/mesh/bug28500 +++ b/tests/bugs/mesh/bug28500 @@ -3,20 +3,22 @@ puts "CR28500: Artifact in shaded view of the shape" puts "=======" puts "" -restore [locate_data_file bug28500_shape_mesh_artifact.brep] result +puts "TODO CR28500 ALL: Artifact in shaded view of the shape" +puts "TODO CR30056 ALL: Meshing statuses: SelfIntersectingWire Failure Reused" -tclean result -incmesh result 0.01 +restore [locate_data_file bug28500_shape_mesh_artifact.brep] a + +incmesh a 0.01 vinit vsetdispmode 1 -vdefaults -autoTriang 0 -vdisplay result +vdisplay a vfit -set log [tricheck result] -if { [llength $log] != 0 } { - puts "Error : Mesh contains faulties" +set x 150 +set y 150 +if { [checkcolor $x $y 0 1 0] == 1 } { + puts "Error: Artifact in shaded view of the shape" } checkview -screenshot -3d -path ${imagedir}/${test_image}.png diff --git a/tests/bugs/mesh/bug32692_1 b/tests/bugs/mesh/bug32692_1 index 1712b35ab1..5a85bff3db 100644 --- a/tests/bugs/mesh/bug32692_1 +++ b/tests/bugs/mesh/bug32692_1 @@ -8,4 +8,4 @@ puts "REQUIRED ALL: Meshing statuses: SelfIntersectingWire Failure" restore [locate_data_file bug32692.brep] s incmesh s 0.01 -parallel -checktrinfo s -nod 7389 -tri 7419 -empty 9 -face 309 +checktrinfo s -nod 7427 -tri 7457 -empty 9 -face 309 diff --git a/tests/hlr/poly_hlr/bug23625_1 b/tests/hlr/poly_hlr/bug23625_1 index ed7a28c97a..598634bec4 100644 --- a/tests/hlr/poly_hlr/bug23625_1 +++ b/tests/hlr/poly_hlr/bug23625_1 @@ -3,8 +3,16 @@ puts "OCC23625" puts "============" puts "" +puts "REQUIRED All: Meshing statuses: SelfIntersectingWire Failure" + set viewname "vfront" -set length 26411.2 +set length 26411.7 restore [locate_data_file bug23625_a1.brep] a + +# workaround bug 0031426 until fix +vinit View1 +vdefaults -autoTriang 0 +incmesh a 7.6 + COMPUTE_HLR $viewname $algotype