Index: media/filters/skcanvas_video_renderer.h |
diff --git a/media/filters/skcanvas_video_renderer.h b/media/filters/skcanvas_video_renderer.h |
index 9e3622d79c531058aee068ae8bce1e3ccc8de2e8..4caadce129cf62217c3885497f8ee8c351b9a432 100644 |
--- a/media/filters/skcanvas_video_renderer.h |
+++ b/media/filters/skcanvas_video_renderer.h |
@@ -10,8 +10,15 @@ |
#include "third_party/skia/include/core/SkBitmap.h" |
#include "ui/gfx/rect.h" |
+class GrContext; |
class SkCanvas; |
+namespace gpu { |
+namespace gles2 { |
+class GLES2Interface; |
+} |
+} |
+ |
namespace media { |
class VideoFrame; |
@@ -23,6 +30,10 @@ class MEDIA_EXPORT SkCanvasVideoRenderer { |
SkCanvasVideoRenderer(); |
~SkCanvasVideoRenderer(); |
+ struct Context3DProvider { |
+ gpu::gles2::GLES2Interface* gl; |
+ class GrContext* gr_context; |
+ }; |
// Paints |video_frame| on |canvas|, scaling the result to fit dimensions |
// specified by |dest_rect|. |
// |
@@ -30,13 +41,28 @@ class MEDIA_EXPORT SkCanvasVideoRenderer { |
void Paint(media::VideoFrame* video_frame, |
SkCanvas* canvas, |
const gfx::RectF& dest_rect, |
- uint8 alpha); |
+ uint8 alpha, |
+ Context3DProvider* context_provider); |
+ |
+ static void CopyVideoFrameToTexture(gpu::gles2::GLES2Interface* gl, |
+ media::VideoFrame* video_frame, |
+ unsigned int texture, |
+ unsigned int level, |
+ unsigned int internal_format, |
+ unsigned int type, |
+ bool premultiply_alpha, |
+ bool flip_y); |
private: |
+ void CleanUpTemporaryBuffers(); |
+ |
// An RGB bitmap and corresponding timestamp of the previously converted |
// video frame data. |
SkBitmap last_frame_; |
base::TimeDelta last_frame_timestamp_; |
+ // It's possible to be used by accelerated client and non-accelerated client. |
+ SkBitmap accelerated_last_frame_; |
+ base::TimeDelta accelerated_last_frame_timestamp_; |
DISALLOW_COPY_AND_ASSIGN(SkCanvasVideoRenderer); |
}; |