Chromium Code Reviews| 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 #include "webkit/media/android/webmediaplayer_android.h" | 5 #include "webkit/media/android/webmediaplayer_android.h" |
| 6 | 6 |
| 7 #include "base/file_path.h" | 7 #include "base/file_path.h" |
| 8 #include "base/logging.h" | 8 #include "base/logging.h" |
| 9 #include "media/base/android/media_player_bridge.h" | 9 #include "media/base/android/media_player_bridge.h" |
| 10 #include "net/base/mime_util.h" | 10 #include "net/base/mime_util.h" |
| (...skipping 24 matching lines...) Expand all Loading... | |
| 35 main_loop_(MessageLoop::current()), | 35 main_loop_(MessageLoop::current()), |
| 36 pending_seek_(0), | 36 pending_seek_(0), |
| 37 seeking_(false), | 37 seeking_(false), |
| 38 did_loading_progress_(false), | 38 did_loading_progress_(false), |
| 39 manager_(manager), | 39 manager_(manager), |
| 40 network_state_(WebMediaPlayer::NetworkStateEmpty), | 40 network_state_(WebMediaPlayer::NetworkStateEmpty), |
| 41 ready_state_(WebMediaPlayer::ReadyStateHaveNothing), | 41 ready_state_(WebMediaPlayer::ReadyStateHaveNothing), |
| 42 is_playing_(false), | 42 is_playing_(false), |
| 43 needs_establish_peer_(true), | 43 needs_establish_peer_(true), |
| 44 has_size_info_(false), | 44 has_size_info_(false), |
| 45 is_in_video_view_(false), | |
| 45 stream_texture_factory_(factory) { | 46 stream_texture_factory_(factory) { |
| 46 main_loop_->AddDestructionObserver(this); | 47 main_loop_->AddDestructionObserver(this); |
| 47 if (manager_) | 48 if (manager_) |
| 48 player_id_ = manager_->RegisterMediaPlayer(this); | 49 player_id_ = manager_->RegisterMediaPlayer(this); |
| 49 | 50 |
| 50 if (stream_texture_factory_.get()) { | 51 if (stream_texture_factory_.get()) { |
| 51 stream_texture_proxy_.reset(stream_texture_factory_->CreateProxy()); | 52 stream_texture_proxy_.reset(stream_texture_factory_->CreateProxy()); |
| 52 stream_id_ = stream_texture_factory_->CreateStreamTexture(&texture_id_); | 53 stream_id_ = stream_texture_factory_->CreateStreamTexture(&texture_id_); |
| 53 ReallocateVideoFrame(); | 54 ReallocateVideoFrame(); |
| 54 } | 55 } |
| (...skipping 314 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 369 video_frame_.reset(); | 370 video_frame_.reset(); |
| 370 | 371 |
| 371 if (manager_) | 372 if (manager_) |
| 372 manager_->UnregisterMediaPlayer(player_id_); | 373 manager_->UnregisterMediaPlayer(player_id_); |
| 373 | 374 |
| 374 manager_ = NULL; | 375 manager_ = NULL; |
| 375 main_loop_ = NULL; | 376 main_loop_ = NULL; |
| 376 } | 377 } |
| 377 | 378 |
| 378 void WebMediaPlayerAndroid::ReallocateVideoFrame() { | 379 void WebMediaPlayerAndroid::ReallocateVideoFrame() { |
| 379 if (texture_id_) { | 380 unsigned int texture_id = texture_id_; |
|
qinmin
2012/12/17 19:34:06
you also want to change the ctor of this class, to
wonsik2
2013/02/14 14:56:38
I think it might make sense to support them both a
| |
| 380 video_frame_.reset(new WebVideoFrameImpl(VideoFrame::WrapNativeTexture( | 381 if (is_in_video_view_) { |
| 381 texture_id_, kGLTextureExternalOES, natural_size_, | 382 texture_id = 0; |
| 382 gfx::Rect(natural_size_), natural_size_, base::TimeDelta(), | 383 } else if (texture_id_ == 0) { |
| 383 VideoFrame::ReadPixelsCB(), | 384 return; |
| 384 base::Closure()))); | |
| 385 } | 385 } |
| 386 video_frame_.reset(new WebVideoFrameImpl(VideoFrame::WrapNativeTexture( | |
| 387 texture_id, kGLTextureExternalOES, natural_size_, | |
| 388 gfx::Rect(natural_size_), natural_size_, base::TimeDelta(), | |
| 389 VideoFrame::ReadPixelsCB(), | |
| 390 base::Closure()))); | |
| 386 } | 391 } |
| 387 | 392 |
| 388 WebVideoFrame* WebMediaPlayerAndroid::getCurrentFrame() { | 393 WebVideoFrame* WebMediaPlayerAndroid::getCurrentFrame() { |
| 389 if (stream_texture_proxy_.get() && !stream_texture_proxy_->IsInitialized() | 394 if (stream_texture_proxy_.get() && !stream_texture_proxy_->IsInitialized() |
| 390 && stream_id_) { | 395 && stream_id_) { |
| 391 stream_texture_proxy_->Initialize( | 396 stream_texture_proxy_->Initialize( |
| 392 stream_id_, video_frame_->width(), video_frame_->height()); | 397 stream_id_, video_frame_->width(), video_frame_->height()); |
| 393 } | 398 } |
| 394 | 399 |
| 395 return video_frame_.get(); | 400 return video_frame_.get(); |
| (...skipping 12 matching lines...) Expand all Loading... | |
| 408 void WebMediaPlayerAndroid::EstablishSurfaceTexturePeer() { | 413 void WebMediaPlayerAndroid::EstablishSurfaceTexturePeer() { |
| 409 if (stream_texture_factory_.get() && stream_id_) | 414 if (stream_texture_factory_.get() && stream_id_) |
| 410 stream_texture_factory_->EstablishPeer(stream_id_, player_id_); | 415 stream_texture_factory_->EstablishPeer(stream_id_, player_id_); |
| 411 needs_establish_peer_ = false; | 416 needs_establish_peer_ = false; |
| 412 } | 417 } |
| 413 | 418 |
| 414 void WebMediaPlayerAndroid::SetNeedsEstablishPeer(bool needs_establish_peer) { | 419 void WebMediaPlayerAndroid::SetNeedsEstablishPeer(bool needs_establish_peer) { |
| 415 needs_establish_peer_ = needs_establish_peer; | 420 needs_establish_peer_ = needs_establish_peer; |
| 416 } | 421 } |
| 417 | 422 |
| 423 void WebMediaPlayerAndroid::SetIsInVideoView(bool is_in_video_view) { | |
| 424 is_in_video_view_ = is_in_video_view;; | |
| 425 ReallocateVideoFrame(); | |
| 426 } | |
| 427 | |
| 418 void WebMediaPlayerAndroid::UpdatePlayingState(bool is_playing) { | 428 void WebMediaPlayerAndroid::UpdatePlayingState(bool is_playing) { |
| 419 is_playing_ = is_playing; | 429 is_playing_ = is_playing; |
| 420 } | 430 } |
| 421 | 431 |
| 422 } // namespace webkit_media | 432 } // namespace webkit_media |
| OLD | NEW |