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