MediaPlayerInterface.h revision 14d2747c7e54037e267bcff78b29e65b2181f0fa
189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project/*
289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project * Copyright (C) 2007 The Android Open Source Project
389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project *
489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project * you may not use this file except in compliance with the License.
689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project * You may obtain a copy of the License at
789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project *
889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project *
1089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project * Unless required by applicable law or agreed to in writing, software
1189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
1289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project * See the License for the specific language governing permissions and
1489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project * limitations under the License.
1589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project */
1689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
1789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#ifndef ANDROID_MEDIAPLAYERINTERFACE_H
1889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#define ANDROID_MEDIAPLAYERINTERFACE_H
1989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
2089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#ifdef __cplusplus
2189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
2214d2747c7e54037e267bcff78b29e65b2181f0faNicolas Catania#include <sys/types.h>
2389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <ui/ISurface.h>
2489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <utils/RefBase.h>
2514d2747c7e54037e267bcff78b29e65b2181f0faNicolas Catania#include <utils/Errors.h>
2689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
2789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <media/mediaplayer.h>
2889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#include <media/AudioSystem.h>
2989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
3089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectnamespace android {
3189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
321d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Cataniaclass Parcel;
331d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania
3489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectenum player_type {
3589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    PV_PLAYER = 1,
3689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    SONIVOX_PLAYER = 2,
3720111aa043c5f404472bc63b90bc5aad906b1101Andreas Huber    VORBIS_PLAYER = 3,
3814d2747c7e54037e267bcff78b29e65b2181f0faNicolas Catania    STAGEFRIGHT_PLAYER = 4,
3914d2747c7e54037e267bcff78b29e65b2181f0faNicolas Catania    // Test players are available only in the 'test' and 'eng' builds.
4014d2747c7e54037e267bcff78b29e65b2181f0faNicolas Catania    // The shared library with the test player is passed passed as an
4114d2747c7e54037e267bcff78b29e65b2181f0faNicolas Catania    // argument to the 'test:' url in the setDataSource call.
4214d2747c7e54037e267bcff78b29e65b2181f0faNicolas Catania    TEST_PLAYER = 5,
4389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project};
4489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
451d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania
4689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#define DEFAULT_AUDIOSINK_BUFFERCOUNT 4
4789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#define DEFAULT_AUDIOSINK_BUFFERSIZE 1200
4889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#define DEFAULT_AUDIOSINK_SAMPLERATE 44100
4989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
5089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
5189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project// callback mechanism for passing messages to MediaPlayer object
5289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projecttypedef void (*notify_callback_f)(void* cookie, int msg, int ext1, int ext2);
5389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
5489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project// abstract base class - use MediaPlayerInterface
5589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectclass MediaPlayerBase : public RefBase
5689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
5789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectpublic:
5889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    // AudioSink: abstraction layer for audio output
5989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    class AudioSink : public RefBase {
6089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    public:
6120111aa043c5f404472bc63b90bc5aad906b1101Andreas Huber        typedef void (*AudioCallback)(
6220111aa043c5f404472bc63b90bc5aad906b1101Andreas Huber                AudioSink *audioSink, void *buffer, size_t size, void *cookie);
6320111aa043c5f404472bc63b90bc5aad906b1101Andreas Huber
6489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        virtual             ~AudioSink() {}
6589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        virtual bool        ready() const = 0; // audio output is open and ready
6689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        virtual bool        realtime() const = 0; // audio output is real-time output
6789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        virtual ssize_t     bufferSize() const = 0;
6889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        virtual ssize_t     frameCount() const = 0;
6989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        virtual ssize_t     channelCount() const = 0;
7089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        virtual ssize_t     frameSize() const = 0;
7189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        virtual uint32_t    latency() const = 0;
7289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        virtual float       msecsPerFrame() const = 0;
7320111aa043c5f404472bc63b90bc5aad906b1101Andreas Huber
7420111aa043c5f404472bc63b90bc5aad906b1101Andreas Huber        // If no callback is specified, use the "write" API below to submit
7520111aa043c5f404472bc63b90bc5aad906b1101Andreas Huber        // audio data. Otherwise return a full buffer of audio data on each
7620111aa043c5f404472bc63b90bc5aad906b1101Andreas Huber        // callback.
7720111aa043c5f404472bc63b90bc5aad906b1101Andreas Huber        virtual status_t    open(
7820111aa043c5f404472bc63b90bc5aad906b1101Andreas Huber                uint32_t sampleRate, int channelCount,
7920111aa043c5f404472bc63b90bc5aad906b1101Andreas Huber                int format=AudioSystem::PCM_16_BIT,
8020111aa043c5f404472bc63b90bc5aad906b1101Andreas Huber                int bufferCount=DEFAULT_AUDIOSINK_BUFFERCOUNT,
8120111aa043c5f404472bc63b90bc5aad906b1101Andreas Huber                AudioCallback cb = NULL,
8220111aa043c5f404472bc63b90bc5aad906b1101Andreas Huber                void *cookie = NULL) = 0;
8320111aa043c5f404472bc63b90bc5aad906b1101Andreas Huber
8489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        virtual void        start() = 0;
8589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        virtual ssize_t     write(const void* buffer, size_t size) = 0;
8689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        virtual void        stop() = 0;
8789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        virtual void        flush() = 0;
8889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        virtual void        pause() = 0;
8989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project        virtual void        close() = 0;
9089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    };
9189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
9289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project                        MediaPlayerBase() : mCookie(0), mNotify(0) {}
9389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual             ~MediaPlayerBase() {}
9489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual status_t    initCheck() = 0;
9589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual bool        hardwareOutput() = 0;
9689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual status_t    setDataSource(const char *url) = 0;
9789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual status_t    setDataSource(int fd, int64_t offset, int64_t length) = 0;
9889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual status_t    setVideoSurface(const sp<ISurface>& surface) = 0;
9989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual status_t    prepare() = 0;
10089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual status_t    prepareAsync() = 0;
10189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual status_t    start() = 0;
10289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual status_t    stop() = 0;
10389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual status_t    pause() = 0;
10489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual bool        isPlaying() = 0;
10589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual status_t    seekTo(int msec) = 0;
10689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual status_t    getCurrentPosition(int *msec) = 0;
10789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual status_t    getDuration(int *msec) = 0;
10889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual status_t    reset() = 0;
10989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual status_t    setLooping(int loop) = 0;
11089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual player_type playerType() = 0;
11189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual void        setNotifyCallback(void* cookie, notify_callback_f notifyFunc) {
11289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project                            mCookie = cookie; mNotify = notifyFunc; }
1131d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania    // Invoke a generic method on the player by using opaque parcels
1141d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania    // for the request and reply.
1151d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania    // @param request Parcel that is positioned at the start of the
1161d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania    //                data sent by the java layer.
1171d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania    // @param[out] reply Parcel to hold the reply data. Cannot be null.
1181d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania    // @return OK if the invocation was made successfully. A player
1191d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania    // not supporting the direct API should return INVALID_OPERATION.
1201d187f1a86855f5f0694d7ec30efc9833bf7c589Nicolas Catania    virtual status_t    invoke(const Parcel& request, Parcel *reply) = 0;
12189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectprotected:
12289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual void        sendEvent(int msg, int ext1=0, int ext2=0) { if (mNotify) mNotify(mCookie, msg, ext1, ext2); }
12389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
12489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    void*               mCookie;
12589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    notify_callback_f   mNotify;
12689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project};
12789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
12889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project// Implement this class for media players that use the AudioFlinger software mixer
12989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectclass MediaPlayerInterface : public MediaPlayerBase
13089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
13189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectpublic:
13289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual             ~MediaPlayerInterface() { }
13389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual bool        hardwareOutput() { return false; }
13489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual void        setAudioSink(const sp<AudioSink>& audioSink) { mAudioSink = audioSink; }
13589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectprotected:
13689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    sp<AudioSink>       mAudioSink;
13789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project};
13889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
13989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project// Implement this class for media players that output directo to hardware
14089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectclass MediaPlayerHWInterface : public MediaPlayerBase
14189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project{
14289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Projectpublic:
14389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual             ~MediaPlayerHWInterface() {}
14489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual bool        hardwareOutput() { return true; }
14589fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual status_t    setVolume(float leftVolume, float rightVolume) = 0;
14689fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project    virtual status_t    setAudioStreamType(int streamType) = 0;
14789fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project};
14889fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
14989fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project}; // namespace android
15089fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
15189fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#endif // __cplusplus
15289fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
15389fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project
15489fa4ad53f2f4d57adbc97ae1149fc00c9b6f3c5The Android Open Source Project#endif // ANDROID_MEDIAPLAYERINTERFACE_H
155