| 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 "media/base/video_frame.h" | 10 #include "media/base/video_frame.h" |
| (...skipping 25 matching lines...) Expand all Loading... |
| 36 main_loop_(MessageLoop::current()), | 36 main_loop_(MessageLoop::current()), |
| 37 pending_seek_(0), | 37 pending_seek_(0), |
| 38 seeking_(false), | 38 seeking_(false), |
| 39 did_loading_progress_(false), | 39 did_loading_progress_(false), |
| 40 manager_(manager), | 40 manager_(manager), |
| 41 network_state_(WebMediaPlayer::NetworkStateEmpty), | 41 network_state_(WebMediaPlayer::NetworkStateEmpty), |
| 42 ready_state_(WebMediaPlayer::ReadyStateHaveNothing), | 42 ready_state_(WebMediaPlayer::ReadyStateHaveNothing), |
| 43 is_playing_(false), | 43 is_playing_(false), |
| 44 needs_establish_peer_(true), | 44 needs_establish_peer_(true), |
| 45 has_size_info_(false), | 45 has_size_info_(false), |
| 46 is_in_video_view_(false), |
| 46 stream_texture_factory_(factory) { | 47 stream_texture_factory_(factory) { |
| 47 main_loop_->AddDestructionObserver(this); | 48 main_loop_->AddDestructionObserver(this); |
| 48 if (manager_) | 49 if (manager_) |
| 49 player_id_ = manager_->RegisterMediaPlayer(this); | 50 player_id_ = manager_->RegisterMediaPlayer(this); |
| 50 | 51 |
| 51 if (stream_texture_factory_.get()) { | 52 if (stream_texture_factory_.get()) { |
| 52 stream_texture_proxy_.reset(stream_texture_factory_->CreateProxy()); | 53 stream_texture_proxy_.reset(stream_texture_factory_->CreateProxy()); |
| 53 stream_id_ = stream_texture_factory_->CreateStreamTexture(&texture_id_); | 54 stream_id_ = stream_texture_factory_->CreateStreamTexture(&texture_id_); |
| 54 ReallocateVideoFrame(); | 55 ReallocateVideoFrame(); |
| 55 } | 56 } |
| (...skipping 317 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 373 stream_texture_factory_->DestroyStreamTexture(texture_id_); | 374 stream_texture_factory_->DestroyStreamTexture(texture_id_); |
| 374 stream_id_ = 0; | 375 stream_id_ = 0; |
| 375 } | 376 } |
| 376 | 377 |
| 377 video_frame_.reset(); | 378 video_frame_.reset(); |
| 378 | 379 |
| 379 manager_ = NULL; | 380 manager_ = NULL; |
| 380 } | 381 } |
| 381 | 382 |
| 382 void WebMediaPlayerAndroid::ReallocateVideoFrame() { | 383 void WebMediaPlayerAndroid::ReallocateVideoFrame() { |
| 383 if (texture_id_) { | 384 unsigned int texture_id = texture_id_; |
| 384 video_frame_.reset(new WebVideoFrameImpl(VideoFrame::WrapNativeTexture( | 385 if (is_in_video_view_) { |
| 385 texture_id_, kGLTextureExternalOES, natural_size_, | 386 texture_id = 0; |
| 386 gfx::Rect(natural_size_), natural_size_, base::TimeDelta(), | 387 } else if (texture_id_ == 0) { |
| 387 VideoFrame::ReadPixelsCB(), | 388 return; |
| 388 base::Closure()))); | |
| 389 } | 389 } |
| 390 video_frame_.reset(new WebVideoFrameImpl(VideoFrame::WrapNativeTexture( |
| 391 texture_id, kGLTextureExternalOES, natural_size_, |
| 392 gfx::Rect(natural_size_), natural_size_, base::TimeDelta(), |
| 393 VideoFrame::ReadPixelsCB(), |
| 394 base::Closure()))); |
| 390 } | 395 } |
| 391 | 396 |
| 392 WebVideoFrame* WebMediaPlayerAndroid::getCurrentFrame() { | 397 WebVideoFrame* WebMediaPlayerAndroid::getCurrentFrame() { |
| 393 if (stream_texture_proxy_.get() && !stream_texture_proxy_->IsInitialized() | 398 if (stream_texture_proxy_.get() && !stream_texture_proxy_->IsInitialized() |
| 394 && stream_id_) { | 399 && stream_id_) { |
| 395 stream_texture_proxy_->Initialize( | 400 stream_texture_proxy_->Initialize( |
| 396 stream_id_, video_frame_->width(), video_frame_->height()); | 401 stream_id_, video_frame_->width(), video_frame_->height()); |
| 397 } | 402 } |
| 398 | 403 |
| 399 return video_frame_.get(); | 404 return video_frame_.get(); |
| (...skipping 12 matching lines...) Expand all Loading... |
| 412 void WebMediaPlayerAndroid::EstablishSurfaceTexturePeer() { | 417 void WebMediaPlayerAndroid::EstablishSurfaceTexturePeer() { |
| 413 if (stream_texture_factory_.get() && stream_id_) | 418 if (stream_texture_factory_.get() && stream_id_) |
| 414 stream_texture_factory_->EstablishPeer(stream_id_, player_id_); | 419 stream_texture_factory_->EstablishPeer(stream_id_, player_id_); |
| 415 needs_establish_peer_ = false; | 420 needs_establish_peer_ = false; |
| 416 } | 421 } |
| 417 | 422 |
| 418 void WebMediaPlayerAndroid::SetNeedsEstablishPeer(bool needs_establish_peer) { | 423 void WebMediaPlayerAndroid::SetNeedsEstablishPeer(bool needs_establish_peer) { |
| 419 needs_establish_peer_ = needs_establish_peer; | 424 needs_establish_peer_ = needs_establish_peer; |
| 420 } | 425 } |
| 421 | 426 |
| 427 void WebMediaPlayerAndroid::SetIsInVideoView(bool is_in_video_view) { |
| 428 is_in_video_view_ = is_in_video_view;; |
| 429 ReallocateVideoFrame(); |
| 430 } |
| 431 |
| 422 void WebMediaPlayerAndroid::UpdatePlayingState(bool is_playing) { | 432 void WebMediaPlayerAndroid::UpdatePlayingState(bool is_playing) { |
| 423 is_playing_ = is_playing; | 433 is_playing_ = is_playing; |
| 424 } | 434 } |
| 425 | 435 |
| 426 } // namespace webkit_media | 436 } // namespace webkit_media |
| OLD | NEW |