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() |
| 63 | #define CHANNEL_MASK_USE_CHANNEL_ORDER 0 |
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; |
Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 111 | |
| 112 | // If no callback is specified, use the "write" API below to submit |
Andreas Huber | 7d5b8a7 | 2010-02-09 16:59:18 -0800 | [diff] [blame] | 113 | // audio data. |
Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 114 | virtual status_t open( |
Jean-Michel Trivi | 786618f | 2012-03-02 14:54:07 -0800 | [diff] [blame] | 115 | uint32_t sampleRate, int channelCount, audio_channel_mask_t channelMask, |
Glenn Kasten | e1c3962 | 2012-01-04 09:36:37 -0800 | [diff] [blame] | 116 | audio_format_t format=AUDIO_FORMAT_PCM_16_BIT, |
Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 117 | int bufferCount=DEFAULT_AUDIOSINK_BUFFERCOUNT, |
| 118 | AudioCallback cb = NULL, |
Eric Laurent | 1948eb3 | 2012-04-13 16:50:19 -0700 | [diff] [blame] | 119 | void *cookie = NULL, |
Richard Fitzgerald | ad3af33 | 2013-03-25 16:54:37 +0000 | [diff] [blame] | 120 | audio_output_flags_t flags = AUDIO_OUTPUT_FLAG_NONE, |
Ronghua Wu | faeb0f2 | 2015-05-21 12:20:21 -0700 | [diff] [blame] | 121 | const audio_offload_info_t *offloadInfo = NULL, |
Andy Hung | 179652e | 2015-05-31 22:49:46 -0700 | [diff] [blame] | 122 | bool doNotReconnect = false, |
| 123 | uint32_t suggestedFrameCount = 0) = 0; |
Andreas Huber | 20111aa | 2009-07-14 16:56:47 -0700 | [diff] [blame] | 124 | |
Richard Fitzgerald | d89532e | 2013-05-14 13:18:21 +0100 | [diff] [blame] | 125 | virtual status_t start() = 0; |
Wei Jia | 7d3f4df | 2015-03-03 15:28:00 -0800 | [diff] [blame] | 126 | |
| 127 | /* Input parameter |size| is in byte units stored in |buffer|. |
| 128 | * Data is copied over and actual number of bytes written (>= 0) |
| 129 | * is returned, or no data is copied and a negative status code |
| 130 | * is returned (even when |blocking| is true). |
| 131 | * When |blocking| is false, AudioSink will immediately return after |
| 132 | * part of or full |buffer| is copied over. |
| 133 | * When |blocking| is true, AudioSink will wait to copy the entire |
| 134 | * buffer, unless an error occurs or the copy operation is |
| 135 | * prematurely stopped. |
| 136 | */ |
| 137 | virtual ssize_t write(const void* buffer, size_t size, bool blocking = true) = 0; |
| 138 | |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 139 | virtual void stop() = 0; |
| 140 | virtual void flush() = 0; |
| 141 | virtual void pause() = 0; |
| 142 | virtual void close() = 0; |
Jean-Michel Trivi | 7a8b0ed | 2012-02-02 09:06:31 -0800 | [diff] [blame] | 143 | |
Lajos Molnar | 3a474aa | 2015-04-24 17:10:07 -0700 | [diff] [blame] | 144 | virtual status_t setPlaybackRate(const AudioPlaybackRate& rate) = 0; |
| 145 | virtual status_t getPlaybackRate(AudioPlaybackRate* rate /* nonnull */) = 0; |
Marco Nelissen | 6b74d67 | 2012-02-28 16:07:44 -0800 | [diff] [blame] | 146 | virtual bool needsTrailingPadding() { return true; } |
Richard Fitzgerald | ad3af33 | 2013-03-25 16:54:37 +0000 | [diff] [blame] | 147 | |
Lajos Molnar | ee4e1b1 | 2015-04-17 13:46:19 -0700 | [diff] [blame] | 148 | virtual status_t setParameters(const String8& /* keyValuePairs */) { return NO_ERROR; } |
| 149 | virtual String8 getParameters(const String8& /* keys */) { return String8::empty(); } |
Andy Hung | 9fc8b5c | 2017-01-24 13:36:48 -0800 | [diff] [blame] | 150 | |
Ivan Lozano | 8cf3a07 | 2017-08-09 09:01:33 -0700 | [diff] [blame] | 151 | virtual media::VolumeShaper::Status applyVolumeShaper( |
| 152 | const sp<media::VolumeShaper::Configuration>& configuration, |
Pirama Arumuga Nainar | 091aa6d | 2019-02-15 11:46:00 -0800 | [diff] [blame] | 153 | const sp<media::VolumeShaper::Operation>& operation) = 0; |
| 154 | virtual sp<media::VolumeShaper::State> getVolumeShaperState(int id) = 0; |
jiabin | 156c687 | 2017-10-06 09:47:15 -0700 | [diff] [blame] | 155 | |
| 156 | // AudioRouting |
Pirama Arumuga Nainar | 091aa6d | 2019-02-15 11:46:00 -0800 | [diff] [blame] | 157 | virtual status_t setOutputDevice(audio_port_handle_t deviceId) = 0; |
| 158 | virtual status_t getRoutedDeviceId(audio_port_handle_t* deviceId) = 0; |
| 159 | virtual status_t enableAudioDeviceCallback(bool enabled) = 0; |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 160 | }; |
| 161 | |
Pawin Vongmasa | 082e4f7 | 2017-12-17 02:31:18 -0800 | [diff] [blame] | 162 | MediaPlayerBase() {} |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 163 | virtual ~MediaPlayerBase() {} |
| 164 | virtual status_t initCheck() = 0; |
| 165 | virtual bool hardwareOutput() = 0; |
Andreas Huber | 2db8455 | 2010-01-28 11:19:57 -0800 | [diff] [blame] | 166 | |
Lajos Molnar | ee4e1b1 | 2015-04-17 13:46:19 -0700 | [diff] [blame] | 167 | virtual status_t setUID(uid_t /* uid */) { |
Andreas Huber | 9b80c2b | 2011-06-30 15:47:02 -0700 | [diff] [blame] | 168 | return INVALID_OPERATION; |
| 169 | } |
| 170 | |
Andreas Huber | 2db8455 | 2010-01-28 11:19:57 -0800 | [diff] [blame] | 171 | virtual status_t setDataSource( |
Andreas Huber | 1b86fe0 | 2014-01-29 11:13:26 -0800 | [diff] [blame] | 172 | const sp<IMediaHTTPService> &httpService, |
Andreas Huber | 2db8455 | 2010-01-28 11:19:57 -0800 | [diff] [blame] | 173 | const char *url, |
| 174 | const KeyedVector<String8, String8> *headers = NULL) = 0; |
| 175 | |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 176 | 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] | 177 | |
Lajos Molnar | ee4e1b1 | 2015-04-17 13:46:19 -0700 | [diff] [blame] | 178 | virtual status_t setDataSource(const sp<IStreamSource>& /* source */) { |
Andreas Huber | e2b1028 | 2010-11-23 11:41:34 -0800 | [diff] [blame] | 179 | return INVALID_OPERATION; |
| 180 | } |
| 181 | |
Lajos Molnar | ee4e1b1 | 2015-04-17 13:46:19 -0700 | [diff] [blame] | 182 | virtual status_t setDataSource(const sp<DataSource>& /* source */) { |
Chris Watkins | 99f3160 | 2015-03-20 13:06:33 -0700 | [diff] [blame] | 183 | return INVALID_OPERATION; |
| 184 | } |
| 185 | |
Andy McFadden | 484566c | 2012-12-18 09:46:54 -0800 | [diff] [blame] | 186 | // pass the buffered IGraphicBufferProducer to the media player service |
Glenn Kasten | 1173118 | 2011-02-08 17:26:17 -0800 | [diff] [blame] | 187 | virtual status_t setVideoSurfaceTexture( |
Andy McFadden | 484566c | 2012-12-18 09:46:54 -0800 | [diff] [blame] | 188 | const sp<IGraphicBufferProducer>& bufferProducer) = 0; |
Glenn Kasten | 1173118 | 2011-02-08 17:26:17 -0800 | [diff] [blame] | 189 | |
Wei Jia | 9bb3803 | 2017-03-23 18:00:38 -0700 | [diff] [blame] | 190 | virtual status_t getBufferingSettings( |
Wei Jia | d399e7e | 2016-10-26 15:49:11 -0700 | [diff] [blame] | 191 | BufferingSettings* buffering /* nonnull */) { |
| 192 | *buffering = BufferingSettings(); |
| 193 | return OK; |
| 194 | } |
| 195 | virtual status_t setBufferingSettings(const BufferingSettings& /* buffering */) { |
| 196 | return OK; |
| 197 | } |
| 198 | |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 199 | virtual status_t prepare() = 0; |
| 200 | virtual status_t prepareAsync() = 0; |
| 201 | virtual status_t start() = 0; |
| 202 | virtual status_t stop() = 0; |
| 203 | virtual status_t pause() = 0; |
| 204 | virtual bool isPlaying() = 0; |
Lajos Molnar | 3a474aa | 2015-04-24 17:10:07 -0700 | [diff] [blame] | 205 | virtual status_t setPlaybackSettings(const AudioPlaybackRate& rate) { |
| 206 | // by default, players only support setting rate to the default |
| 207 | if (!isAudioPlaybackRateEqual(rate, AUDIO_PLAYBACK_RATE_DEFAULT)) { |
| 208 | return BAD_VALUE; |
| 209 | } |
| 210 | return OK; |
| 211 | } |
| 212 | virtual status_t getPlaybackSettings(AudioPlaybackRate* rate /* nonnull */) { |
| 213 | *rate = AUDIO_PLAYBACK_RATE_DEFAULT; |
| 214 | return OK; |
| 215 | } |
| 216 | virtual status_t setSyncSettings(const AVSyncSettings& sync, float /* videoFps */) { |
| 217 | // By default, players only support setting sync source to default; all other sync |
| 218 | // settings are ignored. There is no requirement for getters to return set values. |
| 219 | if (sync.mSource != AVSYNC_SOURCE_DEFAULT) { |
| 220 | return BAD_VALUE; |
| 221 | } |
| 222 | return OK; |
| 223 | } |
| 224 | virtual status_t getSyncSettings( |
| 225 | AVSyncSettings* sync /* nonnull */, float* videoFps /* nonnull */) { |
| 226 | *sync = AVSyncSettings(); |
| 227 | *videoFps = -1.f; |
| 228 | return OK; |
| 229 | } |
Wei Jia | c5de091 | 2016-11-18 10:22:14 -0800 | [diff] [blame] | 230 | virtual status_t seekTo( |
| 231 | int msec, MediaPlayerSeekMode mode = MediaPlayerSeekMode::SEEK_PREVIOUS_SYNC) = 0; |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 232 | virtual status_t getCurrentPosition(int *msec) = 0; |
| 233 | virtual status_t getDuration(int *msec) = 0; |
| 234 | virtual status_t reset() = 0; |
Wei Jia | 52c2851 | 2017-09-13 18:17:51 -0700 | [diff] [blame] | 235 | virtual status_t notifyAt(int64_t /* mediaTimeUs */) { |
| 236 | return INVALID_OPERATION; |
| 237 | } |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 238 | virtual status_t setLooping(int loop) = 0; |
| 239 | virtual player_type playerType() = 0; |
Gloria Wang | 4f9e47f | 2011-04-25 17:28:22 -0700 | [diff] [blame] | 240 | virtual status_t setParameter(int key, const Parcel &request) = 0; |
| 241 | virtual status_t getParameter(int key, Parcel *reply) = 0; |
Andreas Huber | 4e92c7e | 2010-02-12 12:35:58 -0800 | [diff] [blame] | 242 | |
John Grossman | 5f7e55e | 2012-08-24 14:47:25 -0700 | [diff] [blame] | 243 | // default no-op implementation of optional extensions |
Lajos Molnar | ee4e1b1 | 2015-04-17 13:46:19 -0700 | [diff] [blame] | 244 | virtual status_t setRetransmitEndpoint(const struct sockaddr_in* /* endpoint */) { |
John Grossman | c795b64 | 2012-02-22 15:38:35 -0800 | [diff] [blame] | 245 | return INVALID_OPERATION; |
| 246 | } |
Lajos Molnar | ee4e1b1 | 2015-04-17 13:46:19 -0700 | [diff] [blame] | 247 | virtual status_t getRetransmitEndpoint(struct sockaddr_in* /* endpoint */) { |
John Grossman | 44a7e42 | 2012-06-21 17:29:24 -0700 | [diff] [blame] | 248 | return INVALID_OPERATION; |
| 249 | } |
Lajos Molnar | ee4e1b1 | 2015-04-17 13:46:19 -0700 | [diff] [blame] | 250 | virtual status_t setNextPlayer(const sp<MediaPlayerBase>& /* next */) { |
John Grossman | 5f7e55e | 2012-08-24 14:47:25 -0700 | [diff] [blame] | 251 | return OK; |
| 252 | } |
John Grossman | c795b64 | 2012-02-22 15:38:35 -0800 | [diff] [blame] | 253 | |
Nicolas Catania | 1d187f1 | 2009-05-12 23:25:55 -0700 | [diff] [blame] | 254 | // Invoke a generic method on the player by using opaque parcels |
| 255 | // for the request and reply. |
niko | d608a81 | 2009-07-16 16:39:53 -0700 | [diff] [blame] | 256 | // |
Nicolas Catania | 1d187f1 | 2009-05-12 23:25:55 -0700 | [diff] [blame] | 257 | // @param request Parcel that is positioned at the start of the |
| 258 | // data sent by the java layer. |
| 259 | // @param[out] reply Parcel to hold the reply data. Cannot be null. |
niko | d608a81 | 2009-07-16 16:39:53 -0700 | [diff] [blame] | 260 | // @return OK if the call was successful. |
Nicolas Catania | 1d187f1 | 2009-05-12 23:25:55 -0700 | [diff] [blame] | 261 | virtual status_t invoke(const Parcel& request, Parcel *reply) = 0; |
niko | d608a81 | 2009-07-16 16:39:53 -0700 | [diff] [blame] | 262 | |
| 263 | // The Client in the MetadataPlayerService calls this method on |
| 264 | // the native player to retrieve all or a subset of metadata. |
| 265 | // |
| 266 | // @param ids SortedList of metadata ID to be fetch. If empty, all |
| 267 | // the known metadata should be returned. |
| 268 | // @param[inout] records Parcel where the player appends its metadata. |
| 269 | // @return OK if the call was successful. |
Lajos Molnar | ee4e1b1 | 2015-04-17 13:46:19 -0700 | [diff] [blame] | 270 | virtual status_t getMetadata(const media::Metadata::Filter& /* ids */, |
| 271 | Parcel* /* records */) { |
niko | a64c8c7 | 2009-07-20 15:07:26 -0700 | [diff] [blame] | 272 | return INVALID_OPERATION; |
| 273 | }; |
niko | d608a81 | 2009-07-16 16:39:53 -0700 | [diff] [blame] | 274 | |
Andreas Huber | 01f3942 | 2011-01-26 11:19:19 -0800 | [diff] [blame] | 275 | void setNotifyCallback( |
Pawin Vongmasa | 082e4f7 | 2017-12-17 02:31:18 -0800 | [diff] [blame] | 276 | const sp<Listener> &listener) { |
Andreas Huber | 01f3942 | 2011-01-26 11:19:19 -0800 | [diff] [blame] | 277 | Mutex::Autolock autoLock(mNotifyLock); |
Pawin Vongmasa | 082e4f7 | 2017-12-17 02:31:18 -0800 | [diff] [blame] | 278 | mListener = listener; |
Andreas Huber | 01f3942 | 2011-01-26 11:19:19 -0800 | [diff] [blame] | 279 | } |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 280 | |
Gloria Wang | b483c47 | 2011-04-11 17:23:27 -0700 | [diff] [blame] | 281 | void sendEvent(int msg, int ext1=0, int ext2=0, |
| 282 | const Parcel *obj=NULL) { |
Pawin Vongmasa | 082e4f7 | 2017-12-17 02:31:18 -0800 | [diff] [blame] | 283 | sp<Listener> listener; |
Chong Zhang | df2592b | 2014-10-24 18:53:44 -0700 | [diff] [blame] | 284 | { |
| 285 | Mutex::Autolock autoLock(mNotifyLock); |
Pawin Vongmasa | 082e4f7 | 2017-12-17 02:31:18 -0800 | [diff] [blame] | 286 | listener = mListener; |
Chong Zhang | df2592b | 2014-10-24 18:53:44 -0700 | [diff] [blame] | 287 | } |
| 288 | |
Pawin Vongmasa | 082e4f7 | 2017-12-17 02:31:18 -0800 | [diff] [blame] | 289 | if (listener != NULL) { |
| 290 | listener->notify(msg, ext1, ext2, obj); |
| 291 | } |
Andreas Huber | 01f3942 | 2011-01-26 11:19:19 -0800 | [diff] [blame] | 292 | } |
| 293 | |
Lajos Molnar | ee4e1b1 | 2015-04-17 13:46:19 -0700 | [diff] [blame] | 294 | virtual status_t dump(int /* fd */, const Vector<String16>& /* args */) const { |
Andreas Huber | a0b1d4b | 2011-06-07 15:52:25 -0700 | [diff] [blame] | 295 | return INVALID_OPERATION; |
| 296 | } |
| 297 | |
Hassan Shojania | cefac14 | 2017-02-06 21:02:02 -0800 | [diff] [blame] | 298 | // Modular DRM |
Colin Cross | b8c35f9 | 2017-04-27 16:15:51 -0700 | [diff] [blame] | 299 | 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] | 300 | return INVALID_OPERATION; |
| 301 | } |
| 302 | virtual status_t releaseDrm() { |
| 303 | return INVALID_OPERATION; |
| 304 | } |
Hassan Shojania | 071437a | 2017-01-23 09:19:40 -0800 | [diff] [blame] | 305 | |
Andreas Huber | 01f3942 | 2011-01-26 11:19:19 -0800 | [diff] [blame] | 306 | private: |
| 307 | friend class MediaPlayerService; |
| 308 | |
| 309 | Mutex mNotifyLock; |
Pawin Vongmasa | 082e4f7 | 2017-12-17 02:31:18 -0800 | [diff] [blame] | 310 | sp<Listener> mListener; |
The Android Open Source Project | 89fa4ad | 2009-03-03 19:31:44 -0800 | [diff] [blame] | 311 | }; |
| 312 | |
| 313 | // Implement this class for media players that use the AudioFlinger software mixer |
| 314 | class MediaPlayerInterface : public MediaPlayerBase |
| 315 | { |
| 316 | public: |
| 317 | virtual ~MediaPlayerInterface() { } |
| 318 | virtual bool hardwareOutput() { return false; } |
| 319 | virtual void setAudioSink(const sp<AudioSink>& audioSink) { mAudioSink = audioSink; } |
| 320 | protected: |
| 321 | sp<AudioSink> mAudioSink; |
| 322 | }; |
| 323 | |
Glenn Kasten | 1173118 | 2011-02-08 17:26:17 -0800 | [diff] [blame] | 324 | // 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] | 325 | class MediaPlayerHWInterface : public MediaPlayerBase |
| 326 | { |
| 327 | public: |
| 328 | virtual ~MediaPlayerHWInterface() {} |
| 329 | virtual bool hardwareOutput() { return true; } |
| 330 | virtual status_t setVolume(float leftVolume, float rightVolume) = 0; |
Glenn Kasten | fff6d71 | 2012-01-12 16:38:12 -0800 | [diff] [blame] | 331 | 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] | 332 | }; |
| 333 | |
| 334 | }; // namespace android |
| 335 | |
| 336 | #endif // __cplusplus |
| 337 | |
| 338 | |
| 339 | #endif // ANDROID_MEDIAPLAYERINTERFACE_H |