AwesomePlayer.cpp revision fd4a8e09a54469bbccea6248f84319a1eb78765e
1bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber/* 2bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * Copyright (C) 2009 The Android Open Source Project 3bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * 4bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * Licensed under the Apache License, Version 2.0 (the "License"); 5bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * you may not use this file except in compliance with the License. 6bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * You may obtain a copy of the License at 7bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * 8bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * http://www.apache.org/licenses/LICENSE-2.0 9bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * 10bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * Unless required by applicable law or agreed to in writing, software 11bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * distributed under the License is distributed on an "AS IS" BASIS, 12bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * See the License for the specific language governing permissions and 14bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber * limitations under the License. 15bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber */ 16bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 17bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber//#define LOG_NDEBUG 0 18bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#define LOG_TAG "AwesomePlayer" 19bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <utils/Log.h> 20bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 21bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include "include/AwesomePlayer.h" 22bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 234844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber#include <binder/IPCThreadState.h> 24bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <media/stagefright/AudioPlayer.h> 25bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <media/stagefright/DataSource.h> 26bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <media/stagefright/FileSource.h> 27bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <media/stagefright/MediaBuffer.h> 28bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <media/stagefright/MediaExtractor.h> 29bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <media/stagefright/MediaDebug.h> 30bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <media/stagefright/MediaSource.h> 31bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <media/stagefright/MetaData.h> 32bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber#include <media/stagefright/OMXCodec.h> 33bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 34bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubernamespace android { 35bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 36bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstruct AwesomeEvent : public TimedEventQueue::Event { 37bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber AwesomeEvent(AwesomePlayer *player, int32_t code) 38bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber : mPlayer(player), 39bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mCode(code) { 40bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 41bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 42bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberprotected: 43bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber virtual ~AwesomeEvent() {} 44bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 45bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber virtual void fire(TimedEventQueue *queue, int64_t /* now_us */) { 46bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mPlayer->onEvent(mCode); 47bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 48bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 49bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberprivate: 50bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber AwesomePlayer *mPlayer; 51bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int32_t mCode; 52bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 53bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber AwesomeEvent(const AwesomeEvent &); 54bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber AwesomeEvent &operator=(const AwesomeEvent &); 55bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber}; 56bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 57bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas HuberAwesomePlayer::AwesomePlayer() 58bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber : mTimeSource(NULL), 59bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer(NULL), 60bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer(NULL), 61bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer(NULL) { 62bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK_EQ(mClient.connect(), OK); 63bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 64bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber DataSource::RegisterDefaultSniffers(); 65bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 66bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoEvent = new AwesomeEvent(this, 0); 67bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoEventPending = false; 68bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mStreamDoneEvent = new AwesomeEvent(this, 1); 69bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mStreamDoneEventPending = false; 70bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 71bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mQueue.start(); 72bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 73bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber reset(); 74bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 75bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 76bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas HuberAwesomePlayer::~AwesomePlayer() { 77bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mQueue.stop(); 78bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 79bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber reset(); 80bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 81bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mClient.disconnect(); 82bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 83bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 84bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::cancelPlayerEvents() { 85bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mQueue.cancelEvent(mVideoEvent->eventID()); 86bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoEventPending = false; 87bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mQueue.cancelEvent(mStreamDoneEvent->eventID()); 88bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mStreamDoneEventPending = false; 89bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 90bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 91bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::setListener(const sp<MediaPlayerBase> &listener) { 92bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 93bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mListener = listener; 94bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 95bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 96bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::setDataSource(const char *uri) { 97bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 98bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 99bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber reset_l(); 100bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 101bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber sp<MediaExtractor> extractor = MediaExtractor::CreateFromURI(uri); 102bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 103bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (extractor == NULL) { 104bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return UNKNOWN_ERROR; 105bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 106bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 107bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return setDataSource_l(extractor); 108bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 109bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 110bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::setDataSource( 111bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int fd, int64_t offset, int64_t length) { 112bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 113bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 114bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber reset_l(); 115bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 116bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber sp<DataSource> source = new FileSource(fd, offset, length); 117bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 118bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber status_t err = source->initCheck(); 119bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 120bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (err != OK) { 121bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return err; 122bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 123bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 124bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber sp<MediaExtractor> extractor = MediaExtractor::Create(source); 125bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 126bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (extractor == NULL) { 127bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return UNKNOWN_ERROR; 128bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 129bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 130bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return setDataSource_l(extractor); 131bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 132bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 133bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::setDataSource_l(const sp<MediaExtractor> &extractor) { 134bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber reset_l(); 135bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 136bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber bool haveAudio = false; 137bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber bool haveVideo = false; 138bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber for (size_t i = 0; i < extractor->countTracks(); ++i) { 139bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber sp<MetaData> meta = extractor->getTrackMetaData(i); 140bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 141bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber const char *mime; 142bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(meta->findCString(kKeyMIMEType, &mime)); 143bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 144bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (!haveVideo && !strncasecmp(mime, "video/", 6)) { 145bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (setVideoSource(extractor->getTrack(i)) == OK) { 146bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber haveVideo = true; 147bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 148bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } else if (!haveAudio && !strncasecmp(mime, "audio/", 6)) { 149bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (setAudioSource(extractor->getTrack(i)) == OK) { 150bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber haveAudio = true; 151bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 152bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 153bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 154bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (haveAudio && haveVideo) { 155bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber break; 156bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 157bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 158bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 159bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return !haveAudio && !haveVideo ? UNKNOWN_ERROR : OK; 160bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 161bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 162bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::reset() { 163bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 164bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber reset_l(); 165bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 166bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 167bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::reset_l() { 168bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber cancelPlayerEvents(); 169bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 170bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mLastVideoBuffer) { 171bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer->release(); 172bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer = NULL; 173bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 174bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 175bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoBuffer) { 176bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer->release(); 177bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer = NULL; 178bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 179bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 180bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoSource != NULL) { 181bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoSource->stop(); 182bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoSource.clear(); 183bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 184bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 185bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioSource.clear(); 186bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 187bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mTimeSource != mAudioPlayer) { 188bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber delete mTimeSource; 189bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 190bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mTimeSource = NULL; 191bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 192bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber delete mAudioPlayer; 193bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer = NULL; 194bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 195bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoRenderer.clear(); 196bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 197bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mDurationUs = -1; 198bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags = 0; 199bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoWidth = mVideoHeight = -1; 200bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mTimeSourceDeltaUs = 0; 201bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoTimeUs = 0; 202bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 203bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mSeeking = false; 204bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mSeekTimeUs = 0; 205bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 206bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 207bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber// static 208bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::AudioNotify(void *_me, int what) { 209bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber AwesomePlayer *me = (AwesomePlayer *)_me; 210bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 211bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(me->mLock); 212bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 213bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber switch (what) { 214bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber case AudioPlayer::REACHED_EOS: 215bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber me->postStreamDoneEvent_l(); 216bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber break; 217bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 218bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber case AudioPlayer::SEEK_COMPLETE: 219bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber { 220bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (me->mListener != NULL) { 221bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber me->mListener->sendEvent(MEDIA_SEEK_COMPLETE); 222bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 223bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 224bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber break; 225bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 226bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 227bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber default: 228bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(!"should not be here."); 229bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber break; 230bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 231bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 232bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 233bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::onStreamDone() { 234bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber // Posted whenever any stream finishes playing. 235bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 236bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 237bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mStreamDoneEventPending = false; 238bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 239bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mFlags & LOOPING) { 240bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber seekTo_l(0); 241bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 242bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoRenderer != NULL) { 243bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber postVideoEvent_l(); 244bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 245bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } else { 246bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mListener != NULL) { 247bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mListener->sendEvent(MEDIA_PLAYBACK_COMPLETE); 248bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 249bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 250bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber pause_l(); 251bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 252bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 253bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 254bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::play() { 255bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 256bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 257bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mFlags & PLAYING) { 258bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 259bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 260bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 261bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags |= PLAYING; 262bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags |= FIRST_FRAME; 263bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 264fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber bool deferredAudioSeek = false; 265fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber 266bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioSource != NULL) { 267bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioPlayer == NULL) { 268bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioSink != NULL) { 269bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer = new AudioPlayer(mAudioSink); 270bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 271bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer->setListenerCallback( 272bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber &AwesomePlayer::AudioNotify, this); 273bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 274bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer->setSource(mAudioSource); 275bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer->start(); 276bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 277bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber delete mTimeSource; 278bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mTimeSource = mAudioPlayer; 279bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 280fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber deferredAudioSeek = true; 281bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 282bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } else { 283bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer->resume(); 284bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 285bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 286bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 287bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mTimeSource == NULL && mAudioPlayer == NULL) { 288bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mTimeSource = new SystemTimeSource; 289bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 290bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 291bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoSource != NULL) { 292bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoRenderer == NULL) { 293bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber initRenderer_l(); 294bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 295bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 296bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoRenderer != NULL) { 297bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber // Kick off video playback 298bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber postVideoEvent_l(); 299bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 300bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 301bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 302fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber if (deferredAudioSeek) { 303fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber // If there was a seek request while we were paused 304fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber // and we're just starting up again, honor the request now. 305fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber seekAudioIfNecessary_l(); 306fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber } 307fd4a8e09a54469bbccea6248f84319a1eb78765eAndreas Huber 308bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 309bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 310bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 311bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::initRenderer_l() { 312bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mISurface != NULL) { 313bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber sp<MetaData> meta = mVideoSource->getFormat(); 314bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 315bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int32_t format; 316bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber const char *component; 317bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int32_t decodedWidth, decodedHeight; 318bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(meta->findInt32(kKeyColorFormat, &format)); 319bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(meta->findCString(kKeyDecoderComponent, &component)); 320bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(meta->findInt32(kKeyWidth, &decodedWidth)); 321bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(meta->findInt32(kKeyHeight, &decodedHeight)); 322bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 3234844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber mVideoRenderer.clear(); 3244844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber 3254844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber // Must ensure that mVideoRenderer's destructor is actually executed 3264844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber // before creating a new one. 3274844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber IPCThreadState::self()->flushCommands(); 3284844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber 329bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoRenderer = 330bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mClient.interface()->createRenderer( 331bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mISurface, component, 332bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber (OMX_COLOR_FORMATTYPE)format, 333bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber decodedWidth, decodedHeight, 334bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoWidth, mVideoHeight); 335bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 336bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 337bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 338bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::pause() { 339bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 340bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return pause_l(); 341bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 342bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 343bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::pause_l() { 344bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (!(mFlags & PLAYING)) { 345bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 346bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 347bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 348bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber cancelPlayerEvents(); 349bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 350bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioPlayer != NULL) { 351bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer->pause(); 352bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 353bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 354bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags &= ~PLAYING; 355bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 356bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 357bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 358bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 359bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberbool AwesomePlayer::isPlaying() const { 360bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 361bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 362bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return mFlags & PLAYING; 363bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 364bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 365bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::setISurface(const sp<ISurface> &isurface) { 366bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 367bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 368bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mISurface = isurface; 369bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 370bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 371bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::setAudioSink( 372bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber const sp<MediaPlayerBase::AudioSink> &audioSink) { 373bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 374bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 375bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioSink = audioSink; 376bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 377bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 378bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::setLooping(bool shouldLoop) { 379bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 380bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 381bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags = mFlags & ~LOOPING; 382bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 383bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (shouldLoop) { 384bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags |= LOOPING; 385bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 386bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 387bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 388bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 389bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 390bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::getDuration(int64_t *durationUs) { 391bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 392bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 393bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mDurationUs < 0) { 394bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return UNKNOWN_ERROR; 395bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 396bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 397bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber *durationUs = mDurationUs; 398bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 399bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 400bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 401bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 402bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::getPosition(int64_t *positionUs) { 403bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 404bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 405bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoRenderer != NULL) { 406bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber *positionUs = mVideoTimeUs; 407bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } else if (mAudioPlayer != NULL) { 408bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber *positionUs = mAudioPlayer->getMediaTimeUs(); 409bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } else { 410bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber *positionUs = 0; 411bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 412bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 413bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 414bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 415bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 416bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::seekTo(int64_t timeUs) { 417bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 418bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return seekTo_l(timeUs); 419bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 420bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 421bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::seekTo_l(int64_t timeUs) { 422bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mSeeking = true; 423bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mSeekTimeUs = timeUs; 424bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 425bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber seekAudioIfNecessary_l(); 426bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 427bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 428bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 429bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 430bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::seekAudioIfNecessary_l() { 431bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mSeeking && mVideoRenderer == NULL && mAudioPlayer != NULL) { 432bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer->seekTo(mSeekTimeUs); 433bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 434bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mSeeking = false; 435bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 436bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 437bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 438bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::getVideoDimensions( 439bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int32_t *width, int32_t *height) const { 440bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 441bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 442bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoWidth < 0 || mVideoHeight < 0) { 443bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return UNKNOWN_ERROR; 444bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 445bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 446bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber *width = mVideoWidth; 447bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber *height = mVideoHeight; 448bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 449bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return OK; 450bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 451bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 452bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::setAudioSource(const sp<MediaSource> &source) { 453bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (source == NULL) { 454bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return UNKNOWN_ERROR; 455bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 456bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 457bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioSource = OMXCodec::Create( 458bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mClient.interface(), source->getFormat(), 459bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber false, // createEncoder 460bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber source); 461bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 462bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioSource != NULL) { 463bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int64_t durationUs; 464bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (source->getFormat()->findInt64(kKeyDuration, &durationUs)) { 465bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mDurationUs < 0 || durationUs > mDurationUs) { 466bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mDurationUs = durationUs; 467bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 468bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 469bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 470bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 471bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return mAudioSource != NULL ? OK : UNKNOWN_ERROR; 472bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 473bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 474bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huberstatus_t AwesomePlayer::setVideoSource(const sp<MediaSource> &source) { 475bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (source == NULL) { 476bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return UNKNOWN_ERROR; 477bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 478bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 479bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoSource = OMXCodec::Create( 480bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mClient.interface(), source->getFormat(), 481bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber false, // createEncoder 482bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber source); 483bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 484bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoSource != NULL) { 485bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int64_t durationUs; 486bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (source->getFormat()->findInt64(kKeyDuration, &durationUs)) { 487bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mDurationUs < 0 || durationUs > mDurationUs) { 488bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mDurationUs = durationUs; 489bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 490bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 491bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 492bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(source->getFormat()->findInt32(kKeyWidth, &mVideoWidth)); 493bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(source->getFormat()->findInt32(kKeyHeight, &mVideoHeight)); 494bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 495bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoSource->start(); 496bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 497bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 498bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return mVideoSource != NULL ? OK : UNKNOWN_ERROR; 499bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 500bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 501bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::onEvent(int32_t code) { 502bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (code == 1) { 503bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber onStreamDone(); 504bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return; 505bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 506bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 507bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber Mutex::Autolock autoLock(mLock); 508bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoEventPending = false; 509bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 510bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mSeeking) { 511bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mLastVideoBuffer) { 512bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer->release(); 513bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer = NULL; 514bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 515bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 516bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoBuffer) { 517bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer->release(); 518bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer = NULL; 519bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 520bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 521bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 522bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (!mVideoBuffer) { 523bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber MediaSource::ReadOptions options; 524bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mSeeking) { 525bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber LOGV("seeking to %lld us (%.2f secs)", mSeekTimeUs, mSeekTimeUs / 1E6); 526bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 527bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber options.setSeekTo(mSeekTimeUs); 528bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 529bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber for (;;) { 530bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber status_t err = mVideoSource->read(&mVideoBuffer, &options); 531bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 532bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (err != OK) { 533bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK_EQ(mVideoBuffer, NULL); 534bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 535bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (err == INFO_FORMAT_CHANGED) { 536bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber LOGV("VideoSource signalled format change."); 537bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 538bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber initRenderer_l(); 539bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber continue; 540bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 541bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 542bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber postStreamDoneEvent_l(); 543bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return; 544bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 545bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 5464844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber if (mVideoBuffer->range_length() == 0) { 5474844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber mVideoBuffer->release(); 5484844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber mVideoBuffer = NULL; 5494844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber continue; 5504844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber } 5514844ac54e8b5997c3b03872dbafe8ebed4787517Andreas Huber 552bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber break; 553bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 554bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 555bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 556bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int64_t timeUs; 557bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber CHECK(mVideoBuffer->meta_data()->findInt64(kKeyTime, &timeUs)); 558bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 559bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoTimeUs = timeUs; 560bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 561bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mSeeking) { 562bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioPlayer != NULL) { 563bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber LOGV("seeking audio to %lld us (%.2f secs).", timeUs, timeUs / 1E6); 564bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 565bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mAudioPlayer->seekTo(timeUs); 566bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } else { 567bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber // If we're playing video only, report seek complete now, 568bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber // otherwise audio player will notify us later. 569bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mListener != NULL) { 570bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mListener->sendEvent(MEDIA_SEEK_COMPLETE); 571bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 572bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 573bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 574bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags |= FIRST_FRAME; 575bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mSeeking = false; 576bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 577bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 578bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mFlags & FIRST_FRAME) { 579bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mFlags &= ~FIRST_FRAME; 580bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 581bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mTimeSourceDeltaUs = mTimeSource->getRealTimeUs() - timeUs; 582bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 583bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 584bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int64_t realTimeUs, mediaTimeUs; 585bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mAudioPlayer != NULL 586bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber && mAudioPlayer->getMediaTimeMapping(&realTimeUs, &mediaTimeUs)) { 587bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mTimeSourceDeltaUs = realTimeUs - mediaTimeUs; 588bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 589bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 590bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int64_t nowUs = mTimeSource->getRealTimeUs() - mTimeSourceDeltaUs; 591bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 592bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber int64_t latenessUs = nowUs - timeUs; 593bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 594650773d00356129ffd661cdaef3fb3095c343707Andreas Huber if (latenessUs > 40000) { 595650773d00356129ffd661cdaef3fb3095c343707Andreas Huber // We're more than 40ms late. 596650773d00356129ffd661cdaef3fb3095c343707Andreas Huber LOGI("we're late by %lld us (%.2f secs)", latenessUs, latenessUs / 1E6); 597bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 598bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer->release(); 599bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer = NULL; 600bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 601bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber postVideoEvent_l(); 602bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return; 603bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 604bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 605bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (latenessUs < -10000) { 606bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber // We're more than 10ms early. 607bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 608bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber postVideoEvent_l(10000); 609bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return; 610bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 611bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 612bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber void *id; 613bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoBuffer->meta_data()->findPointer(kKeyBufferID, &id)) { 614bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoRenderer->render((IOMX::buffer_id)id); 615bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 616bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 617bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mLastVideoBuffer) { 618bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer->release(); 619bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer = NULL; 620bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 621bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mLastVideoBuffer = mVideoBuffer; 622bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoBuffer = NULL; 623bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 624bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber postVideoEvent_l(); 625bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 626bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 627bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::postVideoEvent_l(int64_t delayUs) { 628bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mVideoEventPending) { 629bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return; 630bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 631bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 632bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mVideoEventPending = true; 633bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mQueue.postEventWithDelay(mVideoEvent, delayUs < 0 ? 10000 : delayUs); 634bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 635bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 636bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Hubervoid AwesomePlayer::postStreamDoneEvent_l() { 637bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber if (mStreamDoneEventPending) { 638bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber return; 639bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber } 640bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mStreamDoneEventPending = true; 641bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber mQueue.postEvent(mStreamDoneEvent); 642bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} 643bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 644bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber} // namespace android 645bfa6b2d7a1be1832ac40ed90aece1834f720b5c6Andreas Huber 646