summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorscherkus@chromium.org <scherkus@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-02-04 20:27:51 +0000
committerscherkus@chromium.org <scherkus@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-02-04 20:27:51 +0000
commitb781e774ae4f5d579c8e9122ea9baafb1f54261a (patch)
tree45803ff01ad1c2d2cc9dd0909e8868a5344378f7
parenta0366a518fb5883c6fcd455c60257046899c44b7 (diff)
downloadchromium_src-b781e774ae4f5d579c8e9122ea9baafb1f54261a.zip
chromium_src-b781e774ae4f5d579c8e9122ea9baafb1f54261a.tar.gz
chromium_src-b781e774ae4f5d579c8e9122ea9baafb1f54261a.tar.bz2
Fix frame accurate seeking for the third time.
Turns out we need to do an integer round to paper over floating point issues. Refer to discussion on https://bugs.webkit.org/show_bug.cgi?id=52697 for details. BUG=69499 TEST=layout test in linked bug Review URL: http://codereview.chromium.org/6250137 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@73838 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--webkit/glue/webmediaplayer_impl.cc26
1 files changed, 21 insertions, 5 deletions
diff --git a/webkit/glue/webmediaplayer_impl.cc b/webkit/glue/webmediaplayer_impl.cc
index b9df79d..9d51910 100644
--- a/webkit/glue/webmediaplayer_impl.cc
+++ b/webkit/glue/webmediaplayer_impl.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Copyright (c) 2011 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
@@ -59,6 +59,25 @@ const int kMaxOutstandingRepaints = 50;
const float kMinRate = 0.0625f;
const float kMaxRate = 16.0f;
+// Platform independent method for converting and rounding floating point
+// seconds to an int64 timestamp.
+//
+// Refer to https://bugs.webkit.org/show_bug.cgi?id=52697 for details.
+base::TimeDelta ConvertSecondsToTimestamp(float seconds) {
+ float microseconds = seconds * base::Time::kMicrosecondsPerSecond;
+ float integer = ceilf(microseconds);
+ float difference = integer - microseconds;
+
+ // Round down if difference is large enough.
+ if ((microseconds > 0 && difference > 0.5f) ||
+ (microseconds <= 0 && difference >= 0.5f)) {
+ integer -= 1.0f;
+ }
+
+ // Now we can safely cast to int64 microseconds.
+ return base::TimeDelta::FromMicroseconds(static_cast<int64>(integer));
+}
+
} // namespace
namespace webkit_glue {
@@ -374,10 +393,7 @@ void WebMediaPlayerImpl::seek(float seconds) {
return;
}
- // Try to preserve as much accuracy as possible.
- float microseconds = seconds * base::Time::kMicrosecondsPerSecond;
- base::TimeDelta seek_time =
- base::TimeDelta::FromMicroseconds(static_cast<int64>(microseconds));
+ base::TimeDelta seek_time = ConvertSecondsToTimestamp(seconds);
// Update our paused time.
if (paused_) {