]> git.sesse.net Git - ffmpeg/blob - libavcodec/proresdec.h
avfilter/vf_identity: fix typo
[ffmpeg] / libavcodec / proresdec.h
1 /*
2  * Copyright (c) 2010-2011 Maxim Poliakovski
3  * Copyright (c) 2010-2011 Elvis Presley
4  *
5  * This file is part of FFmpeg.
6  *
7  * FFmpeg is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Lesser General Public
9  * License as published by the Free Software Foundation; either
10  * version 2.1 of the License, or (at your option) any later version.
11  *
12  * FFmpeg is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15  * Lesser General Public License for more details.
16  *
17  * You should have received a copy of the GNU Lesser General Public
18  * License along with FFmpeg; if not, write to the Free Software
19  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20  */
21
22 #ifndef AVCODEC_PRORESDEC_H
23 #define AVCODEC_PRORESDEC_H
24
25 #include "get_bits.h"
26 #include "blockdsp.h"
27 #include "proresdsp.h"
28
29 typedef struct {
30     const uint8_t *data;
31     unsigned mb_x;
32     unsigned mb_y;
33     unsigned mb_count;
34     unsigned data_size;
35     int ret;
36 } SliceContext;
37
38 typedef struct {
39     BlockDSPContext bdsp;
40     ProresDSPContext prodsp;
41     AVFrame *frame;
42     int frame_type;              ///< 0 = progressive, 1 = tff, 2 = bff
43     uint8_t qmat_luma[64];
44     uint8_t qmat_chroma[64];
45     SliceContext *slices;
46     int slice_count;             ///< number of slices in the current picture
47     unsigned mb_width;           ///< width of the current picture in mb
48     unsigned mb_height;          ///< height of the current picture in mb
49     uint8_t progressive_scan[64];
50     uint8_t interlaced_scan[64];
51     const uint8_t *scan;
52     int first_field;
53     int alpha_info;
54     void (*unpack_alpha)(GetBitContext *gb, uint16_t *dst, int num_coeffs, const int num_bits);
55 } ProresContext;
56
57 #endif /* AVCODEC_PRORESDEC_H */