android_GenericPlayer.h revision 3610785fa93586ce84a27a27530feb77b8035229
113837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi/*
213837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi * Copyright (C) 2011 The Android Open Source Project
313837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi *
413837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi * Licensed under the Apache License, Version 2.0 (the "License");
513837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi * you may not use this file except in compliance with the License.
613837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi * You may obtain a copy of the License at
713837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi *
813837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi *      http://www.apache.org/licenses/LICENSE-2.0
913837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi *
1013837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi * Unless required by applicable law or agreed to in writing, software
1113837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi * distributed under the License is distributed on an "AS IS" BASIS,
1213837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1313837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi * See the License for the specific language governing permissions and
1413837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi * limitations under the License.
1513837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi */
1613837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
174ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi#ifndef __ANDROID_GENERICPLAYER_H__
184ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi#define __ANDROID_GENERICPLAYER_H__
194ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi
204ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi#include <media/stagefright/foundation/AHandler.h>
214ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi#include <media/stagefright/foundation/ALooper.h>
224ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi#include <media/stagefright/foundation/AMessage.h>
2313837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
2413837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi//--------------------------------------------------------------------------------------------------
254ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi/**
264ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi * Message parameters for AHandler messages, see list in GenericPlayer::kWhatxxx
274ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi */
284ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi#define WHATPARAM_SEEK_SEEKTIME_MS                  "seekTimeMs"
294ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi#define WHATPARAM_LOOP_LOOPING                      "looping"
304ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi#define WHATPARAM_BUFFERING_UPDATE                  "bufferingUpdate"
314ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi#define WHATPARAM_BUFFERING_UPDATETHRESHOLD_PERCENT "buffUpdateThreshold"
323610785fa93586ce84a27a27530feb77b8035229Glenn Kasten#define WHATPARAM_ATTACHAUXEFFECT                   "attachAuxEffect"
333610785fa93586ce84a27a27530feb77b8035229Glenn Kasten#define WHATPARAM_SETAUXEFFECTSENDLEVEL             "setAuxEffectSendLevel"
344ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi
3513837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivinamespace android {
3613837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
3713837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Triviclass GenericPlayer : public AHandler
3813837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi{
3913837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivipublic:
4013837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
4113837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    enum {
424ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi        kEventPrepared                = 'prep',
434ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi        kEventHasVideoSize            = 'vsiz',
444ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi        kEventPrefetchStatusChange    = 'pfsc',
454ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi        kEventPrefetchFillLevelUpdate = 'pflu',
464ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi        kEventEndOfStream             = 'eos'
4713837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    };
4813837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
494ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi
5013837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    GenericPlayer(const AudioPlayback_Parameters* params);
5113837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    virtual ~GenericPlayer();
5213837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
5313837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    virtual void init(const notif_cbf_t cbf, void* notifUser);
54e6ded5c61944a87fa9e472dec3a6929855d42aebJean-Michel Trivi    virtual void preDestroy();
5513837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
5613837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    virtual void setDataSource(const char *uri);
5713837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    virtual void setDataSource(int fd, int64_t offset, int64_t length);
5813837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
5913837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    virtual void prepare();
6013837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    virtual void play();
6113837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    virtual void pause();
6213837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    virtual void stop();
6313837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    virtual void seek(int64_t timeMsec);
6413837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    virtual void loop(bool loop);
654ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    virtual void setBufferingUpdateThreshold(int16_t thresholdPercent);
6613837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
674b0e0b2860ffd5e246b42c8a434833cca2f068b3Jean-Michel Trivi    virtual void getDurationMsec(int* msec); //msec != NULL, ANDROID_UNKNOWN_TIME if unknown
684b0e0b2860ffd5e246b42c8a434833cca2f068b3Jean-Michel Trivi    virtual void getPositionMsec(int* msec); //msec != NULL, ANDROID_UNKNOWN_TIME if unknown
694b0e0b2860ffd5e246b42c8a434833cca2f068b3Jean-Michel Trivi    virtual void getSampleRate(uint32_t* hz);// hz  != NULL, UNKNOWN_SAMPLERATE if unknown
7070c49ae2867094072a4365423417ea452bf82231Jean-Michel Trivi
714ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    void setVolume(bool mute, bool useStereoPos, XApermille stereoPos, XAmillibel volume);
723610785fa93586ce84a27a27530feb77b8035229Glenn Kasten    void attachAuxEffect(int32_t effectId);
733610785fa93586ce84a27a27530feb77b8035229Glenn Kasten    void setAuxEffectSendLevel(float level);
7437dc2fccf3f122b79ebd554de209d0a3c94ae161Jean-Michel Trivi
7513837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Triviprotected:
764b0e0b2860ffd5e246b42c8a434833cca2f068b3Jean-Michel Trivi    // mutex used for set vs use of volume and cache (fill, threshold) settings
7737dc2fccf3f122b79ebd554de209d0a3c94ae161Jean-Michel Trivi    Mutex mSettingsLock;
7813837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
7913837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    void resetDataLocator();
8013837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    DataLocator2 mDataLocator;
8113837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    int          mDataLocatorType;
8213837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
834ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    // Constants used to identify the messages in this player's AHandler message loop
844ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    //   in onMessageReceived()
8513837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    enum {
864ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi        kWhatPrepare         = 'prep',
874ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi        kWhatNotif           = 'noti',
884ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi        kWhatPlay            = 'play',
894ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi        kWhatPause           = 'paus',
904ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi        kWhatSeek            = 'seek',
914ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi        kWhatSeekComplete    = 'skcp',
924ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi        kWhatLoop            = 'loop',
934ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi        kWhatVolumeUpdate    = 'volu',
944ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi        kWhatBufferingUpdate = 'bufu',
954ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi        kWhatBuffUpdateThres = 'buut',
963610785fa93586ce84a27a27530feb77b8035229Glenn Kasten        kWhatMediaPlayerInfo = 'mpin',
973610785fa93586ce84a27a27530feb77b8035229Glenn Kasten        kWhatAttachAuxEffect = 'aaux',
983610785fa93586ce84a27a27530feb77b8035229Glenn Kasten        kWhatSetAuxEffectSendLevel = 'saux',
9913837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    };
10013837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
10113837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    // Send a notification to one of the event listeners
10237dc2fccf3f122b79ebd554de209d0a3c94ae161Jean-Michel Trivi    virtual void notify(const char* event, int data1, bool async);
10337dc2fccf3f122b79ebd554de209d0a3c94ae161Jean-Michel Trivi    virtual void notify(const char* event, int data1, int data2, bool async);
10413837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
10513837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    // AHandler implementation
10613837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    virtual void onMessageReceived(const sp<AMessage> &msg);
10713837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
10813837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    // Async event handlers (called from GenericPlayer's event loop)
10913837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    virtual void onPrepare();
11013837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    virtual void onNotify(const sp<AMessage> &msg);
11113837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    virtual void onPlay();
11213837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    virtual void onPause();
11313837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    virtual void onSeek(const sp<AMessage> &msg);
11413837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    virtual void onLoop(const sp<AMessage> &msg);
11537dc2fccf3f122b79ebd554de209d0a3c94ae161Jean-Michel Trivi    virtual void onVolumeUpdate();
1164ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    virtual void onSeekComplete();
1174ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    virtual void onBufferingUpdate(const sp<AMessage> &msg);
1184ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    virtual void onSetBufferingUpdateThreshold(const sp<AMessage> &msg);
1193610785fa93586ce84a27a27530feb77b8035229Glenn Kasten    virtual void onAttachAuxEffect(const sp<AMessage> &msg);
1203610785fa93586ce84a27a27530feb77b8035229Glenn Kasten    virtual void onSetAuxEffectSendLevel(const sp<AMessage> &msg);
1214ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi
1224ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    // Convenience methods
1234ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    //   for async notifications of prefetch status and cache fill level, needs to be called
1244ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    //     with mSettingsLock locked
1254ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    void notifyStatus();
1264ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    void notifyCacheFill();
1274ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    //   for internal async notification to update state that the player is no longer seeking
1284ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    void seekComplete();
1294ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    void bufferingUpdate(int16_t fillLevelPerMille);
13013837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
13113837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    // Event notification from GenericPlayer to OpenSL ES / OpenMAX AL framework
13213837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    notif_cbf_t mNotifyClient;
13313837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    void*       mNotifyUser;
134e6ded5c61944a87fa9e472dec3a6929855d42aebJean-Michel Trivi    // lock to protect mNotifyClient and mNotifyUser updates
135e6ded5c61944a87fa9e472dec3a6929855d42aebJean-Michel Trivi    Mutex       mNotifyClientLock;
13613837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
13749935c51fddcd0caa0030e2aac0c3a7ba3339e3dGlenn Kasten    // Bits for mStateFlags
13813837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    enum {
13949935c51fddcd0caa0030e2aac0c3a7ba3339e3dGlenn Kasten        kFlagPrepared               = 1 << 0,   // use only for successful preparation
14049935c51fddcd0caa0030e2aac0c3a7ba3339e3dGlenn Kasten        kFlagPreparing              = 1 << 1,
14149935c51fddcd0caa0030e2aac0c3a7ba3339e3dGlenn Kasten        kFlagPlaying                = 1 << 2,
14249935c51fddcd0caa0030e2aac0c3a7ba3339e3dGlenn Kasten        kFlagBuffering              = 1 << 3,
14349935c51fddcd0caa0030e2aac0c3a7ba3339e3dGlenn Kasten        kFlagSeeking                = 1 << 4,
14449935c51fddcd0caa0030e2aac0c3a7ba3339e3dGlenn Kasten        kFlagLooping                = 1 << 5,
14549935c51fddcd0caa0030e2aac0c3a7ba3339e3dGlenn Kasten        kFlagPreparedUnsuccessfully = 1 << 6,
14613837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    };
14713837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
14813837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    uint32_t mStateFlags;
14913837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
15013837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    sp<ALooper> mLooper;
15113837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    int32_t mLooperPriority;
15213837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
15313837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    AudioPlayback_Parameters mPlaybackParams;
15413837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
15537dc2fccf3f122b79ebd554de209d0a3c94ae161Jean-Michel Trivi    AndroidAudioLevels mAndroidAudioLevels;
15637dc2fccf3f122b79ebd554de209d0a3c94ae161Jean-Michel Trivi    int mChannelCount; // this is used for the panning law, and is not exposed outside of the object
1574ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    int32_t mDurationMsec;
1584b0e0b2860ffd5e246b42c8a434833cca2f068b3Jean-Michel Trivi    // position is not protected by any lock in this generic class, may be different in subclasses
1594ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    int32_t mPositionMsec;
1607f5cc1afe49395fefaad9b2bbd728a45d1bfda6aJean-Michel Trivi    uint32_t mSampleRateHz;
1614ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi
1624ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    CacheStatus_t mCacheStatus;
1634ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    int16_t mCacheFill; // cache fill level + played back level in permille
1644ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    int16_t mLastNotifiedCacheFill; // last cache fill level communicated to the listener
1654ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi    int16_t mCacheFillNotifThreshold; // threshold in cache fill level for cache fill to be reported
1664ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi
16713837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Triviprivate:
16813837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi    DISALLOW_EVIL_CONSTRUCTORS(GenericPlayer);
16913837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi};
17013837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi
17113837cf3f7be0eb8b1a9552bd99a89f98c987720Jean-Michel Trivi} // namespace android
1724ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi
1734ee246c55533bdab8ab5fa0f0581744fe58e7c91Jean-Michel Trivi#endif /* __ANDROID_GENERICPLAYER_H__ */
174