AwesomePlayer.h revision 8ba01021b573889802e67e029225a96f0dfa471a
1/* 2 * Copyright (C) 2009 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17#ifndef AWESOME_PLAYER_H_ 18 19#define AWESOME_PLAYER_H_ 20 21#include "HTTPBase.h" 22#include "TimedEventQueue.h" 23 24#include <media/MediaPlayerInterface.h> 25#include <media/stagefright/DataSource.h> 26#include <media/stagefright/OMXClient.h> 27#include <media/stagefright/TimeSource.h> 28#include <utils/threads.h> 29#include <drm/DrmManagerClient.h> 30 31namespace android { 32 33struct AudioPlayer; 34struct DataSource; 35struct MediaBuffer; 36struct MediaExtractor; 37struct MediaSource; 38struct NuCachedSource2; 39struct IGraphicBufferProducer; 40 41class DrmManagerClinet; 42class DecryptHandle; 43 44class TimedTextDriver; 45struct WVMExtractor; 46 47struct AwesomeRenderer : public RefBase { 48 AwesomeRenderer() {} 49 50 virtual void render(MediaBuffer *buffer) = 0; 51 52private: 53 AwesomeRenderer(const AwesomeRenderer &); 54 AwesomeRenderer &operator=(const AwesomeRenderer &); 55}; 56 57struct AwesomePlayer { 58 AwesomePlayer(); 59 ~AwesomePlayer(); 60 61 void setListener(const wp<MediaPlayerBase> &listener); 62 void setUID(uid_t uid); 63 64 status_t setDataSource( 65 const char *uri, 66 const KeyedVector<String8, String8> *headers = NULL); 67 68 status_t setDataSource(int fd, int64_t offset, int64_t length); 69 70 status_t setDataSource(const sp<IStreamSource> &source); 71 72 void reset(); 73 74 status_t prepare(); 75 status_t prepare_l(); 76 status_t prepareAsync(); 77 status_t prepareAsync_l(); 78 79 status_t play(); 80 status_t pause(); 81 82 bool isPlaying() const; 83 84 status_t setSurfaceTexture(const sp<IGraphicBufferProducer> &bufferProducer); 85 void setAudioSink(const sp<MediaPlayerBase::AudioSink> &audioSink); 86 status_t setLooping(bool shouldLoop); 87 88 status_t getDuration(int64_t *durationUs); 89 status_t getPosition(int64_t *positionUs); 90 91 status_t setParameter(int key, const Parcel &request); 92 status_t getParameter(int key, Parcel *reply); 93 status_t invoke(const Parcel &request, Parcel *reply); 94 status_t setCacheStatCollectFreq(const Parcel &request); 95 96 status_t seekTo(int64_t timeUs); 97 98 // This is a mask of MediaExtractor::Flags. 99 uint32_t flags() const; 100 101 void postAudioEOS(int64_t delayUs = 0ll); 102 void postAudioSeekComplete(); 103 104 status_t dump(int fd, const Vector<String16> &args) const; 105 106private: 107 friend struct AwesomeEvent; 108 friend struct PreviewPlayer; 109 110 enum { 111 PLAYING = 0x01, 112 LOOPING = 0x02, 113 FIRST_FRAME = 0x04, 114 PREPARING = 0x08, 115 PREPARED = 0x10, 116 AT_EOS = 0x20, 117 PREPARE_CANCELLED = 0x40, 118 CACHE_UNDERRUN = 0x80, 119 AUDIO_AT_EOS = 0x0100, 120 VIDEO_AT_EOS = 0x0200, 121 AUTO_LOOPING = 0x0400, 122 123 // We are basically done preparing but are currently buffering 124 // sufficient data to begin playback and finish the preparation phase 125 // for good. 126 PREPARING_CONNECTED = 0x0800, 127 128 // We're triggering a single video event to display the first frame 129 // after the seekpoint. 130 SEEK_PREVIEW = 0x1000, 131 132 AUDIO_RUNNING = 0x2000, 133 AUDIOPLAYER_STARTED = 0x4000, 134 135 INCOGNITO = 0x8000, 136 137 TEXT_RUNNING = 0x10000, 138 TEXTPLAYER_INITIALIZED = 0x20000, 139 140 SLOW_DECODER_HACK = 0x40000, 141 }; 142 143 mutable Mutex mLock; 144 Mutex mMiscStateLock; 145 mutable Mutex mStatsLock; 146 Mutex mAudioLock; 147 148 OMXClient mClient; 149 TimedEventQueue mQueue; 150 bool mQueueStarted; 151 wp<MediaPlayerBase> mListener; 152 bool mUIDValid; 153 uid_t mUID; 154 155 sp<ANativeWindow> mNativeWindow; 156 sp<MediaPlayerBase::AudioSink> mAudioSink; 157 158 SystemTimeSource mSystemTimeSource; 159 TimeSource *mTimeSource; 160 161 String8 mUri; 162 KeyedVector<String8, String8> mUriHeaders; 163 164 sp<DataSource> mFileSource; 165 166 sp<MediaSource> mVideoTrack; 167 sp<MediaSource> mVideoSource; 168 sp<AwesomeRenderer> mVideoRenderer; 169 bool mVideoRenderingStarted; 170 bool mVideoRendererIsPreview; 171 172 ssize_t mActiveAudioTrackIndex; 173 sp<MediaSource> mAudioTrack; 174 sp<MediaSource> mAudioSource; 175 AudioPlayer *mAudioPlayer; 176 int64_t mDurationUs; 177 178 int32_t mDisplayWidth; 179 int32_t mDisplayHeight; 180 int32_t mVideoScalingMode; 181 182 uint32_t mFlags; 183 uint32_t mExtractorFlags; 184 uint32_t mSinceLastDropped; 185 186 int64_t mTimeSourceDeltaUs; 187 int64_t mVideoTimeUs; 188 189 enum SeekType { 190 NO_SEEK, 191 SEEK, 192 SEEK_VIDEO_ONLY 193 }; 194 SeekType mSeeking; 195 196 bool mSeekNotificationSent; 197 int64_t mSeekTimeUs; 198 199 int64_t mBitrate; // total bitrate of the file (in bps) or -1 if unknown. 200 201 bool mWatchForAudioSeekComplete; 202 bool mWatchForAudioEOS; 203 204 sp<TimedEventQueue::Event> mVideoEvent; 205 bool mVideoEventPending; 206 sp<TimedEventQueue::Event> mStreamDoneEvent; 207 bool mStreamDoneEventPending; 208 sp<TimedEventQueue::Event> mBufferingEvent; 209 bool mBufferingEventPending; 210 sp<TimedEventQueue::Event> mCheckAudioStatusEvent; 211 bool mAudioStatusEventPending; 212 sp<TimedEventQueue::Event> mVideoLagEvent; 213 bool mVideoLagEventPending; 214 215 sp<TimedEventQueue::Event> mAsyncPrepareEvent; 216 Condition mPreparedCondition; 217 bool mIsAsyncPrepare; 218 status_t mPrepareResult; 219 status_t mStreamDoneStatus; 220 221 void postVideoEvent_l(int64_t delayUs = -1); 222 void postBufferingEvent_l(); 223 void postStreamDoneEvent_l(status_t status); 224 void postCheckAudioStatusEvent(int64_t delayUs); 225 void postVideoLagEvent_l(); 226 status_t play_l(); 227 228 MediaBuffer *mVideoBuffer; 229 230 sp<HTTPBase> mConnectingDataSource; 231 sp<NuCachedSource2> mCachedSource; 232 233 DrmManagerClient *mDrmManagerClient; 234 sp<DecryptHandle> mDecryptHandle; 235 236 int64_t mLastVideoTimeUs; 237 TimedTextDriver *mTextDriver; 238 239 sp<WVMExtractor> mWVMExtractor; 240 sp<MediaExtractor> mExtractor; 241 242 status_t setDataSource_l( 243 const char *uri, 244 const KeyedVector<String8, String8> *headers = NULL); 245 246 status_t setDataSource_l(const sp<DataSource> &dataSource); 247 status_t setDataSource_l(const sp<MediaExtractor> &extractor); 248 void reset_l(); 249 status_t seekTo_l(int64_t timeUs); 250 status_t pause_l(bool at_eos = false); 251 void initRenderer_l(); 252 void notifyVideoSize_l(); 253 void seekAudioIfNecessary_l(); 254 255 void cancelPlayerEvents(bool keepNotifications = false); 256 257 void setAudioSource(sp<MediaSource> source); 258 status_t initAudioDecoder(); 259 260 void setVideoSource(sp<MediaSource> source); 261 status_t initVideoDecoder(uint32_t flags = 0); 262 263 void addTextSource_l(size_t trackIndex, const sp<MediaSource>& source); 264 265 void onStreamDone(); 266 267 void notifyListener_l(int msg, int ext1 = 0, int ext2 = 0); 268 269 void onVideoEvent(); 270 void onBufferingUpdate(); 271 void onCheckAudioStatus(); 272 void onPrepareAsyncEvent(); 273 void abortPrepare(status_t err); 274 void finishAsyncPrepare_l(); 275 void onVideoLagUpdate(); 276 277 bool getCachedDuration_l(int64_t *durationUs, bool *eos); 278 279 status_t finishSetDataSource_l(); 280 281 static bool ContinuePreparation(void *cookie); 282 283 bool getBitrate(int64_t *bitrate); 284 285 void finishSeekIfNecessary(int64_t videoTimeUs); 286 void ensureCacheIsFetching_l(); 287 288 status_t startAudioPlayer_l(bool sendErrorNotification = true); 289 290 void shutdownVideoDecoder_l(); 291 status_t setNativeWindow_l(const sp<ANativeWindow> &native); 292 293 bool isStreamingHTTP() const; 294 void sendCacheStats(); 295 void checkDrmStatus(const sp<DataSource>& dataSource); 296 297 enum FlagMode { 298 SET, 299 CLEAR, 300 ASSIGN 301 }; 302 void modifyFlags(unsigned value, FlagMode mode); 303 304 struct TrackStat { 305 String8 mMIME; 306 String8 mDecoderName; 307 }; 308 309 // protected by mStatsLock 310 struct Stats { 311 int mFd; 312 String8 mURI; 313 int64_t mBitrate; 314 315 // FIXME: 316 // These two indices are just 0 or 1 for now 317 // They are not representing the actual track 318 // indices in the stream. 319 ssize_t mAudioTrackIndex; 320 ssize_t mVideoTrackIndex; 321 322 int64_t mNumVideoFramesDecoded; 323 int64_t mNumVideoFramesDropped; 324 int32_t mVideoWidth; 325 int32_t mVideoHeight; 326 uint32_t mFlags; 327 Vector<TrackStat> mTracks; 328 } mStats; 329 330 status_t setVideoScalingMode(int32_t mode); 331 status_t setVideoScalingMode_l(int32_t mode); 332 status_t getTrackInfo(Parcel* reply) const; 333 334 status_t selectAudioTrack_l(const sp<MediaSource>& source, size_t trackIndex); 335 336 // when select is true, the given track is selected. 337 // otherwise, the given track is unselected. 338 status_t selectTrack(size_t trackIndex, bool select); 339 340 size_t countTracks() const; 341 342 AwesomePlayer(const AwesomePlayer &); 343 AwesomePlayer &operator=(const AwesomePlayer &); 344}; 345 346} // namespace android 347 348#endif // AWESOME_PLAYER_H_ 349