diff --git a/src/SelectMgr/SelectMgr_SelectionManager.cxx b/src/SelectMgr/SelectMgr_SelectionManager.cxx index b8cb33e2fa..195ed54c75 100644 --- a/src/SelectMgr/SelectMgr_SelectionManager.cxx +++ b/src/SelectMgr/SelectMgr_SelectionManager.cxx @@ -90,6 +90,7 @@ void SelectMgr_SelectionManager::Remove (const Handle(SelectMgr_SelectableObject { mySelector->RemoveSelectionOfObject (theObject, aSelIter.Value()); aSelIter.Value()->UpdateBVHStatus (SelectMgr_TBU_Remove); + mySelector->Deactivate (aSelIter.Value()); } mySelector->RemoveSelectableObject (theObject); } diff --git a/tests/bugs/vis/bug30672 b/tests/bugs/vis/bug30672 new file mode 100644 index 0000000000..49e80cdd6c --- /dev/null +++ b/tests/bugs/vis/bug30672 @@ -0,0 +1,21 @@ +puts "=============" +puts "0030672: Visualization - AIS_InteractiveContext::SetLocation() sets invalid selection BVH flag to removed object" +puts "=============" + +pload MODELING VISUALIZATION +box b 1 2 3 +vclear +vinit View1 +vaxo +vdisplay -dispMode 1 -highMode 1 b +vfit +vremove -context b +vlocation b -setLocation 2 0 0 +vdisplay -dispMode 1 b +vmoveto 200 200 +if { [vreadpixel 150 150 -rgb -name] != "BLACK" } { puts "Error: wrong prs location" } +if { [vreadpixel 300 300 -rgb -name] != "DARKGOLDENROD3" } { puts "Error: wrong sel location" } +vmoveto 300 300 +if { [vreadpixel 300 300 -rgb -name] != "DARKTURQUOISE" } { puts "Error: wrong highlighting" } + +vdump $imagedir/${casename}.png