diff options
author | scherkus@chromium.org <scherkus@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-10-23 00:56:24 +0000 |
---|---|---|
committer | scherkus@chromium.org <scherkus@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-10-23 00:56:24 +0000 |
commit | f467d03becdffdd9862dacb1feec243781f24952 (patch) | |
tree | 8982da1095ecdcf92a4c8ada323b208d32211f0b /webkit | |
parent | 645e51066961549cb2bf9ff00d141d2a46a9bb7d (diff) | |
download | chromium_src-f467d03becdffdd9862dacb1feec243781f24952.zip chromium_src-f467d03becdffdd9862dacb1feec243781f24952.tar.gz chromium_src-f467d03becdffdd9862dacb1feec243781f24952.tar.bz2 |
Use a saved copy of the time when pausing media elements.
Since our internal pause is asynchronous and we don't want to hang the render thread, it's possible to have our clock creep ahead. This produces unexpected behaviour when pausing media elements, such as seeing currentTime attribute nudge a little ahead after calling pause().
This so happens to also address layout test flakiness.
BUG=13907
TEST=layout tests, especially video-pause-immediately.html -- a new layout test I wrote and am upstreaming
Review URL: http://codereview.chromium.org/334002
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@29851 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit')
-rw-r--r-- | webkit/glue/webmediaplayer_impl.cc | 4 | ||||
-rw-r--r-- | webkit/glue/webmediaplayer_impl.h | 7 |
2 files changed, 11 insertions, 0 deletions
diff --git a/webkit/glue/webmediaplayer_impl.cc b/webkit/glue/webmediaplayer_impl.cc index 7e551b9..12bf8b8 100644 --- a/webkit/glue/webmediaplayer_impl.cc +++ b/webkit/glue/webmediaplayer_impl.cc @@ -260,6 +260,7 @@ void WebMediaPlayerImpl::pause() { paused_ = true; pipeline_->SetPlaybackRate(0.0f); + paused_time_ = pipeline_->GetCurrentTime(); } bool WebMediaPlayerImpl::supportsFullscreen() const { @@ -398,6 +399,9 @@ float WebMediaPlayerImpl::duration() const { float WebMediaPlayerImpl::currentTime() const { DCHECK(MessageLoop::current() == main_loop_); + if (paused_) { + return static_cast<float>(paused_time_.InSecondsF()); + } return static_cast<float>(pipeline_->GetCurrentTime().InSecondsF()); } diff --git a/webkit/glue/webmediaplayer_impl.h b/webkit/glue/webmediaplayer_impl.h index 5c5de44..97c4d89 100644 --- a/webkit/glue/webmediaplayer_impl.h +++ b/webkit/glue/webmediaplayer_impl.h @@ -271,8 +271,15 @@ class WebMediaPlayerImpl : public WebKit::WebMediaPlayer, // single "playback rate" over worrying about paused/stopped etc... It forces // all clients to manage the pause+playback rate externally, but is that // really a bad thing? + // + // TODO(scherkus): since SetPlaybackRate(0) is asynchronous and we don't want + // to hang the render thread during pause(), we record the time at the same + // time we pause and then return that value in currentTime(). Otherwise our + // clock can creep forward a little bit while the asynchronous + // SetPlaybackRate(0) is being executed. bool paused_; float playback_rate_; + base::TimeDelta paused_time_; WebKit::WebMediaPlayerClient* client_; |