| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 1 | /* | 
 | 2 |  * Copyright (C) 2007 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 ANDROID_MEDIAPLAYERINTERFACE_H | 
 | 18 | #define ANDROID_MEDIAPLAYERINTERFACE_H | 
 | 19 |  | 
 | 20 | #ifdef __cplusplus | 
 | 21 |  | 
| Nicolas Catania | 14d2747 | 2009-07-13 14:37:49 -0700 | [diff] [blame] | 22 | #include <sys/types.h> | 
| Nicolas Catania | 14d2747 | 2009-07-13 14:37:49 -0700 | [diff] [blame] | 23 | #include <utils/Errors.h> | 
| Andreas Huber | 2db8455 | 2010-01-28 11:19:57 -0800 | [diff] [blame] | 24 | #include <utils/KeyedVector.h> | 
 | 25 | #include <utils/String8.h> | 
 | 26 | #include <utils/RefBase.h> | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 27 |  | 
 | 28 | #include <media/mediaplayer.h> | 
| Lajos Molnar | 3a474aa | 2015-04-24 17:10:07 -0700 | [diff] [blame] | 29 | #include <media/AudioResamplerPublic.h> | 
| Lajos Molnar | 06ad152 | 2014-08-28 07:27:44 -0700 | [diff] [blame] | 30 | #include <media/AudioTimestamp.h> | 
| Lajos Molnar | 3a474aa | 2015-04-24 17:10:07 -0700 | [diff] [blame] | 31 | #include <media/AVSyncSettings.h> | 
| Wei Jia | d399e7e | 2016-10-26 15:49:11 -0700 | [diff] [blame] | 32 | #include <media/BufferingSettings.h> | 
| niko | a64c8c7 | 2009-07-20 15:07:26 -0700 | [diff] [blame] | 33 | #include <media/Metadata.h> | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 34 |  | 
| John Grossman | c795b64 | 2012-02-22 15:38:35 -0800 | [diff] [blame] | 35 | // Fwd decl to make sure everyone agrees that the scope of struct sockaddr_in is | 
 | 36 | // global, and not in android:: | 
 | 37 | struct sockaddr_in; | 
 | 38 |  | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 39 | namespace android { | 
 | 40 |  | 
| Chris Watkins | 99f3160 | 2015-03-20 13:06:33 -0700 | [diff] [blame] | 41 | class DataSource; | 
| Nicolas Catania | 1d187f1 | 2009-05-12 23:25:55 -0700 | [diff] [blame] | 42 | class Parcel; | 
| Andreas Huber | 5daeb12 | 2010-08-16 08:49:37 -0700 | [diff] [blame] | 43 | class Surface; | 
| Andy McFadden | 484566c | 2012-12-18 09:46:54 -0800 | [diff] [blame] | 44 | class IGraphicBufferProducer; | 
| Mathias Agopian | 3cf6135 | 2010-02-09 17:46:37 -0800 | [diff] [blame] | 45 |  | 
| niko | d608a81 | 2009-07-16 16:39:53 -0700 | [diff] [blame] | 46 | template<typename T> class SortedVector; | 
| Nicolas Catania | 1d187f1 | 2009-05-12 23:25:55 -0700 | [diff] [blame] | 47 |  | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 48 | enum player_type { | 
| Andreas Huber | f933441 | 2010-12-15 15:17:42 -0800 | [diff] [blame] | 49 |     STAGEFRIGHT_PLAYER = 3, | 
 | 50 |     NU_PLAYER = 4, | 
| Nicolas Catania | 14d2747 | 2009-07-13 14:37:49 -0700 | [diff] [blame] | 51 |     // Test players are available only in the 'test' and 'eng' builds. | 
 | 52 |     // The shared library with the test player is passed passed as an | 
 | 53 |     // argument to the 'test:' url in the setDataSource call. | 
 | 54 |     TEST_PLAYER = 5, | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 55 | }; | 
 | 56 |  | 
| Nicolas Catania | 1d187f1 | 2009-05-12 23:25:55 -0700 | [diff] [blame] | 57 |  | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 58 | #define DEFAULT_AUDIOSINK_BUFFERCOUNT 4 | 
 | 59 | #define DEFAULT_AUDIOSINK_BUFFERSIZE 1200 | 
 | 60 | #define DEFAULT_AUDIOSINK_SAMPLERATE 44100 | 
 | 61 |  | 
| Jean-Michel Trivi | 786618f | 2012-03-02 14:54:07 -0800 | [diff] [blame] | 62 | // when the channel mask isn't known, use the channel count to derive a mask in AudioSink::open() | 
| Mikhail Naganov | 5577303 | 2020-10-01 15:08:13 -0700 | [diff] [blame] | 63 | #define CHANNEL_MASK_USE_CHANNEL_ORDER AUDIO_CHANNEL_NONE | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 64 |  | 
| Eric Laurent | 1948eb3 | 2012-04-13 16:50:19 -0700 | [diff] [blame] | 65 | // duration below which we do not allow deep audio buffering | 
 | 66 | #define AUDIO_SINK_MIN_DEEP_BUFFER_DURATION_US 5000000 | 
 | 67 |  | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 68 | // abstract base class - use MediaPlayerInterface | 
 | 69 | class MediaPlayerBase : public RefBase | 
 | 70 | { | 
 | 71 | public: | 
| Pawin Vongmasa | 082e4f7 | 2017-12-17 02:31:18 -0800 | [diff] [blame] | 72 |     // callback mechanism for passing messages to MediaPlayer object | 
 | 73 |     class Listener : public RefBase { | 
 | 74 |     public: | 
 | 75 |         virtual void notify(int msg, int ext1, int ext2, const Parcel *obj) = 0; | 
 | 76 |         virtual ~Listener() {} | 
 | 77 |     }; | 
 | 78 |  | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 79 |     // AudioSink: abstraction layer for audio output | 
 | 80 |     class AudioSink : public RefBase { | 
 | 81 |     public: | 
| Richard Fitzgerald | ad3af33 | 2013-03-25 16:54:37 +0000 | [diff] [blame] | 82 |         enum cb_event_t { | 
 | 83 |             CB_EVENT_FILL_BUFFER,   // Request to write more data to buffer. | 
 | 84 |             CB_EVENT_STREAM_END,    // Sent after all the buffers queued in AF and HW are played | 
 | 85 |                                     // back (after stop is called) | 
 | 86 |             CB_EVENT_TEAR_DOWN      // The AudioTrack was invalidated due to use case change: | 
 | 87 |                                     // Need to re-evaluate offloading options | 
 | 88 |         }; | 
 | 89 |  | 
| Andreas Huber | 7d5b8a7 | 2010-02-09 16:59:18 -0800 | [diff] [blame] | 90 |         // Callback returns the number of bytes actually written to the buffer. | 
 | 91 |         typedef size_t (*AudioCallback)( | 
| Richard Fitzgerald | ad3af33 | 2013-03-25 16:54:37 +0000 | [diff] [blame] | 92 |                 AudioSink *audioSink, void *buffer, size_t size, void *cookie, | 
 | 93 |                         cb_event_t event); | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 94 |  | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 95 |         virtual             ~AudioSink() {} | 
 | 96 |         virtual bool        ready() const = 0; // audio output is open and ready | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 97 |         virtual ssize_t     bufferSize() const = 0; | 
 | 98 |         virtual ssize_t     frameCount() const = 0; | 
 | 99 |         virtual ssize_t     channelCount() const = 0; | 
 | 100 |         virtual ssize_t     frameSize() const = 0; | 
 | 101 |         virtual uint32_t    latency() const = 0; | 
 | 102 |         virtual float       msecsPerFrame() const = 0; | 
| Marco Nelissen | 4110c10 | 2012-03-29 09:31:28 -0700 | [diff] [blame] | 103 |         virtual status_t    getPosition(uint32_t *position) const = 0; | 
| Lajos Molnar | 06ad152 | 2014-08-28 07:27:44 -0700 | [diff] [blame] | 104 |         virtual status_t    getTimestamp(AudioTimestamp &ts) const = 0; | 
| Wei Jia | c4ac817 | 2015-10-21 10:35:48 -0700 | [diff] [blame] | 105 |         virtual int64_t     getPlayedOutDurationUs(int64_t nowUs) const = 0; | 
| Marco Nelissen | 4110c10 | 2012-03-29 09:31:28 -0700 | [diff] [blame] | 106 |         virtual status_t    getFramesWritten(uint32_t *frameswritten) const = 0; | 
| Glenn Kasten | d848eb4 | 2016-03-08 13:42:11 -0800 | [diff] [blame] | 107 |         virtual audio_session_t getSessionId() const = 0; | 
| Eric Laurent | 2261234 | 2013-11-14 17:28:47 -0800 | [diff] [blame] | 108 |         virtual audio_stream_type_t getAudioStreamType() const = 0; | 
| Eric Laurent | 6f59db1 | 2013-07-26 17:16:50 -0700 | [diff] [blame] | 109 |         virtual uint32_t    getSampleRate() const = 0; | 
| Andy Hung | f2c87b3 | 2016-04-07 19:49:29 -0700 | [diff] [blame] | 110 |         virtual int64_t     getBufferDurationInUs() const = 0; | 
| Jaideep Sharma | 18a7912 | 2020-11-04 16:30:05 +0530 | [diff] [blame^] | 111 |         virtual audio_output_flags_t getFlags() const = 0; | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 112 |  | 
 | 113 |         // If no callback is specified, use the "write" API below to submit | 
| Andreas Huber | 7d5b8a7 | 2010-02-09 16:59:18 -0800 | [diff] [blame] | 114 |         // audio data. | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 115 |         virtual status_t    open( | 
| Jean-Michel Trivi | 786618f | 2012-03-02 14:54:07 -0800 | [diff] [blame] | 116 |                 uint32_t sampleRate, int channelCount, audio_channel_mask_t channelMask, | 
| Glenn Kasten | e1c3962 | 2012-01-04 09:36:37 -0800 | [diff] [blame] | 117 |                 audio_format_t format=AUDIO_FORMAT_PCM_16_BIT, | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 118 |                 int bufferCount=DEFAULT_AUDIOSINK_BUFFERCOUNT, | 
 | 119 |                 AudioCallback cb = NULL, | 
| Eric Laurent | 1948eb3 | 2012-04-13 16:50:19 -0700 | [diff] [blame] | 120 |                 void *cookie = NULL, | 
| Richard Fitzgerald | ad3af33 | 2013-03-25 16:54:37 +0000 | [diff] [blame] | 121 |                 audio_output_flags_t flags = AUDIO_OUTPUT_FLAG_NONE, | 
| Ronghua Wu | faeb0f2 | 2015-05-21 12:20:21 -0700 | [diff] [blame] | 122 |                 const audio_offload_info_t *offloadInfo = NULL, | 
| Andy Hung | 179652e | 2015-05-31 22:49:46 -0700 | [diff] [blame] | 123 |                 bool doNotReconnect = false, | 
 | 124 |                 uint32_t suggestedFrameCount = 0) = 0; | 
| Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 125 |  | 
| Richard Fitzgerald | d89532e | 2013-05-14 13:18:21 +0100 | [diff] [blame] | 126 |         virtual status_t    start() = 0; | 
| Wei Jia | 7d3f4df | 2015-03-03 15:28:00 -0800 | [diff] [blame] | 127 |  | 
 | 128 |         /* Input parameter |size| is in byte units stored in |buffer|. | 
 | 129 |          * Data is copied over and actual number of bytes written (>= 0) | 
 | 130 |          * is returned, or no data is copied and a negative status code | 
 | 131 |          * is returned (even when |blocking| is true). | 
 | 132 |          * When |blocking| is false, AudioSink will immediately return after | 
 | 133 |          * part of or full |buffer| is copied over. | 
 | 134 |          * When |blocking| is true, AudioSink will wait to copy the entire | 
 | 135 |          * buffer, unless an error occurs or the copy operation is | 
 | 136 |          * prematurely stopped. | 
 | 137 |          */ | 
 | 138 |         virtual ssize_t     write(const void* buffer, size_t size, bool blocking = true) = 0; | 
 | 139 |  | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 140 |         virtual void        stop() = 0; | 
 | 141 |         virtual void        flush() = 0; | 
 | 142 |         virtual void        pause() = 0; | 
 | 143 |         virtual void        close() = 0; | 
| Jean-Michel Trivi | 7a8b0ed | 2012-02-02 09:06:31 -0800 | [diff] [blame] | 144 |  | 
| Lajos Molnar | 3a474aa | 2015-04-24 17:10:07 -0700 | [diff] [blame] | 145 |         virtual status_t    setPlaybackRate(const AudioPlaybackRate& rate) = 0; | 
 | 146 |         virtual status_t    getPlaybackRate(AudioPlaybackRate* rate /* nonnull */) = 0; | 
| Marco Nelissen | 6b74d67 | 2012-02-28 16:07:44 -0800 | [diff] [blame] | 147 |         virtual bool        needsTrailingPadding() { return true; } | 
| Richard Fitzgerald | ad3af33 | 2013-03-25 16:54:37 +0000 | [diff] [blame] | 148 |  | 
| Lajos Molnar | ee4e1b1 | 2015-04-17 13:46:19 -0700 | [diff] [blame] | 149 |         virtual status_t    setParameters(const String8& /* keyValuePairs */) { return NO_ERROR; } | 
 | 150 |         virtual String8     getParameters(const String8& /* keys */) { return String8::empty(); } | 
| Andy Hung | 9fc8b5c | 2017-01-24 13:36:48 -0800 | [diff] [blame] | 151 |  | 
| Ivan Lozano | 8cf3a07 | 2017-08-09 09:01:33 -0700 | [diff] [blame] | 152 |         virtual media::VolumeShaper::Status applyVolumeShaper( | 
 | 153 |                                     const sp<media::VolumeShaper::Configuration>& configuration, | 
| Pirama Arumuga Nainar | 091aa6d | 2019-02-15 11:46:00 -0800 | [diff] [blame] | 154 |                                     const sp<media::VolumeShaper::Operation>& operation) = 0; | 
 | 155 |         virtual sp<media::VolumeShaper::State> getVolumeShaperState(int id) = 0; | 
| jiabin | 156c687 | 2017-10-06 09:47:15 -0700 | [diff] [blame] | 156 |  | 
 | 157 |         // AudioRouting | 
| Pirama Arumuga Nainar | 091aa6d | 2019-02-15 11:46:00 -0800 | [diff] [blame] | 158 |         virtual status_t    setOutputDevice(audio_port_handle_t deviceId) = 0; | 
 | 159 |         virtual status_t    getRoutedDeviceId(audio_port_handle_t* deviceId) = 0; | 
 | 160 |         virtual status_t    enableAudioDeviceCallback(bool enabled) = 0; | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 161 |     }; | 
 | 162 |  | 
| Pawin Vongmasa | 082e4f7 | 2017-12-17 02:31:18 -0800 | [diff] [blame] | 163 |                         MediaPlayerBase() {} | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 164 |     virtual             ~MediaPlayerBase() {} | 
 | 165 |     virtual status_t    initCheck() = 0; | 
 | 166 |     virtual bool        hardwareOutput() = 0; | 
| Andreas Huber | 2db8455 | 2010-01-28 11:19:57 -0800 | [diff] [blame] | 167 |  | 
| Lajos Molnar | ee4e1b1 | 2015-04-17 13:46:19 -0700 | [diff] [blame] | 168 |     virtual status_t    setUID(uid_t /* uid */) { | 
| Andreas Huber | 9b80c2b | 2011-06-30 15:47:02 -0700 | [diff] [blame] | 169 |         return INVALID_OPERATION; | 
 | 170 |     } | 
 | 171 |  | 
| Andreas Huber | 2db8455 | 2010-01-28 11:19:57 -0800 | [diff] [blame] | 172 |     virtual status_t    setDataSource( | 
| Andreas Huber | 1b86fe0 | 2014-01-29 11:13:26 -0800 | [diff] [blame] | 173 |             const sp<IMediaHTTPService> &httpService, | 
| Andreas Huber | 2db8455 | 2010-01-28 11:19:57 -0800 | [diff] [blame] | 174 |             const char *url, | 
 | 175 |             const KeyedVector<String8, String8> *headers = NULL) = 0; | 
 | 176 |  | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 177 |     virtual status_t    setDataSource(int fd, int64_t offset, int64_t length) = 0; | 
| Andreas Huber | e2b1028 | 2010-11-23 11:41:34 -0800 | [diff] [blame] | 178 |  | 
| Lajos Molnar | ee4e1b1 | 2015-04-17 13:46:19 -0700 | [diff] [blame] | 179 |     virtual status_t    setDataSource(const sp<IStreamSource>& /* source */) { | 
| Andreas Huber | e2b1028 | 2010-11-23 11:41:34 -0800 | [diff] [blame] | 180 |         return INVALID_OPERATION; | 
 | 181 |     } | 
 | 182 |  | 
| Lajos Molnar | ee4e1b1 | 2015-04-17 13:46:19 -0700 | [diff] [blame] | 183 |     virtual status_t    setDataSource(const sp<DataSource>& /* source */) { | 
| Chris Watkins | 99f3160 | 2015-03-20 13:06:33 -0700 | [diff] [blame] | 184 |         return INVALID_OPERATION; | 
 | 185 |     } | 
 | 186 |  | 
| Byeongjo Park | 28225ab | 2019-01-24 20:31:19 +0900 | [diff] [blame] | 187 |     virtual status_t    setDataSource(const String8& /* rtpParams */) { | 
 | 188 |         return INVALID_OPERATION; | 
 | 189 |     } | 
 | 190 |  | 
| Andy McFadden | 484566c | 2012-12-18 09:46:54 -0800 | [diff] [blame] | 191 |     // pass the buffered IGraphicBufferProducer to the media player service | 
| Glenn Kasten | 1173118 | 2011-02-08 17:26:17 -0800 | [diff] [blame] | 192 |     virtual status_t    setVideoSurfaceTexture( | 
| Andy McFadden | 484566c | 2012-12-18 09:46:54 -0800 | [diff] [blame] | 193 |                                 const sp<IGraphicBufferProducer>& bufferProducer) = 0; | 
| Glenn Kasten | 1173118 | 2011-02-08 17:26:17 -0800 | [diff] [blame] | 194 |  | 
| Wei Jia | 9bb3803 | 2017-03-23 18:00:38 -0700 | [diff] [blame] | 195 |     virtual status_t    getBufferingSettings( | 
| Wei Jia | d399e7e | 2016-10-26 15:49:11 -0700 | [diff] [blame] | 196 |                                 BufferingSettings* buffering /* nonnull */) { | 
 | 197 |         *buffering = BufferingSettings(); | 
 | 198 |         return OK; | 
 | 199 |     } | 
 | 200 |     virtual status_t    setBufferingSettings(const BufferingSettings& /* buffering */) { | 
 | 201 |         return OK; | 
 | 202 |     } | 
 | 203 |  | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 204 |     virtual status_t    prepare() = 0; | 
 | 205 |     virtual status_t    prepareAsync() = 0; | 
 | 206 |     virtual status_t    start() = 0; | 
 | 207 |     virtual status_t    stop() = 0; | 
 | 208 |     virtual status_t    pause() = 0; | 
 | 209 |     virtual bool        isPlaying() = 0; | 
| Lajos Molnar | 3a474aa | 2015-04-24 17:10:07 -0700 | [diff] [blame] | 210 |     virtual status_t    setPlaybackSettings(const AudioPlaybackRate& rate) { | 
 | 211 |         // by default, players only support setting rate to the default | 
 | 212 |         if (!isAudioPlaybackRateEqual(rate, AUDIO_PLAYBACK_RATE_DEFAULT)) { | 
 | 213 |             return BAD_VALUE; | 
 | 214 |         } | 
 | 215 |         return OK; | 
 | 216 |     } | 
 | 217 |     virtual status_t    getPlaybackSettings(AudioPlaybackRate* rate /* nonnull */) { | 
 | 218 |         *rate = AUDIO_PLAYBACK_RATE_DEFAULT; | 
 | 219 |         return OK; | 
 | 220 |     } | 
 | 221 |     virtual status_t    setSyncSettings(const AVSyncSettings& sync, float /* videoFps */) { | 
 | 222 |         // By default, players only support setting sync source to default; all other sync | 
 | 223 |         // settings are ignored. There is no requirement for getters to return set values. | 
 | 224 |         if (sync.mSource != AVSYNC_SOURCE_DEFAULT) { | 
 | 225 |             return BAD_VALUE; | 
 | 226 |         } | 
 | 227 |         return OK; | 
 | 228 |     } | 
 | 229 |     virtual status_t    getSyncSettings( | 
 | 230 |                                 AVSyncSettings* sync /* nonnull */, float* videoFps /* nonnull */) { | 
 | 231 |         *sync = AVSyncSettings(); | 
 | 232 |         *videoFps = -1.f; | 
 | 233 |         return OK; | 
 | 234 |     } | 
| Wei Jia | c5de091 | 2016-11-18 10:22:14 -0800 | [diff] [blame] | 235 |     virtual status_t    seekTo( | 
 | 236 |             int msec, MediaPlayerSeekMode mode = MediaPlayerSeekMode::SEEK_PREVIOUS_SYNC) = 0; | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 237 |     virtual status_t    getCurrentPosition(int *msec) = 0; | 
 | 238 |     virtual status_t    getDuration(int *msec) = 0; | 
 | 239 |     virtual status_t    reset() = 0; | 
| Wei Jia | 52c2851 | 2017-09-13 18:17:51 -0700 | [diff] [blame] | 240 |     virtual status_t    notifyAt(int64_t /* mediaTimeUs */) { | 
 | 241 |         return INVALID_OPERATION; | 
 | 242 |     } | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 243 |     virtual status_t    setLooping(int loop) = 0; | 
 | 244 |     virtual player_type playerType() = 0; | 
| Gloria Wang | 4f9e47f | 2011-04-25 17:28:22 -0700 | [diff] [blame] | 245 |     virtual status_t    setParameter(int key, const Parcel &request) = 0; | 
 | 246 |     virtual status_t    getParameter(int key, Parcel *reply) = 0; | 
| Andreas Huber | 4e92c7e | 2010-02-12 12:35:58 -0800 | [diff] [blame] | 247 |  | 
| John Grossman | 5f7e55e | 2012-08-24 14:47:25 -0700 | [diff] [blame] | 248 |     // default no-op implementation of optional extensions | 
| Lajos Molnar | ee4e1b1 | 2015-04-17 13:46:19 -0700 | [diff] [blame] | 249 |     virtual status_t setRetransmitEndpoint(const struct sockaddr_in* /* endpoint */) { | 
| John Grossman | c795b64 | 2012-02-22 15:38:35 -0800 | [diff] [blame] | 250 |         return INVALID_OPERATION; | 
 | 251 |     } | 
| Lajos Molnar | ee4e1b1 | 2015-04-17 13:46:19 -0700 | [diff] [blame] | 252 |     virtual status_t getRetransmitEndpoint(struct sockaddr_in* /* endpoint */) { | 
| John Grossman | 44a7e42 | 2012-06-21 17:29:24 -0700 | [diff] [blame] | 253 |         return INVALID_OPERATION; | 
 | 254 |     } | 
| Lajos Molnar | ee4e1b1 | 2015-04-17 13:46:19 -0700 | [diff] [blame] | 255 |     virtual status_t setNextPlayer(const sp<MediaPlayerBase>& /* next */) { | 
| John Grossman | 5f7e55e | 2012-08-24 14:47:25 -0700 | [diff] [blame] | 256 |         return OK; | 
 | 257 |     } | 
| John Grossman | c795b64 | 2012-02-22 15:38:35 -0800 | [diff] [blame] | 258 |  | 
| Nicolas Catania | 1d187f1 | 2009-05-12 23:25:55 -0700 | [diff] [blame] | 259 |     // Invoke a generic method on the player by using opaque parcels | 
 | 260 |     // for the request and reply. | 
| niko | d608a81 | 2009-07-16 16:39:53 -0700 | [diff] [blame] | 261 |     // | 
| Nicolas Catania | 1d187f1 | 2009-05-12 23:25:55 -0700 | [diff] [blame] | 262 |     // @param request Parcel that is positioned at the start of the | 
 | 263 |     //                data sent by the java layer. | 
 | 264 |     // @param[out] reply Parcel to hold the reply data. Cannot be null. | 
| niko | d608a81 | 2009-07-16 16:39:53 -0700 | [diff] [blame] | 265 |     // @return OK if the call was successful. | 
| Nicolas Catania | 1d187f1 | 2009-05-12 23:25:55 -0700 | [diff] [blame] | 266 |     virtual status_t    invoke(const Parcel& request, Parcel *reply) = 0; | 
| niko | d608a81 | 2009-07-16 16:39:53 -0700 | [diff] [blame] | 267 |  | 
 | 268 |     // The Client in the MetadataPlayerService calls this method on | 
 | 269 |     // the native player to retrieve all or a subset of metadata. | 
 | 270 |     // | 
 | 271 |     // @param ids SortedList of metadata ID to be fetch. If empty, all | 
 | 272 |     //            the known metadata should be returned. | 
 | 273 |     // @param[inout] records Parcel where the player appends its metadata. | 
 | 274 |     // @return OK if the call was successful. | 
| Lajos Molnar | ee4e1b1 | 2015-04-17 13:46:19 -0700 | [diff] [blame] | 275 |     virtual status_t    getMetadata(const media::Metadata::Filter& /* ids */, | 
 | 276 |                                     Parcel* /* records */) { | 
| niko | a64c8c7 | 2009-07-20 15:07:26 -0700 | [diff] [blame] | 277 |         return INVALID_OPERATION; | 
 | 278 |     }; | 
| niko | d608a81 | 2009-07-16 16:39:53 -0700 | [diff] [blame] | 279 |  | 
| Andreas Huber | 01f3942 | 2011-01-26 11:19:19 -0800 | [diff] [blame] | 280 |     void        setNotifyCallback( | 
| Pawin Vongmasa | 082e4f7 | 2017-12-17 02:31:18 -0800 | [diff] [blame] | 281 |             const sp<Listener> &listener) { | 
| Andreas Huber | 01f3942 | 2011-01-26 11:19:19 -0800 | [diff] [blame] | 282 |         Mutex::Autolock autoLock(mNotifyLock); | 
| Pawin Vongmasa | 082e4f7 | 2017-12-17 02:31:18 -0800 | [diff] [blame] | 283 |         mListener = listener; | 
| Andreas Huber | 01f3942 | 2011-01-26 11:19:19 -0800 | [diff] [blame] | 284 |     } | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 285 |  | 
| Gloria Wang | b483c47 | 2011-04-11 17:23:27 -0700 | [diff] [blame] | 286 |     void        sendEvent(int msg, int ext1=0, int ext2=0, | 
 | 287 |                           const Parcel *obj=NULL) { | 
| Pawin Vongmasa | 082e4f7 | 2017-12-17 02:31:18 -0800 | [diff] [blame] | 288 |         sp<Listener> listener; | 
| Chong Zhang | df2592b | 2014-10-24 18:53:44 -0700 | [diff] [blame] | 289 |         { | 
 | 290 |             Mutex::Autolock autoLock(mNotifyLock); | 
| Pawin Vongmasa | 082e4f7 | 2017-12-17 02:31:18 -0800 | [diff] [blame] | 291 |             listener = mListener; | 
| Chong Zhang | df2592b | 2014-10-24 18:53:44 -0700 | [diff] [blame] | 292 |         } | 
 | 293 |  | 
| Pawin Vongmasa | 082e4f7 | 2017-12-17 02:31:18 -0800 | [diff] [blame] | 294 |         if (listener != NULL) { | 
 | 295 |             listener->notify(msg, ext1, ext2, obj); | 
 | 296 |         } | 
| Andreas Huber | 01f3942 | 2011-01-26 11:19:19 -0800 | [diff] [blame] | 297 |     } | 
 | 298 |  | 
| Lajos Molnar | ee4e1b1 | 2015-04-17 13:46:19 -0700 | [diff] [blame] | 299 |     virtual status_t dump(int /* fd */, const Vector<String16>& /* args */) const { | 
| Andreas Huber | a0b1d4b | 2011-06-07 15:52:25 -0700 | [diff] [blame] | 300 |         return INVALID_OPERATION; | 
 | 301 |     } | 
 | 302 |  | 
| Hassan Shojania | cefac14 | 2017-02-06 21:02:02 -0800 | [diff] [blame] | 303 |     // Modular DRM | 
| Colin Cross | b8c35f9 | 2017-04-27 16:15:51 -0700 | [diff] [blame] | 304 |     virtual status_t prepareDrm(const uint8_t /* uuid */[16], const Vector<uint8_t>& /* drmSessionId */) { | 
| Hassan Shojania | 071437a | 2017-01-23 09:19:40 -0800 | [diff] [blame] | 305 |         return INVALID_OPERATION; | 
 | 306 |     } | 
 | 307 |     virtual status_t releaseDrm() { | 
 | 308 |         return INVALID_OPERATION; | 
 | 309 |     } | 
| Hassan Shojania | 071437a | 2017-01-23 09:19:40 -0800 | [diff] [blame] | 310 |  | 
| Andreas Huber | 01f3942 | 2011-01-26 11:19:19 -0800 | [diff] [blame] | 311 | private: | 
 | 312 |     friend class MediaPlayerService; | 
 | 313 |  | 
 | 314 |     Mutex               mNotifyLock; | 
| Pawin Vongmasa | 082e4f7 | 2017-12-17 02:31:18 -0800 | [diff] [blame] | 315 |     sp<Listener>        mListener; | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 316 | }; | 
 | 317 |  | 
 | 318 | // Implement this class for media players that use the AudioFlinger software mixer | 
 | 319 | class MediaPlayerInterface : public MediaPlayerBase | 
 | 320 | { | 
 | 321 | public: | 
 | 322 |     virtual             ~MediaPlayerInterface() { } | 
 | 323 |     virtual bool        hardwareOutput() { return false; } | 
 | 324 |     virtual void        setAudioSink(const sp<AudioSink>& audioSink) { mAudioSink = audioSink; } | 
 | 325 | protected: | 
 | 326 |     sp<AudioSink>       mAudioSink; | 
 | 327 | }; | 
 | 328 |  | 
| Glenn Kasten | 1173118 | 2011-02-08 17:26:17 -0800 | [diff] [blame] | 329 | // Implement this class for media players that output audio directly to hardware | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 330 | class MediaPlayerHWInterface : public MediaPlayerBase | 
 | 331 | { | 
 | 332 | public: | 
 | 333 |     virtual             ~MediaPlayerHWInterface() {} | 
 | 334 |     virtual bool        hardwareOutput() { return true; } | 
 | 335 |     virtual status_t    setVolume(float leftVolume, float rightVolume) = 0; | 
| Glenn Kasten | fff6d71 | 2012-01-12 16:38:12 -0800 | [diff] [blame] | 336 |     virtual status_t    setAudioStreamType(audio_stream_type_t streamType) = 0; | 
| The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 337 | }; | 
 | 338 |  | 
 | 339 | }; // namespace android | 
 | 340 |  | 
 | 341 | #endif // __cplusplus | 
 | 342 |  | 
 | 343 |  | 
 | 344 | #endif // ANDROID_MEDIAPLAYERINTERFACE_H |