Dmitry Kovalev | 37e6fd3 | 2014-02-05 18:34:46 -0800 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (c) 2014 The WebM project authors. All Rights Reserved. |
| 3 | * |
| 4 | * Use of this source code is governed by a BSD-style license |
| 5 | * that can be found in the LICENSE file in the root of the source |
| 6 | * tree. An additional intellectual property rights grant can be found |
| 7 | * in the file PATENTS. All contributing project authors may |
| 8 | * be found in the AUTHORS file in the root of the source tree. |
| 9 | */ |
| 10 | |
| 11 | #ifndef VIDEO_READER_H_ |
| 12 | #define VIDEO_READER_H_ |
| 13 | |
| 14 | #include "./video_common.h" |
| 15 | |
| 16 | // The following code is work in progress. It is going to support transparent |
| 17 | // reading of input files. Right now only IVF format is supported for |
| 18 | // simplicity. The main goal the API is to be simple and easy to use in example |
| 19 | // code and in vpxenc/vpxdec later. All low-level details like memory |
| 20 | // buffer management are hidden from API users. |
| 21 | struct VpxVideoReaderStruct; |
| 22 | typedef struct VpxVideoReaderStruct VpxVideoReader; |
| 23 | |
| 24 | #ifdef __cplusplus |
| 25 | extern "C" { |
| 26 | #endif |
| 27 | |
| 28 | // Opens the input file for reading and inspects it to determine file type. |
| 29 | // Returns an opaque VpxVideoReader* upon success, or NULL upon failure. |
| 30 | // Right now only IVF format is supported. |
| 31 | VpxVideoReader *vpx_video_reader_open(const char *filename); |
| 32 | |
| 33 | // Frees all resources associated with VpxVideoReader* returned from |
| 34 | // vpx_video_reader_open() call. |
| 35 | void vpx_video_reader_close(VpxVideoReader *reader); |
| 36 | |
| 37 | // Reads frame from the file and stores it in internal buffer. |
| 38 | int vpx_video_reader_read_frame(VpxVideoReader *reader); |
| 39 | |
| 40 | // Returns the pointer to memory buffer with frame data read by last call to |
| 41 | // vpx_video_reader_read_frame(). |
| 42 | const uint8_t *vpx_video_reader_get_frame(VpxVideoReader *reader, |
| 43 | size_t *size); |
| 44 | |
| 45 | // Fills VpxVideoInfo with information from opened video file. |
| 46 | const VpxVideoInfo *vpx_video_reader_get_info(VpxVideoReader *reader); |
| 47 | |
| 48 | #ifdef __cplusplus |
| 49 | } // extern "C" |
| 50 | #endif |
| 51 | |
| 52 | #endif // VIDEO_READER_H_ |