// Copyright (c) 2011 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef WEBKIT_GLUE_MEDIA_WEB_VIDEO_RENDERER_H_ #define WEBKIT_GLUE_MEDIA_WEB_VIDEO_RENDERER_H_ #include "media/base/video_frame.h" #include "media/filters/video_renderer_base.h" #include "webkit/glue/webmediaplayer_impl.h" namespace webkit_glue { // A specialized version of a VideoRenderer designed to be used inside WebKit. class WebVideoRenderer : public media::VideoRendererBase { public: WebVideoRenderer() : media::VideoRendererBase() {} virtual ~WebVideoRenderer() {} // Saves the reference to WebMediaPlayerImpl::Proxy. virtual void SetWebMediaPlayerImplProxy(WebMediaPlayerImpl::Proxy* proxy) = 0; // This method is called with the same rect as the Paint() method and could // be used by future implementations to implement an improved color space + // scale code on a separate thread. Since we always do the stretch on the // same thread as the Paint method, we just ignore the call for now. // // Method called on the render thread. virtual void SetRect(const gfx::Rect& rect) = 0; // Paint the current front frame on the |canvas| stretching it to fit the // |dest_rect|. // // Method called on the render thread. virtual void Paint(SkCanvas* canvas, const gfx::Rect& dest_rect) = 0; // Clients of this class (painter/compositor) should use GetCurrentFrame() // obtain ownership of VideoFrame, it should always relinquish the ownership // by use PutCurrentFrame(). Current frame is not guaranteed to be non-NULL. // It expects clients to use color-fill the background if current frame // is NULL. This could happen when before pipeline is pre-rolled or during // pause/flush/seek. virtual void GetCurrentFrame(scoped_refptr<media::VideoFrame>* frame_out) {} virtual void PutCurrentFrame(scoped_refptr<media::VideoFrame> frame) {} private: DISALLOW_COPY_AND_ASSIGN(WebVideoRenderer); }; } // namespace webkit_glue #endif // WEBKIT_GLUE_MEDIA_WEB_VIDEO_RENDERER_H_