1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-04 18:06:22 +03:00

0029285: Visualization, V3d_View::UpdateLights() - eliminate implicit redraw

This commit is contained in:
kgv 2017-11-02 10:04:39 +03:00 committed by bugmaster
parent dd1ae9df09
commit 761d880766
3 changed files with 7 additions and 2 deletions

View File

@ -384,7 +384,6 @@ void V3d_View::UpdateLights() const
aLights.Append (anActiveLightIter.Value()->Light());
}
myView->SetLights (aLights);
Update();
}
//=============================================================================

View File

@ -169,7 +169,7 @@ public:
//! Returns True is The View is empty
Standard_EXPORT Standard_Boolean IsEmpty() const;
//! Updates the lights of the view. The view is redrawn.
//! Updates the lights of the view.
Standard_EXPORT void UpdateLights() const;
//! Sets the automatic z-fit mode and its parameters.

View File

@ -9318,6 +9318,7 @@ static int VLight (Draw_Interpretor& theDi,
Handle(V3d_Light) aLightOld;
Standard_Boolean isGlobal = Standard_True;
Standard_Boolean toCreate = Standard_False;
ViewerTest_AutoUpdater anUpdateTool (ViewerTest::GetAISContext(), aView);
for (Standard_Integer anArgIt = 1; anArgIt < theArgsNb; ++anArgIt)
{
Handle(V3d_Light) aLightCurr = aLightNew.IsNull() ? aLightOld : aLightNew;
@ -9330,6 +9331,11 @@ static int VLight (Draw_Interpretor& theDi,
const TCollection_AsciiString anArg (theArgVec[anArgIt]);
TCollection_AsciiString anArgCase (anArg);
anArgCase.UpperCase();
if (anUpdateTool.parseRedrawMode (anArg))
{
continue;
}
if (anArgCase.IsEqual ("NEW")
|| anArgCase.IsEqual ("ADD")
|| anArgCase.IsEqual ("CREATE"))