NdkImageReader.h revision c360382bf257d815b2a411152485d3c3b37a9f46
1/*
2 * Copyright (C) 2016 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/*
18 * This file defines an NDK API.
19 * Do not remove methods.
20 * Do not change method signatures.
21 * Do not change the value of constants.
22 * Do not change the size of any of the classes defined in here.
23 * Do not reference types that are not part of the NDK.
24 * Do not #include files that aren't part of the NDK.
25 */
26
27#ifndef _NDK_IMAGE_READER_H
28#define _NDK_IMAGE_READER_H
29
30#include <android/native_window.h>
31#include "NdkMediaError.h"
32#include "NdkImage.h"
33
34#ifdef __cplusplus
35extern "C" {
36#endif
37
38typedef struct AImageReader AImageReader;
39
40media_status_t AImageReader_new(
41        int32_t width, int32_t height, int32_t format, int32_t maxImages,
42        /*out*/AImageReader** reader);
43
44// Return all images acquired from this AImageReader back to system and delete
45// the AImageReader instance from memory
46// Do NOT use `reader` after this call
47void AImageReader_delete(AImageReader* reader);
48
49// Do NOT call ANativeWindow_release on the output. Just use AImageReader_delete.
50media_status_t AImageReader_getWindow(AImageReader*, /*out*/ANativeWindow** window);
51
52media_status_t AImageReader_getWidth(const AImageReader* reader, /*out*/int32_t* width);
53media_status_t AImageReader_getHeight(const AImageReader* reader, /*out*/int32_t* height);
54media_status_t AImageReader_getFormat(const AImageReader* reader, /*out*/int32_t* format);
55media_status_t AImageReader_getMaxImages(const AImageReader* reader, /*out*/int32_t* maxImages);
56
57media_status_t AImageReader_acquireNextImage(AImageReader* reader, /*out*/AImage** image);
58
59media_status_t AImageReader_acquireLatestImage(AImageReader* reader, /*out*/AImage** image);
60
61// The callback happens on one dedicated thread per AImageReader instance
62// It's okay to use AImageReader_*/AImage_* APIs within the callback
63typedef void (*AImageReader_ImageCallback)(void* context, AImageReader* reader);
64
65typedef struct AImageReader_ImageListener {
66    void*                      context; // optional application context.
67    AImageReader_ImageCallback onImageAvailable;
68} AImageReader_ImageListener;
69
70media_status_t AImageReader_setImageListener(
71        AImageReader* reader, AImageReader_ImageListener* listener);
72
73#ifdef __cplusplus
74} // extern "C"
75#endif
76
77#endif //_NDK_IMAGE_READER_H
78