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:
parent
8009d0702c
commit
04be500328
@ -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
19
tests/bugs/vis/bug27629
Normal 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
|
Loading…
x
Reference in New Issue
Block a user