mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
0027755: Visualization, V3d_View::ToPixMap() - fix image dump with MSAA turned on
OpenGl_View::Redraw() now handles correctly myTransientDrawToFront with MSAA turned on and resolution not equal to window size.
This commit is contained in:
parent
520cde8769
commit
521b0d7f81
@ -318,13 +318,23 @@ void OpenGl_View::Redraw()
|
|||||||
|| myMainSceneFbos[0]->GetVPSizeY() != aSizeY
|
|| myMainSceneFbos[0]->GetVPSizeY() != aSizeY
|
||||||
|| myMainSceneFbos[0]->NbSamples() != aNbSamples)
|
|| myMainSceneFbos[0]->NbSamples() != aNbSamples)
|
||||||
{
|
{
|
||||||
|
if (!myTransientDrawToFront)
|
||||||
|
{
|
||||||
|
myImmediateSceneFbos[0]->Release (aCtx.operator->());
|
||||||
|
myImmediateSceneFbos[1]->Release (aCtx.operator->());
|
||||||
|
myImmediateSceneFbos[0]->ChangeViewport (0, 0);
|
||||||
|
myImmediateSceneFbos[1]->ChangeViewport (0, 0);
|
||||||
|
}
|
||||||
|
|
||||||
// prepare FBOs containing main scene
|
// prepare FBOs containing main scene
|
||||||
// for further blitting and rendering immediate presentations on top
|
// for further blitting and rendering immediate presentations on top
|
||||||
if (aCtx->core20fwd != NULL)
|
if (aCtx->core20fwd != NULL)
|
||||||
{
|
{
|
||||||
myMainSceneFbos[0]->Init (aCtx, aSizeX, aSizeY, myFboColorFormat, myFboDepthFormat, aNbSamples);
|
myMainSceneFbos[0]->Init (aCtx, aSizeX, aSizeY, myFboColorFormat, myFboDepthFormat, aNbSamples);
|
||||||
}
|
}
|
||||||
if (!aCtx->caps->useSystemBuffer && myMainSceneFbos[0]->IsValid())
|
if (myTransientDrawToFront
|
||||||
|
&& !aCtx->caps->useSystemBuffer
|
||||||
|
&& myMainSceneFbos[0]->IsValid())
|
||||||
{
|
{
|
||||||
myImmediateSceneFbos[0]->InitLazy (aCtx, *myMainSceneFbos[0]);
|
myImmediateSceneFbos[0]->InitLazy (aCtx, *myMainSceneFbos[0]);
|
||||||
}
|
}
|
||||||
@ -434,6 +444,10 @@ void OpenGl_View::Redraw()
|
|||||||
{
|
{
|
||||||
anImmFbo = myImmediateSceneFbos[0].operator->();
|
anImmFbo = myImmediateSceneFbos[0].operator->();
|
||||||
}
|
}
|
||||||
|
if (!myTransientDrawToFront)
|
||||||
|
{
|
||||||
|
anImmFbo = aMainFbo;
|
||||||
|
}
|
||||||
|
|
||||||
#if !defined(GL_ES_VERSION_2_0)
|
#if !defined(GL_ES_VERSION_2_0)
|
||||||
if (aMainFbo == NULL
|
if (aMainFbo == NULL
|
||||||
@ -708,7 +722,8 @@ bool OpenGl_View::redrawImmediate (const Graphic3d_Camera::Projection theProject
|
|||||||
{
|
{
|
||||||
Handle(OpenGl_Context) aCtx = myWorkspace->GetGlContext();
|
Handle(OpenGl_Context) aCtx = myWorkspace->GetGlContext();
|
||||||
GLboolean toCopyBackToFront = GL_FALSE;
|
GLboolean toCopyBackToFront = GL_FALSE;
|
||||||
if (!myTransientDrawToFront)
|
if (theDrawFbo == theReadFbo
|
||||||
|
&& theDrawFbo != NULL)
|
||||||
{
|
{
|
||||||
myBackBufferRestored = Standard_False;
|
myBackBufferRestored = Standard_False;
|
||||||
}
|
}
|
||||||
@ -1339,6 +1354,7 @@ void OpenGl_View::bindDefaultFbo (OpenGl_FrameBuffer* theCustomFbo)
|
|||||||
if (anFbo != NULL)
|
if (anFbo != NULL)
|
||||||
{
|
{
|
||||||
anFbo->BindBuffer (aCtx);
|
anFbo->BindBuffer (aCtx);
|
||||||
|
anFbo->SetupViewport (aCtx);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -1350,8 +1366,8 @@ void OpenGl_View::bindDefaultFbo (OpenGl_FrameBuffer* theCustomFbo)
|
|||||||
aCtx->arbFBO->glBindFramebuffer (GL_FRAMEBUFFER, OpenGl_FrameBuffer::NO_FRAMEBUFFER);
|
aCtx->arbFBO->glBindFramebuffer (GL_FRAMEBUFFER, OpenGl_FrameBuffer::NO_FRAMEBUFFER);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
aCtx->core11fwd->glViewport (0, 0, myWindow->Width(), myWindow->Height());
|
||||||
}
|
}
|
||||||
aCtx->core11fwd->glViewport (0, 0, myWindow->Width(), myWindow->Height());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// =======================================================================
|
// =======================================================================
|
||||||
|
@ -15,10 +15,28 @@ vrotate 0.5 0 0
|
|||||||
vzbufftrihedron
|
vzbufftrihedron
|
||||||
|
|
||||||
vrenderparams -msaa 0
|
vrenderparams -msaa 0
|
||||||
vdump $::imagedir/${::casename}_0.png
|
vdump $::imagedir/${::casename}_512x512@msaa0.png
|
||||||
vrenderparams -msaa 2
|
vrenderparams -msaa 2
|
||||||
vdump $::imagedir/${::casename}_2.png
|
vdump $::imagedir/${::casename}_512x512@msaa2.png
|
||||||
vrenderparams -msaa 4
|
vrenderparams -msaa 4
|
||||||
vdump $::imagedir/${::casename}_4.png
|
vdump $::imagedir/${::casename}_512x512@msaa4.png
|
||||||
vrenderparams -msaa 8
|
vrenderparams -msaa 8
|
||||||
vdump $::imagedir/${::casename}_8.png
|
vdump $::imagedir/${::casename}_512x512@msaa8.png
|
||||||
|
|
||||||
|
# check dump with resolutions not equal to window size
|
||||||
|
vdump $::imagedir/${::casename}_1920x1080@msaa8.png -width 1920 -height 1080
|
||||||
|
vdump $::imagedir/${::casename}_2560x1440@msaa8.png -width 2560 -height 1440
|
||||||
|
|
||||||
|
# check dump with stereo
|
||||||
|
vstereo anaglyph
|
||||||
|
vdump $::imagedir/${::casename}_512x512@msaa8stereo.png -stereo blend
|
||||||
|
vdump $::imagedir/${::casename}_1920x1080@msaa8stereo.png -width 1920 -height 1080 -stereo blend
|
||||||
|
vdump $::imagedir/${::casename}_2560x1440@msaa8stereo.png -width 2560 -height 1440 -stereo blend
|
||||||
|
|
||||||
|
vraytrace 1
|
||||||
|
vsetdispmode b 1
|
||||||
|
vdump $::imagedir/${::casename}_512x512@msaa8stereort.png -stereo blend
|
||||||
|
vdump $::imagedir/${::casename}_1920x1080@msaa8stereort.png -width 1920 -height 1080 -stereo blend
|
||||||
|
vdump $::imagedir/${::casename}_2560x1440@msaa8stereort.png -width 2560 -height 1440 -stereo blend
|
||||||
|
vsetdispmode b 0
|
||||||
|
vraytrace 0
|
||||||
|
Loading…
x
Reference in New Issue
Block a user