Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
godotengine
GitHub Repository: godotengine/godot
Path: blob/master/thirdparty/libwebp/src/dec/vp8li_dec.h
9912 views
1
// Copyright 2012 Google Inc. All Rights Reserved.
2
//
3
// Use of this source code is governed by a BSD-style license
4
// that can be found in the COPYING file in the root of the source
5
// tree. An additional intellectual property rights grant can be found
6
// in the file PATENTS. All contributing project authors may
7
// be found in the AUTHORS file in the root of the source tree.
8
// -----------------------------------------------------------------------------
9
//
10
// Lossless decoder: internal header.
11
//
12
// Author: Skal ([email protected])
13
// Vikas Arora([email protected])
14
15
#ifndef WEBP_DEC_VP8LI_DEC_H_
16
#define WEBP_DEC_VP8LI_DEC_H_
17
18
#include <string.h> // for memcpy()
19
#include "src/dec/webpi_dec.h"
20
#include "src/utils/bit_reader_utils.h"
21
#include "src/utils/color_cache_utils.h"
22
#include "src/utils/huffman_utils.h"
23
#include "src/webp/types.h"
24
25
#ifdef __cplusplus
26
extern "C" {
27
#endif
28
29
typedef enum {
30
READ_DATA = 0,
31
READ_HDR = 1,
32
READ_DIM = 2
33
} VP8LDecodeState;
34
35
typedef struct VP8LTransform VP8LTransform;
36
struct VP8LTransform {
37
VP8LImageTransformType type_; // transform type.
38
int bits_; // subsampling bits defining transform window.
39
int xsize_; // transform window X index.
40
int ysize_; // transform window Y index.
41
uint32_t* data_; // transform data.
42
};
43
44
typedef struct {
45
int color_cache_size_;
46
VP8LColorCache color_cache_;
47
VP8LColorCache saved_color_cache_; // for incremental
48
49
int huffman_mask_;
50
int huffman_subsample_bits_;
51
int huffman_xsize_;
52
uint32_t* huffman_image_;
53
int num_htree_groups_;
54
HTreeGroup* htree_groups_;
55
HuffmanTables huffman_tables_;
56
} VP8LMetadata;
57
58
typedef struct VP8LDecoder VP8LDecoder;
59
struct VP8LDecoder {
60
VP8StatusCode status_;
61
VP8LDecodeState state_;
62
VP8Io* io_;
63
64
const WebPDecBuffer* output_; // shortcut to io->opaque->output
65
66
uint32_t* pixels_; // Internal data: either uint8_t* for alpha
67
// or uint32_t* for BGRA.
68
uint32_t* argb_cache_; // Scratch buffer for temporary BGRA storage.
69
70
VP8LBitReader br_;
71
int incremental_; // if true, incremental decoding is expected
72
VP8LBitReader saved_br_; // note: could be local variables too
73
int saved_last_pixel_;
74
75
int width_;
76
int height_;
77
int last_row_; // last input row decoded so far.
78
int last_pixel_; // last pixel decoded so far. However, it may
79
// not be transformed, scaled and
80
// color-converted yet.
81
int last_out_row_; // last row output so far.
82
83
VP8LMetadata hdr_;
84
85
int next_transform_;
86
VP8LTransform transforms_[NUM_TRANSFORMS];
87
// or'd bitset storing the transforms types.
88
uint32_t transforms_seen_;
89
90
uint8_t* rescaler_memory; // Working memory for rescaling work.
91
WebPRescaler* rescaler; // Common rescaler for all channels.
92
};
93
94
//------------------------------------------------------------------------------
95
// internal functions. Not public.
96
97
struct ALPHDecoder; // Defined in dec/alphai.h.
98
99
// in vp8l.c
100
101
// Decodes image header for alpha data stored using lossless compression.
102
// Returns false in case of error.
103
WEBP_NODISCARD int VP8LDecodeAlphaHeader(struct ALPHDecoder* const alph_dec,
104
const uint8_t* const data,
105
size_t data_size);
106
107
// Decodes *at least* 'last_row' rows of alpha. If some of the initial rows are
108
// already decoded in previous call(s), it will resume decoding from where it
109
// was paused.
110
// Returns false in case of bitstream error.
111
WEBP_NODISCARD int VP8LDecodeAlphaImageStream(
112
struct ALPHDecoder* const alph_dec, int last_row);
113
114
// Allocates and initialize a new lossless decoder instance.
115
WEBP_NODISCARD VP8LDecoder* VP8LNew(void);
116
117
// Decodes the image header. Returns false in case of error.
118
WEBP_NODISCARD int VP8LDecodeHeader(VP8LDecoder* const dec, VP8Io* const io);
119
120
// Decodes an image. It's required to decode the lossless header before calling
121
// this function. Returns false in case of error, with updated dec->status_.
122
WEBP_NODISCARD int VP8LDecodeImage(VP8LDecoder* const dec);
123
124
// Clears and deallocate a lossless decoder instance.
125
void VP8LDelete(VP8LDecoder* const dec);
126
127
// Helper function for reading the different Huffman codes and storing them in
128
// 'huffman_tables' and 'htree_groups'.
129
// If mapping is NULL 'num_htree_groups_max' must equal 'num_htree_groups'.
130
// If it is not NULL, it maps 'num_htree_groups_max' indices to the
131
// 'num_htree_groups' groups. If 'num_htree_groups_max' > 'num_htree_groups',
132
// some of those indices map to -1. This is used for non-balanced codes to
133
// limit memory usage.
134
WEBP_NODISCARD int ReadHuffmanCodesHelper(
135
int color_cache_bits, int num_htree_groups, int num_htree_groups_max,
136
const int* const mapping, VP8LDecoder* const dec,
137
HuffmanTables* const huffman_tables, HTreeGroup** const htree_groups);
138
139
//------------------------------------------------------------------------------
140
141
#ifdef __cplusplus
142
} // extern "C"
143
#endif
144
145
#endif // WEBP_DEC_VP8LI_DEC_H_
146
147