blob: 717849d97798f7ebe1a33cb63146f2b49ac7226c [file] [log] [blame]
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -08001/*
2**
3** Copyright (C) 2008 The Android Open Source Project
4**
5** Licensed under the Apache License, Version 2.0 (the "License");
6** you may not use this file except in compliance with the License.
7** You may obtain a copy of the License at
8**
9** http://www.apache.org/licenses/LICENSE-2.0
10**
11** Unless required by applicable law or agreed to in writing, software
12** distributed under the License is distributed on an "AS IS" BASIS,
13** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14** See the License for the specific language governing permissions and
15** limitations under the License.
16*/
17
18#ifndef ANDROID_MEDIAMETADATARETRIEVERINTERFACE_H
19#define ANDROID_MEDIAMETADATARETRIEVERINTERFACE_H
20
21#include <utils/RefBase.h>
22#include <media/mediametadataretriever.h>
23#include <private/media/VideoFrame.h>
24
25namespace android {
26
27// Abstract base class
28class MediaMetadataRetrieverBase : public RefBase
29{
30public:
31 MediaMetadataRetrieverBase() {}
32 virtual ~MediaMetadataRetrieverBase() {}
33 virtual status_t setDataSource(const char *url) = 0;
34 virtual status_t setDataSource(int fd, int64_t offset, int64_t length) = 0;
35 virtual status_t setMode(int mode) = 0;
James Dong16afe2f2010-12-02 17:42:08 -080036 virtual VideoFrame* getFrameAtTime(int64_t timeUs, int option) = 0;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080037 virtual MediaAlbumArt* extractAlbumArt() = 0;
38 virtual const char* extractMetadata(int keyCode) = 0;
39};
40
41// MediaMetadataRetrieverInterface
42class MediaMetadataRetrieverInterface : public MediaMetadataRetrieverBase
43{
44public:
Andreas Huber93e1fb92010-03-12 15:08:52 -080045 MediaMetadataRetrieverInterface()
46 : mMode(0) {
47 }
48
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080049 virtual ~MediaMetadataRetrieverInterface() {}
James Dong148c1a22009-09-06 14:29:45 -070050
51 // @param mode The intended mode of operations:
52 // can be any of the following:
53 // METADATA_MODE_NOOP: Experimental - just add and remove data source.
54 // METADATA_MODE_FRAME_CAPTURE_ONLY: For capture frame/thumbnail only.
55 // METADATA_MODE_METADATA_RETRIEVAL_ONLY: For meta data retrieval only.
56 // METADATA_MODE_FRAME_CAPTURE_AND_METADATA_RETRIEVAL: For both frame
57 // capture and meta data retrieval.
58 virtual status_t setMode(int mode) {
59 if (mode < METADATA_MODE_NOOP ||
60 mode > METADATA_MODE_FRAME_CAPTURE_AND_METADATA_RETRIEVAL) {
61 return BAD_VALUE;
62 }
Andreas Huber93e1fb92010-03-12 15:08:52 -080063
64 mMode = mode;
James Dong148c1a22009-09-06 14:29:45 -070065 return NO_ERROR;
66 }
67
68 virtual status_t getMode(int* mode) const { *mode = mMode; return NO_ERROR; }
James Dong16afe2f2010-12-02 17:42:08 -080069 virtual VideoFrame* getFrameAtTime(int64_t timeUs, int option) { return NULL; }
James Dong148c1a22009-09-06 14:29:45 -070070 virtual MediaAlbumArt* extractAlbumArt() { return NULL; }
71 virtual const char* extractMetadata(int keyCode) { return NULL; }
72
73 uint32_t mMode;
The Android Open Source Project89fa4ad2009-03-03 19:31:44 -080074};
75
76}; // namespace android
77
78#endif // ANDROID_MEDIAMETADATARETRIEVERINTERFACE_H
79