From 4f73ff97486f89b8e7aca1ed7d55cf42a644d68b Mon Sep 17 00:00:00 2001 From: Gunnar Sletta Date: Sun, 11 Sep 2011 08:54:05 +0200 Subject: orient the fbo rendering the same way as other fbo rendering and enable multisampling Change-Id: Ibfb3bd9577efc50ca7654019638d22b9077df6bb Reviewed-on: http://codereview.qt-project.org/4627 Reviewed-by: Qt Sanity Bot Reviewed-by: Yoann Lopes --- src/declarative/scenegraph/util/qsgpainternode.cpp | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) (limited to 'src/declarative/scenegraph') diff --git a/src/declarative/scenegraph/util/qsgpainternode.cpp b/src/declarative/scenegraph/util/qsgpainternode.cpp index 90d66c094e..5d548792c6 100644 --- a/src/declarative/scenegraph/util/qsgpainternode.cpp +++ b/src/declarative/scenegraph/util/qsgpainternode.cpp @@ -43,6 +43,7 @@ #include "qsgpainteditem.h" #include +#include #include #include #include @@ -148,8 +149,10 @@ void QSGPainterNode::paint() if (m_actualRenderTarget == QSGPaintedItem::Image) painter.begin(&m_image); else { - if (!m_gl_device) + if (!m_gl_device) { m_gl_device = new QOpenGLPaintDevice(m_fboSize); + m_gl_device->setPaintFlipped(true); + } if (m_multisampledFbo) m_multisampledFbo->bind(); @@ -230,7 +233,7 @@ void QSGPainterNode::updateGeometry() if (m_actualRenderTarget == QSGPaintedItem::Image) source = QRectF(0, 0, 1, 1); else - source = QRectF(0, 1, qreal(m_size.width()) / m_fboSize.width(), qreal(-m_size.height()) / m_fboSize.height()); + source = QRectF(0, 0, qreal(m_size.width()) / m_fboSize.width(), qreal(m_size.height()) / m_fboSize.height()); QSGGeometry::updateTexturedRectGeometry(&m_geometry, QRectF(0, 0, m_size.width(), m_size.height()), source); @@ -280,7 +283,7 @@ void QSGPainterNode::updateRenderTarget() { QOpenGLFramebufferObjectFormat format; format.setAttachment(QOpenGLFramebufferObject::CombinedDepthStencil); - format.setSamples(ctx->format().samples()); + format.setSamples(8); m_multisampledFbo = new QOpenGLFramebufferObject(m_fboSize, format); } { -- cgit v1.2.3