blob: 02ec9117f5a53044a1423c83cb872aeb59b0bf18 [file] [log] [blame]
James Dong2f1f2242011-03-17 11:02:04 -07001/*
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
Andreas Hubere46b7be2009-07-14 16:56:47 -070017//#define LOG_NDEBUG 0
18#define LOG_TAG "StagefrightPlayer"
19#include <utils/Log.h>
20
21#include "StagefrightPlayer.h"
Andreas Huber27366fc2009-11-20 09:32:46 -080022
23#include "AwesomePlayer.h"
Andreas Hubere46b7be2009-07-14 16:56:47 -070024
Andreas Huber62f7ffe2010-05-06 10:18:05 -070025#include <media/Metadata.h>
26#include <media/stagefright/MediaExtractor.h>
27
Andreas Hubere46b7be2009-07-14 16:56:47 -070028namespace android {
29
30StagefrightPlayer::StagefrightPlayer()
Andreas Huber27366fc2009-11-20 09:32:46 -080031 : mPlayer(new AwesomePlayer) {
Andreas Hubere46b7be2009-07-14 16:56:47 -070032 LOGV("StagefrightPlayer");
Andreas Huber27366fc2009-11-20 09:32:46 -080033
34 mPlayer->setListener(this);
Andreas Hubere46b7be2009-07-14 16:56:47 -070035}
36
37StagefrightPlayer::~StagefrightPlayer() {
38 LOGV("~StagefrightPlayer");
39 reset();
Andreas Huber27366fc2009-11-20 09:32:46 -080040
41 delete mPlayer;
42 mPlayer = NULL;
Andreas Hubere46b7be2009-07-14 16:56:47 -070043}
44
45status_t StagefrightPlayer::initCheck() {
46 LOGV("initCheck");
47 return OK;
48}
49
Andreas Huber25643002010-01-28 11:19:57 -080050status_t StagefrightPlayer::setDataSource(
Andreas Huber433c9ac2010-01-27 16:49:05 -080051 const char *url, const KeyedVector<String8, String8> *headers) {
Andreas Huber433c9ac2010-01-27 16:49:05 -080052 return mPlayer->setDataSource(url, headers);
Andreas Hubere46b7be2009-07-14 16:56:47 -070053}
54
Andreas Huberda440f12009-11-10 11:51:43 -080055// Warning: The filedescriptor passed into this method will only be valid until
56// the method returns, if you want to keep it, dup it!
Andreas Hubere46b7be2009-07-14 16:56:47 -070057status_t StagefrightPlayer::setDataSource(int fd, int64_t offset, int64_t length) {
58 LOGV("setDataSource(%d, %lld, %lld)", fd, offset, length);
Andreas Huber27366fc2009-11-20 09:32:46 -080059 return mPlayer->setDataSource(dup(fd), offset, length);
Andreas Hubere46b7be2009-07-14 16:56:47 -070060}
61
Andreas Huber52b52cd2010-11-23 11:41:34 -080062status_t StagefrightPlayer::setDataSource(const sp<IStreamSource> &source) {
63 return mPlayer->setDataSource(source);
64}
65
Andreas Hubere3c01832010-08-16 08:49:37 -070066status_t StagefrightPlayer::setVideoSurface(const sp<Surface> &surface) {
67 LOGV("setVideoSurface");
68
69 mPlayer->setSurface(surface);
70 return OK;
71}
72
Glenn Kastencc562a32011-02-08 17:26:17 -080073status_t StagefrightPlayer::setVideoSurfaceTexture(
74 const sp<ISurfaceTexture> &surfaceTexture) {
75 LOGV("setVideoSurfaceTexture");
76
77 mPlayer->setSurfaceTexture(surfaceTexture);
78 return OK;
79}
80
Andreas Hubere46b7be2009-07-14 16:56:47 -070081status_t StagefrightPlayer::prepare() {
Andreas Huber6be780e2010-02-08 14:40:30 -080082 return mPlayer->prepare();
Andreas Hubere46b7be2009-07-14 16:56:47 -070083}
84
85status_t StagefrightPlayer::prepareAsync() {
Andreas Huber6be780e2010-02-08 14:40:30 -080086 return mPlayer->prepareAsync();
Andreas Hubere46b7be2009-07-14 16:56:47 -070087}
88
89status_t StagefrightPlayer::start() {
90 LOGV("start");
91
Andreas Huber27366fc2009-11-20 09:32:46 -080092 return mPlayer->play();
Andreas Hubere46b7be2009-07-14 16:56:47 -070093}
94
95status_t StagefrightPlayer::stop() {
96 LOGV("stop");
97
Andreas Huber27366fc2009-11-20 09:32:46 -080098 return pause(); // what's the difference?
Andreas Hubere46b7be2009-07-14 16:56:47 -070099}
100
101status_t StagefrightPlayer::pause() {
102 LOGV("pause");
103
Andreas Huber27366fc2009-11-20 09:32:46 -0800104 return mPlayer->pause();
Andreas Hubere46b7be2009-07-14 16:56:47 -0700105}
106
107bool StagefrightPlayer::isPlaying() {
108 LOGV("isPlaying");
Andreas Huber27366fc2009-11-20 09:32:46 -0800109 return mPlayer->isPlaying();
Andreas Hubere46b7be2009-07-14 16:56:47 -0700110}
111
112status_t StagefrightPlayer::seekTo(int msec) {
Andreas Huber8e64c312011-04-04 09:12:56 -0700113 LOGV("seekTo %.2f secs", msec / 1E3);
Andreas Hubere46b7be2009-07-14 16:56:47 -0700114
Andreas Hubere46b7be2009-07-14 16:56:47 -0700115 status_t err = mPlayer->seekTo((int64_t)msec * 1000);
116
Andreas Hubere46b7be2009-07-14 16:56:47 -0700117 return err;
118}
119
120status_t StagefrightPlayer::getCurrentPosition(int *msec) {
121 LOGV("getCurrentPosition");
122
Andreas Huber27366fc2009-11-20 09:32:46 -0800123 int64_t positionUs;
124 status_t err = mPlayer->getPosition(&positionUs);
125
126 if (err != OK) {
127 return err;
Andreas Hubere46b7be2009-07-14 16:56:47 -0700128 }
129
Andreas Huber27366fc2009-11-20 09:32:46 -0800130 *msec = (positionUs + 500) / 1000;
131
Andreas Hubere46b7be2009-07-14 16:56:47 -0700132 return OK;
133}
134
135status_t StagefrightPlayer::getDuration(int *msec) {
136 LOGV("getDuration");
137
Andreas Huber27366fc2009-11-20 09:32:46 -0800138 int64_t durationUs;
139 status_t err = mPlayer->getDuration(&durationUs);
140
141 if (err != OK) {
Andreas Huber62f7ffe2010-05-06 10:18:05 -0700142 *msec = 0;
143 return OK;
Andreas Hubere46b7be2009-07-14 16:56:47 -0700144 }
145
Andreas Huber27366fc2009-11-20 09:32:46 -0800146 *msec = (durationUs + 500) / 1000;
147
Andreas Hubere46b7be2009-07-14 16:56:47 -0700148 return OK;
149}
150
151status_t StagefrightPlayer::reset() {
152 LOGV("reset");
153
Andreas Huber27366fc2009-11-20 09:32:46 -0800154 mPlayer->reset();
Andreas Hubere46b7be2009-07-14 16:56:47 -0700155
156 return OK;
157}
158
159status_t StagefrightPlayer::setLooping(int loop) {
160 LOGV("setLooping");
Andreas Huber27366fc2009-11-20 09:32:46 -0800161
162 return mPlayer->setLooping(loop);
Andreas Hubere46b7be2009-07-14 16:56:47 -0700163}
164
165player_type StagefrightPlayer::playerType() {
166 LOGV("playerType");
167 return STAGEFRIGHT_PLAYER;
168}
169
170status_t StagefrightPlayer::invoke(const Parcel &request, Parcel *reply) {
171 return INVALID_OPERATION;
172}
173
174void StagefrightPlayer::setAudioSink(const sp<AudioSink> &audioSink) {
175 MediaPlayerInterface::setAudioSink(audioSink);
176
Andreas Huber27366fc2009-11-20 09:32:46 -0800177 mPlayer->setAudioSink(audioSink);
Andreas Hubere46b7be2009-07-14 16:56:47 -0700178}
179
Gloria Wangd01ec6e2011-04-25 17:28:22 -0700180status_t StagefrightPlayer::setParameter(int key, const Parcel &request) {
181 LOGV("setParameter");
182 return mPlayer->setParameter(key, request);
183}
184
185status_t StagefrightPlayer::getParameter(int key, Parcel *reply) {
186 LOGV("getParameter");
187 return mPlayer->getParameter(key, reply);
188}
189
Andreas Huber62f7ffe2010-05-06 10:18:05 -0700190status_t StagefrightPlayer::getMetadata(
191 const media::Metadata::Filter& ids, Parcel *records) {
192 using media::Metadata;
193
194 uint32_t flags = mPlayer->flags();
195
196 Metadata metadata(records);
197
198 metadata.appendBool(
199 Metadata::kPauseAvailable,
200 flags & MediaExtractor::CAN_PAUSE);
201
202 metadata.appendBool(
203 Metadata::kSeekBackwardAvailable,
204 flags & MediaExtractor::CAN_SEEK_BACKWARD);
205
206 metadata.appendBool(
207 Metadata::kSeekForwardAvailable,
208 flags & MediaExtractor::CAN_SEEK_FORWARD);
209
Andreas Huber10b9b3f2010-10-08 10:16:24 -0700210 metadata.appendBool(
211 Metadata::kSeekAvailable,
212 flags & MediaExtractor::CAN_SEEK);
213
Andreas Huber62f7ffe2010-05-06 10:18:05 -0700214 return OK;
215}
216
Andreas Hubere46b7be2009-07-14 16:56:47 -0700217} // namespace android