Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 MEDIA_BLINK_WEBMEDIAPLAYER_IMPL_H_ | 5 #ifndef MEDIA_BLINK_WEBMEDIAPLAYER_IMPL_H_ |
| 6 #define MEDIA_BLINK_WEBMEDIAPLAYER_IMPL_H_ | 6 #define MEDIA_BLINK_WEBMEDIAPLAYER_IMPL_H_ |
| 7 | 7 |
| 8 #include <stdint.h> | 8 #include <stdint.h> |
| 9 | 9 |
| 10 #include <string> | 10 #include <string> |
| (...skipping 18 matching lines...) Expand all Loading... | |
| 29 #include "media/blink/video_frame_compositor.h" | 29 #include "media/blink/video_frame_compositor.h" |
| 30 #include "media/blink/webmediaplayer_delegate.h" | 30 #include "media/blink/webmediaplayer_delegate.h" |
| 31 #include "media/blink/webmediaplayer_params.h" | 31 #include "media/blink/webmediaplayer_params.h" |
| 32 #include "media/blink/webmediaplayer_util.h" | 32 #include "media/blink/webmediaplayer_util.h" |
| 33 #include "media/renderers/skcanvas_video_renderer.h" | 33 #include "media/renderers/skcanvas_video_renderer.h" |
| 34 #include "third_party/WebKit/public/platform/WebAudioSourceProvider.h" | 34 #include "third_party/WebKit/public/platform/WebAudioSourceProvider.h" |
| 35 #include "third_party/WebKit/public/platform/WebContentDecryptionModuleResult.h" | 35 #include "third_party/WebKit/public/platform/WebContentDecryptionModuleResult.h" |
| 36 #include "third_party/WebKit/public/platform/WebMediaPlayer.h" | 36 #include "third_party/WebKit/public/platform/WebMediaPlayer.h" |
| 37 #include "url/gurl.h" | 37 #include "url/gurl.h" |
| 38 | 38 |
| 39 #if defined(OS_ANDROID) | |
| 40 // Use WIMPI_CAST instead of OS_ANDROID to clearly mark the cast implementation | |
| 41 // so that we can easily remove it later, see crbug/575276. | |
| 42 #define WIMPI_CAST | |
|
DaleCurtis
2016/01/07 19:59:32
Can we avoid setting this here. #define in header
hubbe
2016/01/07 20:31:03
Hmm, so where should it go then?
I see two possib
DaleCurtis
2016/01/07 21:28:39
I'd just use OS_ANDROID with a // WMPI_CAST commen
hubbe
2016/01/11 22:47:24
Done.
| |
| 43 #endif | |
| 44 | |
| 45 #if defined(WIMPI_CAST) | |
| 46 // Delete this file when WIMPI_CAST is no longer needed. | |
| 47 #include "media/blink/renderer_media_player_interface.h" | |
| 48 #endif | |
| 49 | |
| 39 namespace blink { | 50 namespace blink { |
| 40 class WebGraphicsContext3D; | 51 class WebGraphicsContext3D; |
| 41 class WebLocalFrame; | 52 class WebLocalFrame; |
| 42 class WebMediaPlayerClient; | 53 class WebMediaPlayerClient; |
| 43 class WebMediaPlayerEncryptedMediaClient; | 54 class WebMediaPlayerEncryptedMediaClient; |
| 44 } | 55 } |
| 45 | 56 |
| 46 namespace base { | 57 namespace base { |
| 47 class SingleThreadTaskRunner; | 58 class SingleThreadTaskRunner; |
| 48 class TaskRunner; | 59 class TaskRunner; |
| (...skipping 14 matching lines...) Expand all Loading... | |
| 63 class WebAudioSourceProviderImpl; | 74 class WebAudioSourceProviderImpl; |
| 64 class WebMediaPlayerDelegate; | 75 class WebMediaPlayerDelegate; |
| 65 class WebTextTrackImpl; | 76 class WebTextTrackImpl; |
| 66 | 77 |
| 67 // The canonical implementation of blink::WebMediaPlayer that's backed by | 78 // The canonical implementation of blink::WebMediaPlayer that's backed by |
| 68 // Pipeline. Handles normal resource loading, Media Source, and | 79 // Pipeline. Handles normal resource loading, Media Source, and |
| 69 // Encrypted Media. | 80 // Encrypted Media. |
| 70 class MEDIA_BLINK_EXPORT WebMediaPlayerImpl | 81 class MEDIA_BLINK_EXPORT WebMediaPlayerImpl |
| 71 : public NON_EXPORTED_BASE(blink::WebMediaPlayer), | 82 : public NON_EXPORTED_BASE(blink::WebMediaPlayer), |
| 72 public NON_EXPORTED_BASE(WebMediaPlayerDelegate::Observer), | 83 public NON_EXPORTED_BASE(WebMediaPlayerDelegate::Observer), |
| 84 #if defined(WIMPI_CAST) | |
| 85 public RendererMediaPlayerInterface, | |
| 86 #endif | |
| 73 public base::SupportsWeakPtr<WebMediaPlayerImpl> { | 87 public base::SupportsWeakPtr<WebMediaPlayerImpl> { |
| 74 public: | 88 public: |
| 75 // Constructs a WebMediaPlayer implementation using Chromium's media stack. | 89 // Constructs a WebMediaPlayer implementation using Chromium's media stack. |
| 76 // |delegate| may be null. |renderer| may also be null, in which case an | 90 // |delegate| may be null. |renderer| may also be null, in which case an |
| 77 // internal renderer will be created. | 91 // internal renderer will be created. |
| 78 // TODO(xhwang): Drop the internal renderer path and always pass in a renderer | 92 // TODO(xhwang): Drop the internal renderer path and always pass in a renderer |
| 79 // here. | 93 // here. |
| 80 WebMediaPlayerImpl( | 94 WebMediaPlayerImpl( |
| 81 blink::WebLocalFrame* frame, | 95 blink::WebLocalFrame* frame, |
| 82 blink::WebMediaPlayerClient* client, | 96 blink::WebMediaPlayerClient* client, |
| (...skipping 100 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 183 void OnPipelineMetadata(PipelineMetadata metadata); | 197 void OnPipelineMetadata(PipelineMetadata metadata); |
| 184 void OnPipelineBufferingStateChanged(BufferingState buffering_state); | 198 void OnPipelineBufferingStateChanged(BufferingState buffering_state); |
| 185 void OnDemuxerOpened(); | 199 void OnDemuxerOpened(); |
| 186 void OnAddTextTrack(const TextTrackConfig& config, | 200 void OnAddTextTrack(const TextTrackConfig& config, |
| 187 const AddTextTrackDoneCB& done_cb); | 201 const AddTextTrackDoneCB& done_cb); |
| 188 | 202 |
| 189 // WebMediaPlayerDelegate::Observer implementation. | 203 // WebMediaPlayerDelegate::Observer implementation. |
| 190 void OnHidden() override; | 204 void OnHidden() override; |
| 191 void OnShown() override; | 205 void OnShown() override; |
| 192 | 206 |
| 207 #if defined(WIMPI_CAST) | |
|
DaleCurtis
2016/01/07 19:59:32
Can you stick this all in another class instead th
hubbe
2016/01/07 20:31:03
It's not a simple thing to do.
Some of these metho
DaleCurtis
2016/01/07 21:28:40
Please give it some more thought. You're essential
DaleCurtis
2016/01/07 21:29:09
s/900/400/
liberato (no reviews please)
2016/01/08 16:37:58
many of the operations these things perform are on
hubbe
2016/01/11 22:47:24
I think it might turn out messy, but I'm not sure.
| |
| 208 void requestRemotePlayback() override; | |
| 209 void requestRemotePlaybackControl() override; | |
| 210 | |
| 211 void set_media_player_manager( | |
| 212 RendererMediaPlayerManagerInterface* media_player_manager); | |
| 213 | |
| 214 // RendererMediaPlayerInterface implementation | |
| 215 void OnMediaMetadataChanged(base::TimeDelta duration, | |
| 216 int width, | |
| 217 int height, | |
| 218 bool success) override; | |
| 219 void OnPlaybackComplete() override; | |
| 220 void OnBufferingUpdate(int percentage) override; | |
| 221 void OnSeekRequest(const base::TimeDelta& time_to_seek) override; | |
| 222 void OnSeekComplete(const base::TimeDelta& current_time) override; | |
| 223 void OnMediaError(int error_type) override; | |
| 224 void OnVideoSizeChanged(int width, int height) override; | |
| 225 | |
| 226 // Called to update the current time. | |
| 227 void OnTimeUpdate(base::TimeDelta current_timestamp, | |
| 228 base::TimeTicks current_time_ticks) override; | |
| 229 | |
| 230 // void OnWaitingForDecryptionKey() override; | |
| 231 void OnPlayerReleased() override; | |
| 232 | |
| 233 // Functions called when media player status changes. | |
| 234 void OnConnectedToRemoteDevice( | |
| 235 const std::string& remote_playback_message) override; | |
| 236 void OnDisconnectedFromRemoteDevice() override; | |
| 237 void OnDidExitFullscreen() override; | |
| 238 void OnMediaPlayerPlay() override; | |
| 239 void OnMediaPlayerPause() override; | |
| 240 void OnRemoteRouteAvailabilityChanged(bool routes_available) override; | |
| 241 | |
| 242 // Getters of playback state. | |
| 243 // bool paused() const override; | |
| 244 | |
| 245 // True if the loaded media has a playable video track. | |
| 246 // bool hasVideo() const override; | |
| 247 | |
| 248 // This function is called by the RendererMediaPlayerManager to pause the | |
| 249 // video and release the media player and surface texture when we switch tabs. | |
| 250 // However, the actual GlTexture is not released to keep the video screenshot. | |
| 251 void ReleaseMediaResources() override; | |
| 252 | |
| 253 #if defined(VIDEO_HOLE) | |
| 254 // Calculate the boundary rectangle of the media player (i.e. location and | |
| 255 // size of the video frame). | |
| 256 // Returns true if the geometry has been changed since the last call. | |
| 257 bool UpdateBoundaryRectangle() override; | |
| 258 | |
| 259 const gfx::RectF GetBoundaryRectangle() override; | |
| 260 #endif | |
| 261 | |
| 262 void DrawRemotePlaybackText(const std::string& remote_playback_message); | |
| 263 #endif | |
| 264 | |
| 193 private: | 265 private: |
| 194 // Initiate suspending the pipeline. | 266 // Initiate suspending the pipeline. |
| 195 void Suspend(); | 267 void Suspend(); |
| 196 | 268 |
| 197 // Initiate resuming the pipeline. | 269 // Initiate resuming the pipeline. |
| 198 void Resume(); | 270 void Resume(); |
| 199 | 271 |
| 200 // Called after |defer_load_cb_| has decided to allow the load. If | 272 // Called after |defer_load_cb_| has decided to allow the load. If |
| 201 // |defer_load_cb_| is null this is called immediately. | 273 // |defer_load_cb_| is null this is called immediately. |
| 202 void DoLoad(LoadType load_type, | 274 void DoLoad(LoadType load_type, |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 235 // Returns the current video frame from |compositor_|. Blocks until the | 307 // Returns the current video frame from |compositor_|. Blocks until the |
| 236 // compositor can return the frame. | 308 // compositor can return the frame. |
| 237 scoped_refptr<VideoFrame> GetCurrentFrameFromCompositor(); | 309 scoped_refptr<VideoFrame> GetCurrentFrameFromCompositor(); |
| 238 | 310 |
| 239 // Called when the demuxer encounters encrypted streams. | 311 // Called when the demuxer encounters encrypted streams. |
| 240 void OnEncryptedMediaInitData(EmeInitDataType init_data_type, | 312 void OnEncryptedMediaInitData(EmeInitDataType init_data_type, |
| 241 const std::vector<uint8_t>& init_data); | 313 const std::vector<uint8_t>& init_data); |
| 242 | 314 |
| 243 // Called when a decoder detects that the key needed to decrypt the stream | 315 // Called when a decoder detects that the key needed to decrypt the stream |
| 244 // is not available. | 316 // is not available. |
| 245 void OnWaitingForDecryptionKey(); | 317 void OnWaitingForDecryptionKey() override; |
| 246 | 318 |
| 247 // Sets |cdm_context| on the pipeline and fires |cdm_attached_cb| when done. | 319 // Sets |cdm_context| on the pipeline and fires |cdm_attached_cb| when done. |
| 248 // Parameter order is reversed for easy binding. | 320 // Parameter order is reversed for easy binding. |
| 249 void SetCdm(const CdmAttachedCB& cdm_attached_cb, CdmContext* cdm_context); | 321 void SetCdm(const CdmAttachedCB& cdm_attached_cb, CdmContext* cdm_context); |
| 250 | 322 |
| 251 // Called when a CDM has been attached to the |pipeline_|. | 323 // Called when a CDM has been attached to the |pipeline_|. |
| 252 void OnCdmAttached(bool success); | 324 void OnCdmAttached(bool success); |
| 253 | 325 |
| 254 // Updates |paused_time_| to the current media time with consideration for the | 326 // Updates |paused_time_| to the current media time with consideration for the |
| 255 // |ended_| state by clamping current time to duration upon |ended_|. | 327 // |ended_| state by clamping current time to duration upon |ended_|. |
| (...skipping 137 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 393 // The compositor layer for displaying the video content when using composited | 465 // The compositor layer for displaying the video content when using composited |
| 394 // playback. | 466 // playback. |
| 395 scoped_ptr<cc_blink::WebLayerImpl> video_weblayer_; | 467 scoped_ptr<cc_blink::WebLayerImpl> video_weblayer_; |
| 396 | 468 |
| 397 EncryptedMediaPlayerSupport encrypted_media_support_; | 469 EncryptedMediaPlayerSupport encrypted_media_support_; |
| 398 | 470 |
| 399 scoped_ptr<blink::WebContentDecryptionModuleResult> set_cdm_result_; | 471 scoped_ptr<blink::WebContentDecryptionModuleResult> set_cdm_result_; |
| 400 | 472 |
| 401 scoped_ptr<RendererFactory> renderer_factory_; | 473 scoped_ptr<RendererFactory> renderer_factory_; |
| 402 | 474 |
| 475 #if defined(WIMPI_CAST) | |
| 476 // Manages this object and delegates player calls to the browser process. | |
| 477 // Owned by RenderFrameImpl. | |
| 478 RendererMediaPlayerManagerInterface* player_manager_ = nullptr; | |
| 479 | |
| 480 // Player ID assigned by the |player_manager_|. | |
| 481 int player_id_; | |
| 482 | |
| 483 // Whether the browser is currently connected to a remote media player. | |
| 484 bool is_remote_ = false; | |
| 485 | |
| 486 // Last reported playout time. | |
| 487 base::TimeDelta remote_time_; | |
| 488 base::TimeTicks remote_time_at_; | |
| 489 | |
| 490 // Whether the media player has been initialized. | |
| 491 bool is_player_initialized_ = false; | |
| 492 #endif | |
| 493 | |
| 403 DISALLOW_COPY_AND_ASSIGN(WebMediaPlayerImpl); | 494 DISALLOW_COPY_AND_ASSIGN(WebMediaPlayerImpl); |
| 404 }; | 495 }; |
| 405 | 496 |
| 406 } // namespace media | 497 } // namespace media |
| 407 | 498 |
| 408 #endif // MEDIA_BLINK_WEBMEDIAPLAYER_IMPL_H_ | 499 #endif // MEDIA_BLINK_WEBMEDIAPLAYER_IMPL_H_ |
| OLD | NEW |