From fad3eca77fba62eb0afbbec039aa01fb3dc60366 Mon Sep 17 00:00:00 2001 From: kgv Date: Thu, 24 May 2018 20:10:32 +0300 Subject: [PATCH] 0029791: Visualization - Wrong result of SelectMgr_RectangularFrustum::IsClipped SelectMgr_RectangularFrustum::computeClippingRange() fix skipping depth range starting behind the ray. --- .../SelectMgr_RectangularFrustum.cxx | 13 +++++------- tests/bugs/vis/bug29791 | 21 +++++++++++++++++++ 2 files changed, 26 insertions(+), 8 deletions(-) create mode 100644 tests/bugs/vis/bug29791 diff --git a/src/SelectMgr/SelectMgr_RectangularFrustum.cxx b/src/SelectMgr/SelectMgr_RectangularFrustum.cxx index 82bb7b0607..d191a41efc 100644 --- a/src/SelectMgr/SelectMgr_RectangularFrustum.cxx +++ b/src/SelectMgr/SelectMgr_RectangularFrustum.cxx @@ -675,18 +675,15 @@ void SelectMgr_RectangularFrustum::computeClippingRange (const Graphic3d_Sequenc } // compute distance to point of pick line intersection with the plane - Standard_Real aParam = aDistance / aDotProduct; - - // check if ray intersects the plane, in case aIntDist < 0 - // the plane is "behind" the ray + const Standard_Real aParam = aDistance / aDotProduct; + const gp_Pnt anIntersectionPt = myNearPickedPnt.XYZ() + myViewRayDir.XYZ() * aParam; + Standard_Real aDistToPln = anIntersectionPt.Distance (myNearPickedPnt); if (aParam < 0.0) { - continue; + // the plane is "behind" the ray + aDistToPln = -aDistToPln; } - const gp_Pnt anIntersectionPt = myNearPickedPnt.XYZ() + myViewRayDir.XYZ() * aParam; - const Standard_Real aDistToPln = anIntersectionPt.Distance (myNearPickedPnt); - // change depth limits for case of opposite and directed planes if (aDotProduct < 0.0) { diff --git a/tests/bugs/vis/bug29791 b/tests/bugs/vis/bug29791 new file mode 100644 index 0000000000..64190c1951 --- /dev/null +++ b/tests/bugs/vis/bug29791 @@ -0,0 +1,21 @@ +puts "============" +puts "0029791: Visualization - Wrong result of SelectMgr_RectangularFrustum::IsClipped" +puts "============" +puts "" + +pload MODELING VISUALIZATION +restore [locate_data_file occ/bottle.brep] b +vclear +vinit View1 +vdisplay -dispMode 1 -highMode 1 b +vfit +vzbufftrihedron +vviewparams -scale 14.7435 -proj 0.193921 -0.891229 0.410007 -up -0.0205984 0.414149 0.909976 -at 11.3689 1.32152 24.9954 +vclipplane p -equation 1 0 0 -20 -set +vmoveto 150 200 +vstate -entities +vselect 150 200 +if { [vreadpixel 150 200 rgb name] != "BLACK" } { puts "Error: object is not clipped" } +if { [vreadpixel 300 200 rgb name] != "GOLDENROD1" } { puts "Error: object should NOT be selected" } + +vdump $imagedir/${casename}.png