diff options
author | Andy Nichols <andy.nichols@digia.com> | 2012-11-19 16:26:38 +0100 |
---|---|---|
committer | The Qt Project <gerrit-noreply@qt-project.org> | 2012-11-21 16:56:55 +0100 |
commit | 4c2346bbddc83e8a1f8baf9fc335280ed2dace5e (patch) | |
tree | e42910522240c94c946fa4b6236b909f08df899f /src/plugins/avfoundation/mediaplayer/avfvideoframerenderer.mm | |
parent | 21c39152055131d87614f051ca08566bd51f268f (diff) |
AVFoundation: Enable QImage based frame fallback
QGraphicsVideoItem was not working because the QPainterVideoSurface was
unable to paint BGR32 format OpenGL textures. Now if the QGraphicsView
window has a QGLWidget viewport, we use the GLTextureHandle to render
the video, otherwise we fallback to the software QImage rendered case.
Task-number: QTBUG-28017
Change-Id: I9304e0a2536f15075ae34cdd509ef24fbc18604e
Reviewed-by: Yoann Lopes <yoann.lopes@digia.com>
Diffstat (limited to 'src/plugins/avfoundation/mediaplayer/avfvideoframerenderer.mm')
-rw-r--r-- | src/plugins/avfoundation/mediaplayer/avfvideoframerenderer.mm | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/src/plugins/avfoundation/mediaplayer/avfvideoframerenderer.mm b/src/plugins/avfoundation/mediaplayer/avfvideoframerenderer.mm index ea787dc16..294ea32e3 100644 --- a/src/plugins/avfoundation/mediaplayer/avfvideoframerenderer.mm +++ b/src/plugins/avfoundation/mediaplayer/avfvideoframerenderer.mm @@ -131,6 +131,7 @@ GLuint AVFVideoFrameRenderer::renderLayerToTexture(AVPlayerLayer *layer) return 0; renderLayerToFBO(layer, fbo); + m_glContext->doneCurrent(); return fbo->texture(); } @@ -148,8 +149,10 @@ QImage AVFVideoFrameRenderer::renderLayerToImage(AVPlayerLayer *layer) return QImage(); renderLayerToFBO(layer, fbo); + QImage fboImage = fbo->toImage().mirrored(); + m_glContext->doneCurrent(); - return fbo->toImage(); + return fboImage; } QOpenGLFramebufferObject *AVFVideoFrameRenderer::initRenderer(AVPlayerLayer *layer) @@ -179,8 +182,8 @@ QOpenGLFramebufferObject *AVFVideoFrameRenderer::initRenderer(AVPlayerLayer *lay } else { #ifdef QT_DEBUG_AVF qWarning("failed to get Render Thread context"); - m_isContextShared = false; #endif + m_isContextShared = false; } if (!m_glContext->create()) { qWarning("failed to create QOpenGLContext"); @@ -253,6 +256,4 @@ void AVFVideoFrameRenderer::renderLayerToFBO(AVPlayerLayer *layer, QOpenGLFrameb glFinish(); //Rendering needs to be done before passing texture to video frame fbo->release(); - - m_glContext->doneCurrent(); } |