1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
|
// Copyright (c) 2010 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.
//
// The video renderer implementation to be use by the media pipeline. It lives
// inside video renderer thread and also WebKit's main thread. We need to be
// extra careful about members shared by two different threads, especially
// video frame buffers.
#ifndef WEBKIT_GLUE_MEDIA_VIDEO_RENDERER_IMPL_H_
#define WEBKIT_GLUE_MEDIA_VIDEO_RENDERER_IMPL_H_
#include "gfx/rect.h"
#include "gfx/size.h"
#include "media/base/buffers.h"
#include "media/base/filters.h"
#include "media/filters/video_renderer_base.h"
#include "skia/ext/platform_canvas.h"
#include "third_party/WebKit/WebKit/chromium/public/WebMediaPlayer.h"
#include "webkit/glue/media/web_video_renderer.h"
#include "webkit/glue/webmediaplayer_impl.h"
namespace webkit_glue {
class VideoRendererImpl : public WebVideoRenderer {
public:
// WebVideoRenderer implementation.
virtual void SetRect(const gfx::Rect& rect);
virtual void Paint(skia::PlatformCanvas* canvas, const gfx::Rect& dest_rect);
// Static method for creating factory for this object.
static media::FilterFactory* CreateFactory(WebMediaPlayerImpl::Proxy* proxy,
bool pts_logging);
// FilterFactoryImpl2 implementation.
static bool IsMediaFormatSupported(const media::MediaFormat& media_format);
// TODO(scherkus): remove this mega-hack, see http://crbug.com/28207
class FactoryFactory : public webkit_glue::WebVideoRendererFactoryFactory {
public:
FactoryFactory(bool pts_logging)
: webkit_glue::WebVideoRendererFactoryFactory(),
pts_logging_(pts_logging) {
}
virtual media::FilterFactory* CreateFactory(
webkit_glue::WebMediaPlayerImpl::Proxy* proxy) {
return VideoRendererImpl::CreateFactory(proxy, pts_logging_);
}
private:
// Whether we're logging video presentation timestamps (PTS).
bool pts_logging_;
DISALLOW_COPY_AND_ASSIGN(FactoryFactory);
};
protected:
// Method called by VideoRendererBase during initialization.
virtual bool OnInitialize(media::VideoDecoder* decoder);
// Method called by the VideoRendererBase when stopping.
virtual void OnStop();
// Method called by the VideoRendererBase when a frame is available.
virtual void OnFrameAvailable();
private:
// Only the filter factories can create instances.
friend class media::FilterFactoryImpl2<VideoRendererImpl,
WebMediaPlayerImpl::Proxy*,
bool>;
VideoRendererImpl(WebMediaPlayerImpl::Proxy* proxy, bool pts_logging);
virtual ~VideoRendererImpl() {}
// Determine the conditions to perform fast paint. Returns true if we can do
// fast paint otherwise false.
bool CanFastPaint(skia::PlatformCanvas* canvas, const gfx::Rect& dest_rect);
// Slow paint does a YUV => RGB, and scaled blit in two separate operations.
void SlowPaint(media::VideoFrame* video_frame,
skia::PlatformCanvas* canvas,
const gfx::Rect& dest_rect);
// Fast paint does YUV => RGB, scaling, blitting all in one step into the
// canvas. It's not always safe and appropriate to perform fast paint.
// CanFastPaint() is used to determine the conditions.
void FastPaint(media::VideoFrame* video_frame,
skia::PlatformCanvas* canvas,
const gfx::Rect& dest_rect);
void TransformToSkIRect(const SkMatrix& matrix, const gfx::Rect& src_rect,
SkIRect* dest_rect);
// Pointer to our parent object that is called to request repaints.
scoped_refptr<WebMediaPlayerImpl::Proxy> proxy_;
// An RGB bitmap used to convert the video frames.
SkBitmap bitmap_;
// These two members are used to determine if the |bitmap_| contains
// an already converted image of the current frame. IMPORTANT NOTE: The
// value of |last_converted_frame_| must only be used for comparison purposes,
// and it should be assumed that the value of the pointer is INVALID unless
// it matches the pointer returned from GetCurrentFrame(). Even then, just
// to make sure, we compare the timestamp to be sure the bits in the
// |current_frame_bitmap_| are valid.
media::VideoFrame* last_converted_frame_;
base::TimeDelta last_converted_timestamp_;
// The size of the video.
gfx::Size video_size_;
// Whether we're logging video presentation timestamps (PTS).
bool pts_logging_;
DISALLOW_COPY_AND_ASSIGN(VideoRendererImpl);
};
} // namespace webkit_glue
#endif // WEBKIT_GLUE_MEDIA_VIDEO_RENDERER_IMPL_H_
|