| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef WEBKIT_MEDIA_ANDROID_WEBMEDIAPLAYER_ANDROID_H_ | 5 #ifndef WEBKIT_MEDIA_ANDROID_WEBMEDIAPLAYER_ANDROID_H_ |
| 6 #define WEBKIT_MEDIA_ANDROID_WEBMEDIAPLAYER_ANDROID_H_ | 6 #define WEBKIT_MEDIA_ANDROID_WEBMEDIAPLAYER_ANDROID_H_ |
| 7 | 7 |
| 8 #include <jni.h> | 8 #include <jni.h> |
| 9 | 9 |
| 10 #include "base/basictypes.h" | 10 #include "base/basictypes.h" |
| 11 #include "base/memory/ref_counted.h" |
| 12 #include "base/memory/scoped_ptr.h" |
| 11 #include "base/message_loop.h" | 13 #include "base/message_loop.h" |
| 12 #include "base/memory/scoped_ptr.h" | |
| 13 #include "base/time.h" | 14 #include "base/time.h" |
| 15 #include "cc/layers/video_frame_provider.h" |
| 14 #include "third_party/WebKit/Source/Platform/chromium/public/WebSize.h" | 16 #include "third_party/WebKit/Source/Platform/chromium/public/WebSize.h" |
| 15 #include "third_party/WebKit/Source/Platform/chromium/public/WebURL.h" | 17 #include "third_party/WebKit/Source/Platform/chromium/public/WebURL.h" |
| 16 #include "third_party/WebKit/Source/WebKit/chromium/public/WebMediaPlayer.h" | 18 #include "third_party/WebKit/Source/WebKit/chromium/public/WebMediaPlayer.h" |
| 17 | 19 |
| 18 namespace WebKit { | 20 namespace WebKit { |
| 19 class WebVideoFrame; | 21 class WebVideoFrame; |
| 20 } | 22 } |
| 21 | 23 |
| 24 namespace webkit { |
| 25 class WebLayerImpl; |
| 26 } |
| 27 |
| 22 namespace webkit_media { | 28 namespace webkit_media { |
| 23 | 29 |
| 24 class StreamTextureFactory; | 30 class StreamTextureFactory; |
| 25 class StreamTextureProxy; | 31 class StreamTextureProxy; |
| 26 class WebMediaPlayerManagerAndroid; | 32 class WebMediaPlayerManagerAndroid; |
| 27 class WebVideoFrameImpl; | 33 class WebVideoFrameImpl; |
| 28 | 34 |
| 29 // An abstract class that serves as the common base class for implementing | 35 // An abstract class that serves as the common base class for implementing |
| 30 // WebKit::WebMediaPlayer on Android. | 36 // WebKit::WebMediaPlayer on Android. |
| 31 class WebMediaPlayerAndroid | 37 class WebMediaPlayerAndroid |
| 32 : public WebKit::WebMediaPlayer, | 38 : public WebKit::WebMediaPlayer, |
| 39 #ifdef REMOVE_WEBVIDEOFRAME |
| 40 public cc::VideoFrameProvider, |
| 41 #endif |
| 33 public MessageLoop::DestructionObserver { | 42 public MessageLoop::DestructionObserver { |
| 34 public: | 43 public: |
| 35 // Resource loading. | 44 // Resource loading. |
| 36 virtual void load(const WebKit::WebURL& url, CORSMode cors_mode); | 45 virtual void load(const WebKit::WebURL& url, CORSMode cors_mode); |
| 37 virtual void load(const WebKit::WebURL& url, | 46 virtual void load(const WebKit::WebURL& url, |
| 38 WebKit::WebMediaSource* media_source, | 47 WebKit::WebMediaSource* media_source, |
| 39 CORSMode cors_mode); | 48 CORSMode cors_mode); |
| 40 virtual void cancelLoad(); | 49 virtual void cancelLoad(); |
| 41 | 50 |
| 42 // Playback controls. | 51 // Playback controls. |
| (...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 87 virtual WebKit::WebMediaPlayer::MovieLoadType movieLoadType() const; | 96 virtual WebKit::WebMediaPlayer::MovieLoadType movieLoadType() const; |
| 88 | 97 |
| 89 virtual float mediaTimeForTimeValue(float timeValue) const; | 98 virtual float mediaTimeForTimeValue(float timeValue) const; |
| 90 | 99 |
| 91 // Provide statistics. | 100 // Provide statistics. |
| 92 virtual unsigned decodedFrameCount() const; | 101 virtual unsigned decodedFrameCount() const; |
| 93 virtual unsigned droppedFrameCount() const; | 102 virtual unsigned droppedFrameCount() const; |
| 94 virtual unsigned audioDecodedByteCount() const; | 103 virtual unsigned audioDecodedByteCount() const; |
| 95 virtual unsigned videoDecodedByteCount() const; | 104 virtual unsigned videoDecodedByteCount() const; |
| 96 | 105 |
| 106 #ifndef REMOVE_WEBVIDEOFRAME |
| 97 // Methods called from VideoLayerChromium. These methods are running on the | 107 // Methods called from VideoLayerChromium. These methods are running on the |
| 98 // compositor thread. | 108 // compositor thread. |
| 99 virtual WebKit::WebVideoFrame* getCurrentFrame(); | 109 virtual WebKit::WebVideoFrame* getCurrentFrame(); |
| 100 virtual void putCurrentFrame(WebKit::WebVideoFrame*); | 110 virtual void putCurrentFrame(WebKit::WebVideoFrame*); |
| 101 | 111 |
| 102 // This gets called both on compositor and main thread to set the callback | 112 // This gets called both on compositor and main thread to set the callback |
| 103 // target when a frame is produced. | 113 // target when a frame is produced. |
| 104 virtual void setStreamTextureClient(WebKit::WebStreamTextureClient* client); | 114 virtual void setStreamTextureClient(WebKit::WebStreamTextureClient* client); |
| 115 #else |
| 116 // cc::VideoFrameProvider implementation. These methods are running on the |
| 117 // compositor thread. |
| 118 virtual void SetVideoFrameProviderClient( |
| 119 cc::VideoFrameProvider::Client* client) OVERRIDE; |
| 120 virtual scoped_refptr<media::VideoFrame> GetCurrentFrame() OVERRIDE; |
| 121 virtual void PutCurrentFrame(const scoped_refptr<media::VideoFrame>& frame) |
| 122 OVERRIDE; |
| 123 #endif |
| 105 | 124 |
| 106 // Media player callback handlers. | 125 // Media player callback handlers. |
| 107 virtual void OnMediaPrepared(base::TimeDelta duration); | 126 virtual void OnMediaPrepared(base::TimeDelta duration); |
| 108 virtual void OnPlaybackComplete(); | 127 virtual void OnPlaybackComplete(); |
| 109 virtual void OnBufferingUpdate(int percentage); | 128 virtual void OnBufferingUpdate(int percentage); |
| 110 virtual void OnSeekComplete(base::TimeDelta current_time); | 129 virtual void OnSeekComplete(base::TimeDelta current_time); |
| 111 virtual void OnMediaError(int error_type); | 130 virtual void OnMediaError(int error_type); |
| 112 virtual void OnVideoSizeChanged(int width, int height); | 131 virtual void OnVideoSizeChanged(int width, int height); |
| 113 | 132 |
| 114 // Called to update the current time. | 133 // Called to update the current time. |
| (...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 188 void ReallocateVideoFrame(); | 207 void ReallocateVideoFrame(); |
| 189 | 208 |
| 190 WebKit::WebMediaPlayerClient* const client_; | 209 WebKit::WebMediaPlayerClient* const client_; |
| 191 | 210 |
| 192 // Save the list of buffered time ranges. | 211 // Save the list of buffered time ranges. |
| 193 WebKit::WebTimeRanges buffered_; | 212 WebKit::WebTimeRanges buffered_; |
| 194 | 213 |
| 195 // Size of the video. | 214 // Size of the video. |
| 196 WebKit::WebSize natural_size_; | 215 WebKit::WebSize natural_size_; |
| 197 | 216 |
| 198 // The video frame object used for renderering by WebKit. | 217 // The video frame object used for rendering by the compositor. |
| 199 scoped_ptr<WebVideoFrameImpl> web_video_frame_; | 218 scoped_refptr<media::VideoFrame> current_frame_; |
| 200 | 219 |
| 201 // Message loop for main renderer thread. | 220 // Message loop for main renderer thread. |
| 202 MessageLoop* main_loop_; | 221 MessageLoop* main_loop_; |
| 203 | 222 |
| 204 // URL of the media file to be fetched. | 223 // URL of the media file to be fetched. |
| 205 GURL url_; | 224 GURL url_; |
| 206 | 225 |
| 207 // Media duration. | 226 // Media duration. |
| 208 base::TimeDelta duration_; | 227 base::TimeDelta duration_; |
| 209 | 228 |
| (...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 244 // Object for allocating stream textures. | 263 // Object for allocating stream textures. |
| 245 scoped_ptr<StreamTextureFactory> stream_texture_factory_; | 264 scoped_ptr<StreamTextureFactory> stream_texture_factory_; |
| 246 | 265 |
| 247 // Object for calling back the compositor thread to repaint the video when a | 266 // Object for calling back the compositor thread to repaint the video when a |
| 248 // frame available. It should be initialized on the compositor thread. | 267 // frame available. It should be initialized on the compositor thread. |
| 249 scoped_ptr<StreamTextureProxy> stream_texture_proxy_; | 268 scoped_ptr<StreamTextureProxy> stream_texture_proxy_; |
| 250 | 269 |
| 251 // Whether media player needs external surface. | 270 // Whether media player needs external surface. |
| 252 bool needs_external_surface_; | 271 bool needs_external_surface_; |
| 253 | 272 |
| 273 // A pointer back to the compositor to inform it about state changes. This is |
| 274 // not NULL while the compositor is actively using this webmediaplayer. |
| 275 cc::VideoFrameProvider::Client* video_frame_provider_client_; |
| 276 |
| 277 scoped_ptr<webkit::WebLayerImpl> video_weblayer_; |
| 278 |
| 254 DISALLOW_COPY_AND_ASSIGN(WebMediaPlayerAndroid); | 279 DISALLOW_COPY_AND_ASSIGN(WebMediaPlayerAndroid); |
| 255 }; | 280 }; |
| 256 | 281 |
| 257 } // namespace webkit_media | 282 } // namespace webkit_media |
| 258 | 283 |
| 259 #endif // WEBKIT_MEDIA_ANDROID_WEBMEDIAPLAYER_ANDROID_H_ | 284 #endif // WEBKIT_MEDIA_ANDROID_WEBMEDIAPLAYER_ANDROID_H_ |
| OLD | NEW |