From 14cda02f8205d7bafb81760eeb7b8c8c84ffee8f Mon Sep 17 00:00:00 2001 From: vpa Date: Wed, 13 May 2015 12:30:38 +0300 Subject: [PATCH] 0026217: Visualization, Select3D_SensitiveCircle - fix compilation with CLang for iOS Inclusion detection for filled sensitive circles was corrected --- src/Select3D/Select3D_SensitiveCircle.cxx | 6 ++-- src/ViewerTest/ViewerTest_ObjectCommands.cxx | 2 +- tests/bugs/vis/bug26217 | 33 ++++++++++++++++++++ 3 files changed, 38 insertions(+), 3 deletions(-) create mode 100644 tests/bugs/vis/bug26217 diff --git a/src/Select3D/Select3D_SensitiveCircle.cxx b/src/Select3D/Select3D_SensitiveCircle.cxx index 3f8eaa23a5..bd5c9fd687 100644 --- a/src/Select3D/Select3D_SensitiveCircle.cxx +++ b/src/Select3D/Select3D_SensitiveCircle.cxx @@ -256,9 +256,11 @@ Standard_Boolean Select3D_SensitiveCircle::Matches (SelectBasics_SelectingVolume if (!theMgr.IsOverlapAllowed()) { thePickResult = SelectBasics_PickResult (aDepth, aDistToCOG); - if (!theMgr.Overlaps (myBndBox.CornerMin(), myBndBox.CornerMax(), Standard_False)) + for (Standard_Integer aPntIdx = anArrayOfPnt->Lower(); aPntIdx <= anArrayOfPnt->Upper(); ++aPntIdx) { - return Standard_False; + Standard_Real aDummy; + if (!theMgr.Overlaps (anArrayOfPnt->Value (aPntIdx), aDummy)) + return Standard_False; } return Standard_True; } diff --git a/src/ViewerTest/ViewerTest_ObjectCommands.cxx b/src/ViewerTest/ViewerTest_ObjectCommands.cxx index 0c59eeec6b..c28f0d22f4 100644 --- a/src/ViewerTest/ViewerTest_ObjectCommands.cxx +++ b/src/ViewerTest/ViewerTest_ObjectCommands.cxx @@ -4337,7 +4337,7 @@ class Triangle: public AIS_InteractiveObject { public: // CASCADE RTTI - DEFINE_STANDARD_RTTI(FilledCircle); + DEFINE_STANDARD_RTTI(Triangle); Triangle (const gp_Pnt& theP1, const gp_Pnt& theP2, const gp_Pnt& theP3); diff --git a/tests/bugs/vis/bug26217 b/tests/bugs/vis/bug26217 new file mode 100644 index 0000000000..5fb9e00803 --- /dev/null +++ b/tests/bugs/vis/bug26217 @@ -0,0 +1,33 @@ +puts "============" +puts "CR26217" +puts "============" +puts "" + +########################################################################################## +puts "Visualization, Select3D_SensitiveCircle - fix compilation with CLang for iOS" +########################################################################################## + +pload VISUALIZATION + +vinit View1 +vpoint radP1 0 0 0 +vpoint radP2 50 50 0 +vpoint radP3 100 0 0 +vcircle circle radP1 radP2 radP3 1 +vfit + +vselect 40 120 185 320 +set aColor [vreadpixel 120 200 rgb name] +if {$aColor != "DARKGOLDENROD3"} { + puts "ERROR: the circle is selected with no overlap mode activated" +} + +vselect 0 0 + +vselect 40 120 185 320 -allowoverlap 1 +set aColor [vreadpixel 120 200 rgb name] +if {$aColor != "GRAY80"} { + puts "ERROR: the circle is not selected with overlap mode activated" +} + +vdump ${imagedir}/${casename}.png