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

0027629: Visualization - apply a correct model-world matrix to normals in fixed function pipeline with enabled zoom persistence.

Small correction of test case for issue CR27629
This commit is contained in:
isk 2016-06-23 15:01:34 +03:00 committed by bugmaster
parent 8009d0702c
commit 04be500328
2 changed files with 27 additions and 8 deletions

View File

@ -474,14 +474,6 @@ void OpenGl_Structure::Render (const Handle(OpenGl_Workspace) &theWorkspace) con
aCtx->ModelWorldState.Push();
aCtx->ModelWorldState.SetCurrent (Transformation);
// detect scale transform
const Standard_Boolean anOldGlNormalize = aCtx->IsGlNormalizeEnabled();
const Standard_ShortReal aScaleX = Transformation.GetRow (0).xyz().SquareModulus();
if (Abs (aScaleX - 1.f) > Precision::Confusion())
{
aCtx->SetGlNormalizeEnabled (Standard_True);
}
if (TransformPersistence.Flags)
{
OpenGl_Mat4 aProjection = aCtx->ProjectionState.Current();
@ -495,6 +487,14 @@ void OpenGl_Structure::Render (const Handle(OpenGl_Workspace) &theWorkspace) con
aCtx->ApplyProjectionMatrix();
}
// detect scale transform
const Standard_Boolean anOldGlNormalize = aCtx->IsGlNormalizeEnabled();
const Standard_ShortReal aScaleX = aCtx->ModelWorldState.Current().GetRow (0).xyz().SquareModulus();
if (Abs (aScaleX - 1.f) > Precision::Confusion())
{
aCtx->SetGlNormalizeEnabled (Standard_True);
}
// Take into account transform persistence
aCtx->ApplyModelViewMatrix();

19
tests/bugs/vis/bug27629 Normal file
View File

@ -0,0 +1,19 @@
puts "========"
puts "OCC27629"
puts "========"
puts ""
##############################################################################################################################
puts "Visualization - apply a correct model-world matrix to normals in fixed function pipeline with enabled zoom persistence."
##############################################################################################################################
vinit
box b0 25 25 25
vsetdispmode 1
vdisplay b0 -trsfPers zoom
vzoom 10
if { [vreadpixel 220 200 name] != "DARKGOLDENROD3 1"} {
puts "Error: normals aren't normalized!"
}
checkview -screenshot -3d -path ${imagedir}/${test_image}.png