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