mediaplayer.cpp revision b483c4724846c0b8d4e82afcbb7c17f671bae81c
189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project/* mediaplayer.cpp 289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** 389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** Copyright 2006, The Android Open Source Project 489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** 589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** Licensed under the Apache License, Version 2.0 (the "License"); 689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** you may not use this file except in compliance with the License. 789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** You may obtain a copy of the License at 889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** 989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** http://www.apache.org/licenses/LICENSE-2.0 1089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** 1189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** Unless required by applicable law or agreed to in writing, software 1289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** distributed under the License is distributed on an "AS IS" BASIS, 1389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 1489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** See the License for the specific language governing permissions and 1589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project** limitations under the License. 1689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project*/ 1789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 1889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project//#define LOG_NDEBUG 0 1989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#define LOG_TAG "MediaPlayer" 2089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <utils/Log.h> 2189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 2289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <sys/types.h> 2389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <sys/stat.h> 2489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <unistd.h> 2589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <fcntl.h> 2689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 277562408b2261d38415453378b6188f74fda99d88Mathias Agopian#include <binder/IServiceManager.h> 287562408b2261d38415453378b6188f74fda99d88Mathias Agopian#include <binder/IPCThreadState.h> 2989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 3089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <media/mediaplayer.h> 3189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <media/AudioTrack.h> 3289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 333cf613507f1e2f7bd932d921a6e222e426fd3be4Mathias Agopian#include <surfaceflinger/Surface.h> 343cf613507f1e2f7bd932d921a6e222e426fd3be4Mathias Agopian 357562408b2261d38415453378b6188f74fda99d88Mathias Agopian#include <binder/MemoryBase.h> 3689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 372db8455d8f4468a637109d31f319ce02d9d743ecAndreas Huber#include <utils/KeyedVector.h> 382db8455d8f4468a637109d31f319ce02d9d743ecAndreas Huber#include <utils/String8.h> 392db8455d8f4468a637109d31f319ce02d9d743ecAndreas Huber 4089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectnamespace android { 4189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 4289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source ProjectMediaPlayer::MediaPlayer() 4389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 4489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("constructor"); 4589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mListener = NULL; 4689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCookie = NULL; 4789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mDuration = -1; 4889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mStreamType = AudioSystem::MUSIC; 4989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentPosition = -1; 5089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mSeekPosition = -1; 5189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_IDLE; 5289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPrepareSync = false; 5389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPrepareStatus = NO_ERROR; 5489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mLoop = false; 5589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mLeftVolume = mRightVolume = 1.0; 5689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mVideoWidth = mVideoHeight = 0; 571af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams mLockThreadId = 0; 58a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent mAudioSessionId = AudioSystem::newAudioSessionId(); 598c563ed9ca8a863a66965330b5d14bb4b4ab59d4Eric Laurent mSendLevel = 0; 6089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 6189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 6289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source ProjectMediaPlayer::~MediaPlayer() 6389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 6489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("destructor"); 6589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project disconnect(); 6689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project IPCThreadState::self()->flushCommands(); 6789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 6889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 6989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectvoid MediaPlayer::disconnect() 7089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 7189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("disconnect"); 7289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sp<IMediaPlayer> p; 7389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project { 7489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 7589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project p = mPlayer; 7689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPlayer.clear(); 7789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 7889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 7989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (p != 0) { 8089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project p->disconnect(); 8189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 8289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 8389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 8489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project// always call with lock held 8589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectvoid MediaPlayer::clear_l() 8689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 8789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mDuration = -1; 8889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentPosition = -1; 8989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mSeekPosition = -1; 9089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mVideoWidth = mVideoHeight = 0; 9189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 9289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 9389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::setListener(const sp<MediaPlayerListener>& listener) 9489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 9589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("setListener"); 9689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 9789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mListener = listener; 9889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return NO_ERROR; 9989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 10089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 10189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 10289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::setDataSource(const sp<IMediaPlayer>& player) 10389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 10489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project status_t err = UNKNOWN_ERROR; 10589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sp<IMediaPlayer> p; 10689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project { // scope for the lock 10789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 10889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 10983ff1438d2d1d5dbf39ca5e6f2e4fa1799e7ba80Marco Nelissen if ( !( (mCurrentState & MEDIA_PLAYER_IDLE) || 11083ff1438d2d1d5dbf39ca5e6f2e4fa1799e7ba80Marco Nelissen (mCurrentState == MEDIA_PLAYER_STATE_ERROR ) ) ) { 11189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("setDataSource called in state %d", mCurrentState); 11289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return INVALID_OPERATION; 11389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 11489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 11589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project clear_l(); 11689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project p = mPlayer; 11789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPlayer = player; 11889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (player != 0) { 11989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_INITIALIZED; 12089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project err = NO_ERROR; 12189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } else { 12289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("Unable to to create media player"); 12389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 12489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 12589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 12689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (p != 0) { 12789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project p->disconnect(); 12889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 12989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 13089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return err; 13189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 13289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 1332db8455d8f4468a637109d31f319ce02d9d743ecAndreas Huberstatus_t MediaPlayer::setDataSource( 1342db8455d8f4468a637109d31f319ce02d9d743ecAndreas Huber const char *url, const KeyedVector<String8, String8> *headers) 13589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 13689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("setDataSource(%s)", url); 13789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project status_t err = BAD_VALUE; 13889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (url != NULL) { 13989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project const sp<IMediaPlayerService>& service(getMediaPlayerService()); 14089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (service != 0) { 1412db8455d8f4468a637109d31f319ce02d9d743ecAndreas Huber sp<IMediaPlayer> player( 142a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent service->create(getpid(), this, url, headers, mAudioSessionId)); 14389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project err = setDataSource(player); 14489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 14589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 14689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return err; 14789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 14889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 14989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::setDataSource(int fd, int64_t offset, int64_t length) 15089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 15189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("setDataSource(%d, %lld, %lld)", fd, offset, length); 15289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project status_t err = UNKNOWN_ERROR; 15389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project const sp<IMediaPlayerService>& service(getMediaPlayerService()); 15489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (service != 0) { 155a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent sp<IMediaPlayer> player(service->create(getpid(), this, fd, offset, length, mAudioSessionId)); 15689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project err = setDataSource(player); 15789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 15889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return err; 15989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 16089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 1611d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Cataniastatus_t MediaPlayer::invoke(const Parcel& request, Parcel *reply) 1621d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania{ 1631d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania Mutex::Autolock _l(mLock); 1644023493a827bc9751d8e40795516d0d536a53348Nicolas Catania const bool hasBeenInitialized = 1654023493a827bc9751d8e40795516d0d536a53348Nicolas Catania (mCurrentState != MEDIA_PLAYER_STATE_ERROR) && 1664023493a827bc9751d8e40795516d0d536a53348Nicolas Catania ((mCurrentState & MEDIA_PLAYER_IDLE) != MEDIA_PLAYER_IDLE); 1674023493a827bc9751d8e40795516d0d536a53348Nicolas Catania if ((mPlayer != NULL) && hasBeenInitialized) { 1681d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania LOGV("invoke %d", request.dataSize()); 1691d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania return mPlayer->invoke(request, reply); 1701d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania } 1711d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania LOGE("invoke failed: wrong state %X", mCurrentState); 1721d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania return INVALID_OPERATION; 1731d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania} 1741d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania 175a7e0e8b4c429fc68eb1bd5b5a30f5b91352288f9Nicolas Cataniastatus_t MediaPlayer::setMetadataFilter(const Parcel& filter) 176a7e0e8b4c429fc68eb1bd5b5a30f5b91352288f9Nicolas Catania{ 177a7e0e8b4c429fc68eb1bd5b5a30f5b91352288f9Nicolas Catania LOGD("setMetadataFilter"); 1788e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania Mutex::Autolock lock(mLock); 1798e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania if (mPlayer == NULL) { 180a7e0e8b4c429fc68eb1bd5b5a30f5b91352288f9Nicolas Catania return NO_INIT; 181a7e0e8b4c429fc68eb1bd5b5a30f5b91352288f9Nicolas Catania } 182a7e0e8b4c429fc68eb1bd5b5a30f5b91352288f9Nicolas Catania return mPlayer->setMetadataFilter(filter); 183a7e0e8b4c429fc68eb1bd5b5a30f5b91352288f9Nicolas Catania} 1841d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania 1858e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Cataniastatus_t MediaPlayer::getMetadata(bool update_only, bool apply_filter, Parcel *metadata) 1868e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania{ 1878e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania LOGD("getMetadata"); 1888e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania Mutex::Autolock lock(mLock); 1898e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania if (mPlayer == NULL) { 1908e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania return NO_INIT; 1918e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania } 1928e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania return mPlayer->getMetadata(update_only, apply_filter, metadata); 1938e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania} 1948e1b6cce24574b9ecd5b0300155776bd0b4ef756Nicolas Catania 19589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::setVideoSurface(const sp<Surface>& surface) 19689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 19789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("setVideoSurface"); 19889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 19989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer == 0) return NO_INIT; 2005daeb129a2c2ba3d14ccd94af283b5f561c783eaAndreas Huber 2015daeb129a2c2ba3d14ccd94af283b5f561c783eaAndreas Huber return mPlayer->setVideoSurface(surface); 20289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 20389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 2041173118eace0e9e347cb007f0da817cee87579edGlenn Kastenstatus_t MediaPlayer::setVideoSurfaceTexture( 2051173118eace0e9e347cb007f0da817cee87579edGlenn Kasten const sp<ISurfaceTexture>& surfaceTexture) 2061173118eace0e9e347cb007f0da817cee87579edGlenn Kasten{ 2071173118eace0e9e347cb007f0da817cee87579edGlenn Kasten LOGV("setVideoSurfaceTexture"); 2081173118eace0e9e347cb007f0da817cee87579edGlenn Kasten Mutex::Autolock _l(mLock); 2091173118eace0e9e347cb007f0da817cee87579edGlenn Kasten if (mPlayer == 0) return NO_INIT; 2101173118eace0e9e347cb007f0da817cee87579edGlenn Kasten 2111173118eace0e9e347cb007f0da817cee87579edGlenn Kasten return mPlayer->setVideoSurfaceTexture(surfaceTexture); 2121173118eace0e9e347cb007f0da817cee87579edGlenn Kasten} 2131173118eace0e9e347cb007f0da817cee87579edGlenn Kasten 21489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project// must call with lock held 21589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::prepareAsync_l() 21689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 21789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if ( (mPlayer != 0) && ( mCurrentState & ( MEDIA_PLAYER_INITIALIZED | MEDIA_PLAYER_STOPPED) ) ) { 21889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPlayer->setAudioStreamType(mStreamType); 21989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_PREPARING; 22089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return mPlayer->prepareAsync(); 22189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 22289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("prepareAsync called in state %d", mCurrentState); 22389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return INVALID_OPERATION; 22489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 22589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 22665e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project// TODO: In case of error, prepareAsync provides the caller with 2 error codes, 22765e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project// one defined in the Android framework and one provided by the implementation 22865e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project// that generated the error. The sync version of prepare returns only 1 error 22965e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project// code. 23089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::prepare() 23189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 23289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("prepare"); 23389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 2341af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams mLockThreadId = getThreadId(); 2351af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams if (mPrepareSync) { 2361af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams mLockThreadId = 0; 2371af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams return -EALREADY; 2381af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams } 23989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPrepareSync = true; 24089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project status_t ret = prepareAsync_l(); 2411af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams if (ret != NO_ERROR) { 2421af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams mLockThreadId = 0; 2431af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams return ret; 2441af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams } 24589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 24689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPrepareSync) { 24789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mSignal.wait(mLock); // wait for prepare done 24889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPrepareSync = false; 24989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 25089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("prepare complete - status=%d", mPrepareStatus); 2511af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams mLockThreadId = 0; 25289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return mPrepareStatus; 25389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 25489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 25589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::prepareAsync() 25689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 25789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("prepareAsync"); 25889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 25989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return prepareAsync_l(); 26089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 26189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 26289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::start() 26389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 26489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("start"); 26589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 26689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mCurrentState & MEDIA_PLAYER_STARTED) 26789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return NO_ERROR; 26889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if ( (mPlayer != 0) && ( mCurrentState & ( MEDIA_PLAYER_PREPARED | 26989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project MEDIA_PLAYER_PLAYBACK_COMPLETE | MEDIA_PLAYER_PAUSED ) ) ) { 27089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPlayer->setLooping(mLoop); 27189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPlayer->setVolume(mLeftVolume, mRightVolume); 2722beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent mPlayer->setAuxEffectSendLevel(mSendLevel); 27389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_STARTED; 27489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project status_t ret = mPlayer->start(); 27589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (ret != NO_ERROR) { 27689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_STATE_ERROR; 27789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } else { 27889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mCurrentState == MEDIA_PLAYER_PLAYBACK_COMPLETE) { 27989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("playback completed immediately following start()"); 28089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 28189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 28289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return ret; 28389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 28489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("start called in state %d", mCurrentState); 28589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return INVALID_OPERATION; 28689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 28789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 28889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::stop() 28989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 29089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("stop"); 29189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 29289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mCurrentState & MEDIA_PLAYER_STOPPED) return NO_ERROR; 29389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if ( (mPlayer != 0) && ( mCurrentState & ( MEDIA_PLAYER_STARTED | MEDIA_PLAYER_PREPARED | 29489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project MEDIA_PLAYER_PAUSED | MEDIA_PLAYER_PLAYBACK_COMPLETE ) ) ) { 29589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project status_t ret = mPlayer->stop(); 29689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (ret != NO_ERROR) { 29789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_STATE_ERROR; 29889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } else { 29989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_STOPPED; 30089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 30189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return ret; 30289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 30389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("stop called in state %d", mCurrentState); 30489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return INVALID_OPERATION; 30589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 30689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 30789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::pause() 30889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 30989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("pause"); 31089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 311698f476590bc9e38d4d1d4155da9efdbedd357c4Marco Nelissen if (mCurrentState & (MEDIA_PLAYER_PAUSED|MEDIA_PLAYER_PLAYBACK_COMPLETE)) 31289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return NO_ERROR; 31389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if ((mPlayer != 0) && (mCurrentState & MEDIA_PLAYER_STARTED)) { 31489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project status_t ret = mPlayer->pause(); 31589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (ret != NO_ERROR) { 31689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_STATE_ERROR; 31789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } else { 31889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_PAUSED; 31989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 32089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return ret; 32189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 32289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("pause called in state %d", mCurrentState); 32389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return INVALID_OPERATION; 32489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 32589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 32689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectbool MediaPlayer::isPlaying() 32789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 32889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 32989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer != 0) { 33089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project bool temp = false; 33189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPlayer->isPlaying(&temp); 33289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("isPlaying: %d", temp); 33389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if ((mCurrentState & MEDIA_PLAYER_STARTED) && ! temp) { 33489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("internal/external state mismatch corrected"); 33589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_PAUSED; 33689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 33789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return temp; 33889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 33989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("isPlaying: no active player"); 34089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return false; 34189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 34289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 34389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::getVideoWidth(int *w) 34489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 34589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("getVideoWidth"); 34689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 34789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer == 0) return INVALID_OPERATION; 34889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project *w = mVideoWidth; 34989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return NO_ERROR; 35089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 35189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 35289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::getVideoHeight(int *h) 35389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 35489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("getVideoHeight"); 35589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 35689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer == 0) return INVALID_OPERATION; 35789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project *h = mVideoHeight; 35889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return NO_ERROR; 35989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 36089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 36189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::getCurrentPosition(int *msec) 36289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 36389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("getCurrentPosition"); 36489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 36589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer != 0) { 36689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mCurrentPosition >= 0) { 36789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("Using cached seek position: %d", mCurrentPosition); 36889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project *msec = mCurrentPosition; 36989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return NO_ERROR; 37089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 37189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return mPlayer->getCurrentPosition(msec); 37289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 37389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return INVALID_OPERATION; 37489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 37589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 37689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::getDuration_l(int *msec) 37789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 37889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("getDuration"); 37989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project bool isValidState = (mCurrentState & (MEDIA_PLAYER_PREPARED | MEDIA_PLAYER_STARTED | MEDIA_PLAYER_PAUSED | MEDIA_PLAYER_STOPPED | MEDIA_PLAYER_PLAYBACK_COMPLETE)); 38089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer != 0 && isValidState) { 38189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project status_t ret = NO_ERROR; 38289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mDuration <= 0) 38389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project ret = mPlayer->getDuration(&mDuration); 38489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (msec) 38589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project *msec = mDuration; 38689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return ret; 38789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 38889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("Attempt to call getDuration without a valid mediaplayer"); 38989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return INVALID_OPERATION; 39089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 39189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 39289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::getDuration(int *msec) 39389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 39489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 39589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return getDuration_l(msec); 39689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 39789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 39889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::seekTo_l(int msec) 39989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 40089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("seekTo %d", msec); 40189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if ((mPlayer != 0) && ( mCurrentState & ( MEDIA_PLAYER_STARTED | MEDIA_PLAYER_PREPARED | MEDIA_PLAYER_PAUSED | MEDIA_PLAYER_PLAYBACK_COMPLETE) ) ) { 40289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if ( msec < 0 ) { 40389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGW("Attempt to seek to invalid position: %d", msec); 40489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project msec = 0; 40589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } else if ((mDuration > 0) && (msec > mDuration)) { 40689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGW("Attempt to seek to past end of file: request = %d, EOF = %d", msec, mDuration); 40789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project msec = mDuration; 40889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 40989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project // cache duration 41089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentPosition = msec; 41189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mSeekPosition < 0) { 41289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project getDuration_l(NULL); 41389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mSeekPosition = msec; 41489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return mPlayer->seekTo(msec); 41589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 41689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project else { 41789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("Seek in progress - queue up seekTo[%d]", msec); 41889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return NO_ERROR; 41989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 42089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 42189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("Attempt to perform seekTo in wrong state: mPlayer=%p, mCurrentState=%u", mPlayer.get(), mCurrentState); 42289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return INVALID_OPERATION; 42389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 42489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 42589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::seekTo(int msec) 42689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 4275cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber mLockThreadId = getThreadId(); 42889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 4295cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber status_t result = seekTo_l(msec); 4305cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber mLockThreadId = 0; 4315cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber 4325cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber return result; 43389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 43489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 43589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::reset() 43689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 43789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("reset"); 43889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 43989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mLoop = false; 44089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mCurrentState == MEDIA_PLAYER_IDLE) return NO_ERROR; 44189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPrepareSync = false; 44289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer != 0) { 44389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project status_t ret = mPlayer->reset(); 44489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (ret != NO_ERROR) { 44589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("reset() failed with return code (%d)", ret); 44689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_STATE_ERROR; 44789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } else { 44889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_IDLE; 44989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 450a1680bce73ea1b051cc92e0df651a53944b104eeJames Dong // setDataSource has to be called again to create a 451a1680bce73ea1b051cc92e0df651a53944b104eeJames Dong // new mediaplayer. 452a1680bce73ea1b051cc92e0df651a53944b104eeJames Dong mPlayer = 0; 45389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return ret; 45489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 45589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project clear_l(); 45689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return NO_ERROR; 45789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 45889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 45989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::setAudioStreamType(int type) 46089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 46189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("MediaPlayer::setAudioStreamType"); 46289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 46389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mStreamType == type) return NO_ERROR; 46489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mCurrentState & ( MEDIA_PLAYER_PREPARED | MEDIA_PLAYER_STARTED | 46589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project MEDIA_PLAYER_PAUSED | MEDIA_PLAYER_PLAYBACK_COMPLETE ) ) { 46689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project // Can't change the stream type after prepare 46789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("setAudioStream called in state %d", mCurrentState); 46889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return INVALID_OPERATION; 46989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 47089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project // cache 47189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mStreamType = type; 47289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return OK; 47389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 47489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 47589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::setLooping(int loop) 47689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 47789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("MediaPlayer::setLooping"); 47889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 47989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mLoop = (loop != 0); 48089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer != 0) { 48189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return mPlayer->setLooping(loop); 48289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 48389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return OK; 48489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 48589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 48689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectbool MediaPlayer::isLooping() { 48789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("isLooping"); 48889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 48989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer != 0) { 49089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return mLoop; 49189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 49289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("isLooping: no active player"); 49389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return false; 49489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 49589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 49689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectstatus_t MediaPlayer::setVolume(float leftVolume, float rightVolume) 49789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 49889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("MediaPlayer::setVolume(%f, %f)", leftVolume, rightVolume); 49989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mLock); 50089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mLeftVolume = leftVolume; 50189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mRightVolume = rightVolume; 50289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPlayer != 0) { 50389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return mPlayer->setVolume(leftVolume, rightVolume); 50489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 50589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return OK; 50689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 50789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 508a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurentstatus_t MediaPlayer::setAudioSessionId(int sessionId) 509a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent{ 510a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent LOGV("MediaPlayer::setAudioSessionId(%d)", sessionId); 511a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent Mutex::Autolock _l(mLock); 512a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent if (!(mCurrentState & MEDIA_PLAYER_IDLE)) { 513a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent LOGE("setAudioSessionId called in state %d", mCurrentState); 514a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent return INVALID_OPERATION; 515a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent } 516a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent if (sessionId < 0) { 517a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent return BAD_VALUE; 518a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent } 519a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent mAudioSessionId = sessionId; 520a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent return NO_ERROR; 521a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent} 522a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent 523a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurentint MediaPlayer::getAudioSessionId() 524a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent{ 525a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent Mutex::Autolock _l(mLock); 526a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent return mAudioSessionId; 527a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent} 528a514bdb58b5de4986679f72b7204b4764f7a2778Eric Laurent 5292beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurentstatus_t MediaPlayer::setAuxEffectSendLevel(float level) 5302beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent{ 5312beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent LOGV("MediaPlayer::setAuxEffectSendLevel(%f)", level); 5322beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent Mutex::Autolock _l(mLock); 5332beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent mSendLevel = level; 5342beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent if (mPlayer != 0) { 5352beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent return mPlayer->setAuxEffectSendLevel(level); 5362beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent } 5372beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent return OK; 5382beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent} 5392beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent 5402beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurentstatus_t MediaPlayer::attachAuxEffect(int effectId) 5412beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent{ 5422beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent LOGV("MediaPlayer::attachAuxEffect(%d)", effectId); 5432beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent Mutex::Autolock _l(mLock); 5442beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent if (mPlayer == 0 || 5452beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent (mCurrentState & MEDIA_PLAYER_IDLE) || 5462beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent (mCurrentState == MEDIA_PLAYER_STATE_ERROR )) { 5472beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent LOGE("attachAuxEffect called in state %d", mCurrentState); 5482beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent return INVALID_OPERATION; 5492beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent } 5502beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent 5512beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent return mPlayer->attachAuxEffect(effectId); 5522beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent} 5532beeb50b1bba9e92f6cacfeca37fe9fa9d36ead1Eric Laurent 554b483c4724846c0b8d4e82afcbb7c17f671bae81cGloria Wangvoid MediaPlayer::notify(int msg, int ext1, int ext2, const Parcel *obj) 55589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 55689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("message received msg=%d, ext1=%d, ext2=%d", msg, ext1, ext2); 55789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project bool send = true; 5581af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams bool locked = false; 55989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 56089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project // TODO: In the future, we might be on the same thread if the app is 56189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project // running in the same process as the media server. In that case, 56289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project // this will deadlock. 563660951867e959ebe98612742ef1f72d33ea7e9a3Nicolas Catania // 5641af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams // The threadId hack below works around this for the care of prepare 5655cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber // and seekTo within the same process. 5665cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber // FIXME: Remember, this is a hack, it's not even a hack that is applied 5675cb07aa071b43a214e4c880b3b7852714e06451bAndreas Huber // consistently for all use-cases, this needs to be revisited. 5681af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams if (mLockThreadId != getThreadId()) { 5691af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams mLock.lock(); 5701af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams locked = true; 571660951867e959ebe98612742ef1f72d33ea7e9a3Nicolas Catania } 5721af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams 5733b26844e60f8487388e7e62709faf0dada86e7e1Eric Laurent // Allows calls from JNI in idle state to notify errors 5743b26844e60f8487388e7e62709faf0dada86e7e1Eric Laurent if (!(msg == MEDIA_ERROR && mCurrentState == MEDIA_PLAYER_IDLE) && mPlayer == 0) { 57589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("notify(%d, %d, %d) callback on disconnected mediaplayer", msg, ext1, ext2); 5761af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams if (locked) mLock.unlock(); // release the lock when done. 57789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return; 57889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 57989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 58089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project switch (msg) { 58189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project case MEDIA_NOP: // interface test message 58289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project break; 58389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project case MEDIA_PREPARED: 58489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("prepared"); 58589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_PREPARED; 58689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPrepareSync) { 58789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("signal application thread"); 58889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPrepareSync = false; 58989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPrepareStatus = NO_ERROR; 59089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mSignal.signal(); 59189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 59289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project break; 59389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project case MEDIA_PLAYBACK_COMPLETE: 59489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("playback complete"); 5951c1503cf47c0a37a30e7acac2c5d29140fc61a5fMarco Nelissen if (mCurrentState == MEDIA_PLAYER_IDLE) { 5961c1503cf47c0a37a30e7acac2c5d29140fc61a5fMarco Nelissen LOGE("playback complete in idle state"); 5971c1503cf47c0a37a30e7acac2c5d29140fc61a5fMarco Nelissen } 59889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (!mLoop) { 59989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_PLAYBACK_COMPLETE; 60089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 60189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project break; 60289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project case MEDIA_ERROR: 60365e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project // Always log errors. 60465e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project // ext1: Media framework error code. 60565e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project // ext2: Implementation dependant error code. 60689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("error (%d, %d)", ext1, ext2); 60789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentState = MEDIA_PLAYER_STATE_ERROR; 60889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mPrepareSync) 60989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project { 61089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("signal application thread"); 61189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPrepareSync = false; 61289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mPrepareStatus = ext1; 61389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mSignal.signal(); 61489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project send = false; 61589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 61689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project break; 61765e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project case MEDIA_INFO: 61865e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project // ext1: Media framework error code. 61965e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project // ext2: Implementation dependant error code. 620145e68fc778275963189b02a1adcbe27cce4d769Andreas Huber if (ext1 != MEDIA_INFO_VIDEO_TRACK_LAGGING) { 621145e68fc778275963189b02a1adcbe27cce4d769Andreas Huber LOGW("info/warning (%d, %d)", ext1, ext2); 622145e68fc778275963189b02a1adcbe27cce4d769Andreas Huber } 62365e731f393f704eedab6fbe0af7f8a580c8d4617The Android Open Source Project break; 62489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project case MEDIA_SEEK_COMPLETE: 62589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("Received seek complete"); 62689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (mSeekPosition != mCurrentPosition) { 62789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("Executing queued seekTo(%d)", mSeekPosition); 62889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mSeekPosition = -1; 62989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project seekTo_l(mCurrentPosition); 63089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 63189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project else { 63289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("All seeks complete - return to regularly scheduled program"); 63389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mCurrentPosition = mSeekPosition = -1; 63489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 63589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project break; 63689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project case MEDIA_BUFFERING_UPDATE: 63789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("buffering %d", ext1); 63889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project break; 63989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project case MEDIA_SET_VIDEO_SIZE: 64089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("New video size %d x %d", ext1, ext2); 64189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mVideoWidth = ext1; 64289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project mVideoHeight = ext2; 64389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project break; 644b483c4724846c0b8d4e82afcbb7c17f671bae81cGloria Wang case MEDIA_TIMED_TEXT: 645b483c4724846c0b8d4e82afcbb7c17f671bae81cGloria Wang LOGV("Received timed text message"); 646b483c4724846c0b8d4e82afcbb7c17f671bae81cGloria Wang break; 64789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project default: 64889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("unrecognized message: (%d, %d, %d)", msg, ext1, ext2); 64989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project break; 65089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 65189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 65289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sp<MediaPlayerListener> listener = mListener; 6531af452f333664e8b0a61d96a9b3bb682d8b9a00fJason Sams if (locked) mLock.unlock(); 65489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 65589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project // this prevents re-entrant calls into client code 65689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if ((listener != 0) && send) { 65789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project Mutex::Autolock _l(mNotifyLock); 65889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("callback application"); 659b483c4724846c0b8d4e82afcbb7c17f671bae81cGloria Wang listener->notify(msg, ext1, ext2, obj); 66089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("back from callback"); 66189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 66289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 66389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 66489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project/*static*/ sp<IMemory> MediaPlayer::decode(const char* url, uint32_t *pSampleRate, int* pNumChannels, int* pFormat) 66589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 66689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("decode(%s)", url); 66789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sp<IMemory> p; 66889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project const sp<IMediaPlayerService>& service = getMediaPlayerService(); 66989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (service != 0) { 670dd172fce75b2a1c3cb3a5d3b3bbb5020b1ae8675James Dong p = service->decode(url, pSampleRate, pNumChannels, pFormat); 67189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } else { 67289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("Unable to locate media service"); 67389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 67489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return p; 67589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 67689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 67789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 678dd172fce75b2a1c3cb3a5d3b3bbb5020b1ae8675James Dongvoid MediaPlayer::died() 679dd172fce75b2a1c3cb3a5d3b3bbb5020b1ae8675James Dong{ 680dd172fce75b2a1c3cb3a5d3b3bbb5020b1ae8675James Dong LOGV("died"); 681dd172fce75b2a1c3cb3a5d3b3bbb5020b1ae8675James Dong notify(MEDIA_ERROR, MEDIA_ERROR_SERVER_DIED, 0); 682dd172fce75b2a1c3cb3a5d3b3bbb5020b1ae8675James Dong} 683dd172fce75b2a1c3cb3a5d3b3bbb5020b1ae8675James Dong 68489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project/*static*/ sp<IMemory> MediaPlayer::decode(int fd, int64_t offset, int64_t length, uint32_t *pSampleRate, int* pNumChannels, int* pFormat) 68589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{ 68689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGV("decode(%d, %lld, %lld)", fd, offset, length); 68789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project sp<IMemory> p; 68889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project const sp<IMediaPlayerService>& service = getMediaPlayerService(); 68989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project if (service != 0) { 690dd172fce75b2a1c3cb3a5d3b3bbb5020b1ae8675James Dong p = service->decode(fd, offset, length, pSampleRate, pNumChannels, pFormat); 69189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } else { 69289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project LOGE("Unable to locate media service"); 69389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project } 69489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project return p; 69589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 69689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project} 69789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project 69889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}; // namespace android 699