summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Andrei Popescu <andreip@google.com> 2010-04-14 10:26:58 -0700
committer Android (Google) Code Review <android-gerrit@google.com> 2010-04-14 10:26:58 -0700
commit01e3feaf54ce6ef2ad4b9fc30f602bafd99cf412 (patch)
treee41d1210adbec9d13fd07e634d6cb87aad260854
parent8656145e2abe881caffa4181ee5c2e4e3dba1cee (diff)
parentc4fbceb57bcfbabb6e370e2dd6448184dc116015 (diff)
Merge "Make sure the onended event is dispatched even when the user dismisses the video before it plays to completion." into froyo
-rw-r--r--core/java/android/webkit/HTML5VideoViewProxy.java12
1 files changed, 7 insertions, 5 deletions
diff --git a/core/java/android/webkit/HTML5VideoViewProxy.java b/core/java/android/webkit/HTML5VideoViewProxy.java
index eee80251fd5d..eda2e72af376 100644
--- a/core/java/android/webkit/HTML5VideoViewProxy.java
+++ b/core/java/android/webkit/HTML5VideoViewProxy.java
@@ -132,6 +132,7 @@ class HTML5VideoViewProxy extends Handler
if (mVideoView.isPlaying()) {
mVideoView.stopPlayback();
}
+ mCurrentProxy.dispatchOnEnded();
mCurrentProxy = null;
mLayout.removeView(mVideoView);
mVideoView = null;
@@ -154,7 +155,7 @@ class HTML5VideoViewProxy extends Handler
if (mCurrentProxy != null) {
// Some other video is already playing. Notify the caller that its playback ended.
- proxy.playbackEnded();
+ proxy.dispatchOnEnded();
return;
}
@@ -245,7 +246,10 @@ class HTML5VideoViewProxy extends Handler
// MediaPlayer.OnCompletionListener;
public void onCompletion(MediaPlayer mp) {
- playbackEnded();
+ // The video ended by itself, so we need to
+ // send a message to the UI thread to dismiss
+ // the video view and to return to the WebView.
+ sendMessage(obtainMessage(ENDED));
}
// MediaPlayer.OnErrorListener
@@ -254,11 +258,9 @@ class HTML5VideoViewProxy extends Handler
return false;
}
- public void playbackEnded() {
+ public void dispatchOnEnded() {
Message msg = Message.obtain(mWebCoreHandler, ENDED);
mWebCoreHandler.sendMessage(msg);
- // also send a message to ourselves to return to the WebView
- sendMessage(obtainMessage(ENDED));
}
public void onTimeupdate() {