| Index: webkit/media/android/webmediaplayer_android.cc
|
| diff --git a/webkit/media/android/webmediaplayer_android.cc b/webkit/media/android/webmediaplayer_android.cc
|
| index faaadaf79731cebeadb3c1947b04d0003aa3bea2..08e4598044823f83ae301d486847fe81b9f01f9d 100644
|
| --- a/webkit/media/android/webmediaplayer_android.cc
|
| +++ b/webkit/media/android/webmediaplayer_android.cc
|
| @@ -63,7 +63,8 @@ WebMediaPlayerAndroid::WebMediaPlayerAndroid(
|
| client_(client),
|
| buffered_(1u),
|
| video_frame_(new WebVideoFrameImpl(VideoFrame::CreateEmptyFrame())),
|
| - proxy_(new WebMediaPlayerProxyAndroid(base::MessageLoopProxy::current(),
|
| + main_loop_(MessageLoop::current()),
|
| + proxy_(new WebMediaPlayerProxyAndroid(main_loop_->message_loop_proxy(),
|
| AsWeakPtr())),
|
| prepared_(false),
|
| duration_(0),
|
| @@ -81,17 +82,19 @@ WebMediaPlayerAndroid::WebMediaPlayerAndroid(
|
| stream_id_(0),
|
| needs_establish_peer_(true),
|
| stream_texture_factory_(factory) {
|
| - player_id_ = manager_->RegisterMediaPlayer(this);
|
| + main_loop_->AddDestructionObserver(this);
|
| + if (manager_)
|
| + player_id_ = manager_->RegisterMediaPlayer(this);
|
| if (stream_texture_factory_.get())
|
| stream_texture_proxy_.reset(stream_texture_factory_->CreateProxy());
|
| }
|
|
|
| WebMediaPlayerAndroid::~WebMediaPlayerAndroid() {
|
| - if (media_player_.get()) {
|
| - media_player_->Stop();
|
| - }
|
| + if (manager_)
|
| + manager_->UnregisterMediaPlayer(player_id_);
|
|
|
| - manager_->UnregisterMediaPlayer(player_id_);
|
| + if (main_loop_)
|
| + main_loop_->RemoveDestructionObserver(this);
|
| }
|
|
|
| void WebMediaPlayerAndroid::InitIncognito(bool incognito_mode) {
|
| @@ -473,6 +476,10 @@ void WebMediaPlayerAndroid::ReleaseMediaResources() {
|
| prepared_ = false;
|
| }
|
|
|
| +bool WebMediaPlayerAndroid::IsInitialized() const {
|
| + return (media_player_ != NULL);
|
| +}
|
| +
|
| void WebMediaPlayerAndroid::InitializeMediaPlayer() {
|
| CHECK(!media_player_.get());
|
| prepared_ = false;
|
| @@ -486,6 +493,9 @@ void WebMediaPlayerAndroid::InitializeMediaPlayer() {
|
| }
|
| media_player_->SetDataSource(url_.spec(), cookies, incognito_mode_);
|
|
|
| + if (manager_)
|
| + manager_->RequestMediaResources(player_id_);
|
| +
|
| media_player_->Prepare(
|
| base::Bind(&WebMediaPlayerProxyAndroid::MediaInfoCallback, proxy_),
|
| base::Bind(&WebMediaPlayerProxyAndroid::MediaErrorCallback, proxy_),
|
| @@ -548,6 +558,11 @@ void WebMediaPlayerAndroid::DestroyStreamTexture() {
|
| stream_id_ = 0;
|
| }
|
|
|
| +void WebMediaPlayerAndroid::WillDestroyCurrentMessageLoop() {
|
| + manager_ = NULL;
|
| + main_loop_ = NULL;
|
| +}
|
| +
|
| WebVideoFrame* WebMediaPlayerAndroid::getCurrentFrame() {
|
| if (!stream_texture_proxy_->IsInitialized() && stream_id_) {
|
| stream_texture_proxy_->Initialize(
|
|
|