summaryrefslogtreecommitdiffstats
path: root/media
diff options
context:
space:
mode:
authorAndreas Huber <andih@google.com>2010-10-29 15:47:52 -0700
committerAndreas Huber <andih@google.com>2010-11-30 11:46:38 -0800
commit09b3581ef7ddba70c5d89d252de3a15d512aa49b (patch)
tree0b199015fa3f564580355088031819c7b775069a /media
parent4d0565de200e61f457e4d97fcfbc4c9ccd81bdad (diff)
downloadframeworks_av-09b3581ef7ddba70c5d89d252de3a15d512aa49b.zip
frameworks_av-09b3581ef7ddba70c5d89d252de3a15d512aa49b.tar.gz
frameworks_av-09b3581ef7ddba70c5d89d252de3a15d512aa49b.tar.bz2
After seeking display the first new video frame right away without concern for A/V sync. This looks much more responsive to the user.
Change-Id: Ifb1f8c91e95a5cafe30ae1035973316c210b98a5 related-to-bug: 3152363
Diffstat (limited to 'media')
-rw-r--r--media/libstagefright/AwesomePlayer.cpp6
1 files changed, 6 insertions, 0 deletions
diff --git a/media/libstagefright/AwesomePlayer.cpp b/media/libstagefright/AwesomePlayer.cpp
index 5c423c0..08cf515 100644
--- a/media/libstagefright/AwesomePlayer.cpp
+++ b/media/libstagefright/AwesomePlayer.cpp
@@ -1248,6 +1248,7 @@ void AwesomePlayer::onVideoEvent() {
mVideoTimeUs = timeUs;
}
+ bool wasSeeking = mSeeking;
finishSeekIfNecessary(timeUs);
TimeSource *ts = (mFlags & AUDIO_AT_EOS) ? &mSystemTimeSource : mTimeSource;
@@ -1268,6 +1269,11 @@ void AwesomePlayer::onVideoEvent() {
int64_t latenessUs = nowUs - timeUs;
+ if (wasSeeking) {
+ // Let's display the first frame after seeking right away.
+ latenessUs = 0;
+ }
+
if (mRTPSession != NULL) {
// We'll completely ignore timestamps for gtalk videochat
// and we'll play incoming video as fast as we get it.