2012-04-11 02:23:38 +02:00
|
|
|
// Copyright 2012 Google Inc. All Rights Reserved.
|
|
|
|
//
|
|
|
|
// This code is licensed under the same terms as WebM:
|
|
|
|
// Software License Agreement: http://www.webmproject.org/license/software/
|
|
|
|
// Additional IP Rights Grant: http://www.webmproject.org/license/additional/
|
|
|
|
// -----------------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// Lossless decoder: internal header.
|
|
|
|
//
|
|
|
|
// Author: Skal (pascal.massimino@gmail.com)
|
|
|
|
// Vikas Arora(vikaas.arora@gmail.com)
|
|
|
|
|
|
|
|
#ifndef WEBP_DEC_VP8LI_H_
|
|
|
|
#define WEBP_DEC_VP8LI_H_
|
|
|
|
|
|
|
|
#include <string.h> // for memcpy()
|
|
|
|
#include "./webpi.h"
|
|
|
|
#include "../utils/bit_reader.h"
|
|
|
|
#include "../utils/color_cache.h"
|
2012-04-23 17:36:14 +02:00
|
|
|
#include "../utils/huffman.h"
|
2012-05-24 11:21:37 +02:00
|
|
|
#include "../webp/format_constants.h"
|
2012-04-11 02:23:38 +02:00
|
|
|
|
|
|
|
#if defined(__cplusplus) || defined(c_plusplus)
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
READ_DATA = 0,
|
|
|
|
READ_HDR = 1,
|
|
|
|
READ_DIM = 2
|
|
|
|
} VP8LDecodeState;
|
|
|
|
|
|
|
|
typedef struct VP8LTransform VP8LTransform;
|
|
|
|
struct VP8LTransform {
|
|
|
|
VP8LImageTransformType type_; // transform type.
|
|
|
|
int bits_; // subsampling bits defining transform window.
|
2012-04-24 21:23:58 +02:00
|
|
|
int xsize_; // transform window X index.
|
|
|
|
int ysize_; // transform window Y index.
|
2012-04-11 02:23:38 +02:00
|
|
|
uint32_t *data_; // transform data.
|
|
|
|
};
|
|
|
|
|
2012-04-23 17:36:14 +02:00
|
|
|
typedef struct {
|
|
|
|
HuffmanTree htrees_[HUFFMAN_CODES_PER_META_CODE];
|
|
|
|
} HTreeGroup;
|
|
|
|
|
2012-04-11 02:23:38 +02:00
|
|
|
typedef struct {
|
|
|
|
int color_cache_size_;
|
|
|
|
VP8LColorCache *color_cache_;
|
|
|
|
|
|
|
|
int huffman_mask_;
|
|
|
|
int huffman_subsample_bits_;
|
|
|
|
int huffman_xsize_;
|
|
|
|
uint32_t *huffman_image_;
|
2012-04-23 17:36:14 +02:00
|
|
|
int num_htree_groups_;
|
|
|
|
HTreeGroup *htree_groups_;
|
2012-04-11 02:23:38 +02:00
|
|
|
} VP8LMetadata;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
VP8StatusCode status_;
|
|
|
|
VP8LDecodeState action_;
|
|
|
|
VP8LDecodeState state_;
|
|
|
|
VP8Io *io_;
|
|
|
|
|
|
|
|
uint32_t *argb_; // Internal data: always in BGRA color mode.
|
|
|
|
uint32_t *argb_cache_; // Scratch buffer for temporary BGRA storage.
|
|
|
|
|
2012-04-13 10:56:31 +02:00
|
|
|
VP8LBitReader br_;
|
2012-04-11 02:23:38 +02:00
|
|
|
|
|
|
|
int width_;
|
|
|
|
int height_;
|
|
|
|
int last_row_; // last input row decoded so far.
|
|
|
|
int last_out_row_; // last row output so far.
|
|
|
|
|
|
|
|
VP8LMetadata hdr_;
|
|
|
|
|
|
|
|
int next_transform_;
|
|
|
|
VP8LTransform transforms_[NUM_TRANSFORMS];
|
2012-05-24 11:04:23 +02:00
|
|
|
// or'd bitset storing the transforms types.
|
|
|
|
uint32_t transforms_seen_;
|
2012-04-11 02:23:38 +02:00
|
|
|
|
|
|
|
uint8_t *rescaler_memory; // Working memory for rescaling work.
|
|
|
|
WebPRescaler *rescaler; // Common rescaler for all channels.
|
|
|
|
} VP8LDecoder;
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
// internal functions. Not public.
|
|
|
|
|
|
|
|
// in vp8l.c
|
|
|
|
|
|
|
|
// Validates the VP8L data-header and retrieves basic header information viz
|
|
|
|
// width and height. Returns 0 in case of formatting error. width/height
|
|
|
|
// can be passed NULL.
|
2012-05-23 21:45:05 +02:00
|
|
|
int VP8LGetInfo(const uint8_t* data, size_t data_size, // data available so far
|
|
|
|
int* const width, int* const height);
|
2012-04-11 02:23:38 +02:00
|
|
|
|
2012-05-23 17:01:44 +02:00
|
|
|
|
|
|
|
// Decodes a raw image stream (without header) and store the alpha data
|
|
|
|
// into *output, which must be of size width x height. Returns false in case
|
|
|
|
// of error.
|
|
|
|
int VP8LDecodeAlphaImageStream(int width, int height, const uint8_t* const data,
|
2012-05-23 21:45:05 +02:00
|
|
|
size_t data_size, uint8_t* const output);
|
2012-05-23 17:01:44 +02:00
|
|
|
|
2012-04-11 02:23:38 +02:00
|
|
|
// Allocates and initialize a new lossless decoder instance.
|
|
|
|
VP8LDecoder* VP8LNew(void);
|
|
|
|
|
|
|
|
// Decodes the image header. Returns false in case of error.
|
|
|
|
int VP8LDecodeHeader(VP8LDecoder* const dec, VP8Io* const io);
|
|
|
|
|
|
|
|
// Decodes an image. It's required to decode the lossless header before calling
|
|
|
|
// this function. Returns false in case of error, with updated dec->status_.
|
|
|
|
int VP8LDecodeImage(VP8LDecoder* const dec);
|
|
|
|
|
|
|
|
// Resets the decoder in its initial state, reclaiming memory.
|
2012-04-05 11:31:10 +02:00
|
|
|
// Preserves the dec->status_ value.
|
2012-04-11 02:23:38 +02:00
|
|
|
void VP8LClear(VP8LDecoder* const dec);
|
|
|
|
|
|
|
|
// Clears and deallocate a lossless decoder instance.
|
|
|
|
void VP8LDelete(VP8LDecoder* const dec);
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#if defined(__cplusplus) || defined(c_plusplus)
|
|
|
|
} // extern "C"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* WEBP_DEC_VP8LI_H_ */
|