diff options
author | Robert Shih <robertshih@google.com> | 2015-08-04 18:07:44 -0700 |
---|---|---|
committer | Robert Shih <robertshih@google.com> | 2015-08-05 13:20:18 -0700 |
commit | 1a5c859016e743779e4db25855390b3ce523cd48 (patch) | |
tree | d457520647e05164e177ee0cdc96522733ae5bea /media/libmediaplayerservice/nuplayer/NuPlayerRenderer.cpp | |
parent | f09d59b9c03d3ac3523517ea587e7587e669b6a4 (diff) | |
download | frameworks_av-1a5c859016e743779e4db25855390b3ce523cd48.zip frameworks_av-1a5c859016e743779e4db25855390b3ce523cd48.tar.gz frameworks_av-1a5c859016e743779e4db25855390b3ce523cd48.tar.bz2 |
NuPlayer:seek handling on kWhatAudioTearDown
Restart from previous seek time on kWhatAudioTearDown if mRenderer
didn't supply a useful positionUs.
Bug: 22662968
Change-Id: Ic21957f676ba25fb92694f71093bed60b630390b
Diffstat (limited to 'media/libmediaplayerservice/nuplayer/NuPlayerRenderer.cpp')
-rw-r--r-- | media/libmediaplayerservice/nuplayer/NuPlayerRenderer.cpp | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/media/libmediaplayerservice/nuplayer/NuPlayerRenderer.cpp b/media/libmediaplayerservice/nuplayer/NuPlayerRenderer.cpp index e9f3799..2e0d0d3 100644 --- a/media/libmediaplayerservice/nuplayer/NuPlayerRenderer.cpp +++ b/media/libmediaplayerservice/nuplayer/NuPlayerRenderer.cpp @@ -1586,16 +1586,15 @@ void NuPlayer::Renderer::onAudioTearDown(AudioTearDownReason reason) { mAudioTornDown = true; int64_t currentPositionUs; - if (getCurrentPosition(¤tPositionUs) != OK) { - currentPositionUs = 0; + sp<AMessage> notify = mNotify->dup(); + if (getCurrentPosition(¤tPositionUs) == OK) { + notify->setInt64("positionUs", currentPositionUs); } mAudioSink->stop(); mAudioSink->flush(); - sp<AMessage> notify = mNotify->dup(); notify->setInt32("what", kWhatAudioTearDown); - notify->setInt64("positionUs", currentPositionUs); notify->setInt32("reason", reason); notify->post(); } |