mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
0027986: Visualization - AIS_InteractiveContext::SetLocation() does not update dynamic highlighting
AIS_InteractiveContext::SetLocation() - update HilightMode instead of DisplayMode. PrsMgr_PresentationManager::UpdateHighlightTrsf() - fix accessing NULL presentation.
This commit is contained in:
parent
d94bed0e26
commit
7bbccb5f4e
@ -1331,9 +1331,10 @@ void AIS_InteractiveContext::SetLocation (const Handle(AIS_InteractiveObject)& t
|
|||||||
// to its highlight structure immediately
|
// to its highlight structure immediately
|
||||||
if (!myLastPicked.IsNull() && myLastPicked->IsSameSelectable (theIObj))
|
if (!myLastPicked.IsNull() && myLastPicked->IsSameSelectable (theIObj))
|
||||||
{
|
{
|
||||||
|
const Standard_Integer aHiMod = theIObj->HasHilightMode() ? theIObj->HilightMode() : 0;
|
||||||
myLastPicked->UpdateHighlightTrsf (myMainVwr,
|
myLastPicked->UpdateHighlightTrsf (myMainVwr,
|
||||||
myMainPM,
|
myMainPM,
|
||||||
theIObj->HasDisplayMode() ? theIObj->DisplayMode() : 0);
|
aHiMod);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -641,12 +641,15 @@ void PrsMgr_PresentationManager::UpdateHighlightTrsf (const Handle(V3d_Viewer)&
|
|||||||
if (theObj.IsNull())
|
if (theObj.IsNull())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
const Handle(Prs3d_Presentation)& aBasePrs = Presentation (theObj, theMode, Standard_False)->Presentation();
|
Handle(PrsMgr_Presentation) aPrs = Presentation (!theSelObj.IsNull() ? theSelObj : theObj, theMode, Standard_False);
|
||||||
const Handle(Prs3d_Presentation)& aParentPrs = theSelObj.IsNull() ?
|
if (aPrs.IsNull())
|
||||||
aBasePrs : Presentation (theSelObj, theMode, Standard_False)->Presentation();
|
{
|
||||||
const Standard_Integer aParentId = aParentPrs->CStructure()->Id;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
updatePrsTransformation (myImmediateList, aParentId, aBasePrs->CStructure()->Transformation());
|
Handle(Geom_Transformation) aTrsf = theObj->LocalTransformationGeom();
|
||||||
|
const Standard_Integer aParentId = aPrs->Presentation()->CStructure()->Id;
|
||||||
|
updatePrsTransformation (myImmediateList, aParentId, aTrsf);
|
||||||
|
|
||||||
if (!myViewDependentImmediateList.IsEmpty())
|
if (!myViewDependentImmediateList.IsEmpty())
|
||||||
{
|
{
|
||||||
@ -658,7 +661,7 @@ void PrsMgr_PresentationManager::UpdateHighlightTrsf (const Handle(V3d_Viewer)&
|
|||||||
{
|
{
|
||||||
updatePrsTransformation (myViewDependentImmediateList,
|
updatePrsTransformation (myViewDependentImmediateList,
|
||||||
aViewDepParentPrs->CStructure()->Id,
|
aViewDepParentPrs->CStructure()->Id,
|
||||||
aBasePrs->CStructure()->Transformation());
|
aTrsf);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
23
tests/bugs/vis/bug27986_1
Normal file
23
tests/bugs/vis/bug27986_1
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
puts "==========="
|
||||||
|
puts "OCC27986"
|
||||||
|
puts "Visualization - AIS_InteractiveContext::SetLocation() does not update dynamic highlighting"
|
||||||
|
puts "Test global selection"
|
||||||
|
puts "==========="
|
||||||
|
puts ""
|
||||||
|
|
||||||
|
pload MODELING VISUALIZATION
|
||||||
|
box b 1 2 3
|
||||||
|
|
||||||
|
vclear
|
||||||
|
vinit View1
|
||||||
|
vaxo
|
||||||
|
vdisplay -dispMode 0 -highMode 1 b
|
||||||
|
vfit
|
||||||
|
vzoom 0.5
|
||||||
|
vmoveto 250 250
|
||||||
|
vsetlocation b 2 1 0
|
||||||
|
set aColor1 [vreadpixel 220 200 rgb name]
|
||||||
|
set aColor2 [vreadpixel 350 220 rgb name]
|
||||||
|
if { "$aColor1" != "BLACK" || "$aColor2" != "DARKTURQUOISE" } { puts "Error: dynamic highlighting is not updated" }
|
||||||
|
|
||||||
|
vdump $imagedir/${casename}.png
|
24
tests/bugs/vis/bug27986_2
Normal file
24
tests/bugs/vis/bug27986_2
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
puts "==========="
|
||||||
|
puts "OCC27986"
|
||||||
|
puts "Visualization - AIS_InteractiveContext::SetLocation() does not update dynamic highlighting"
|
||||||
|
puts "Test local selection"
|
||||||
|
puts "==========="
|
||||||
|
puts ""
|
||||||
|
|
||||||
|
pload MODELING VISUALIZATION
|
||||||
|
box b 1 2 3
|
||||||
|
|
||||||
|
vclear
|
||||||
|
vinit View1
|
||||||
|
vaxo
|
||||||
|
vdisplay -dispMode 0 -highMode 1 b
|
||||||
|
vfit
|
||||||
|
vzoom 0.5
|
||||||
|
vselmode b 4 1
|
||||||
|
vmoveto 250 250
|
||||||
|
vsetlocation b 2 1 0
|
||||||
|
set aColor1 [vreadpixel 220 200 rgb name]
|
||||||
|
set aColor2 [vreadpixel 350 220 rgb name]
|
||||||
|
if { "$aColor1" != "BLACK" || "$aColor2" != "DARKTURQUOISE" } { puts "Error: dynamic highlighting is not updated" }
|
||||||
|
|
||||||
|
vdump $imagedir/${casename}.png
|
Loading…
x
Reference in New Issue
Block a user