72 for (j = 0; j < 2; j++)
73 memset(dst + j * linesize, v[0], 2);
78 for (j = 0; j < 2; j++)
79 for (i = 0; i < 2; i++)
83 for (j = 0; j < 2; j++)
84 for (i = 0; i < 2; i++)
85 dst[j * linesize + i] =
get_bits(gb, 8);
99 for (j = 0; j < 4; j++)
100 memset(dst + j * linesize, v[0], 4);
105 for (j = 2; j >= 0; j -= 2) {
106 for (i = 0; i < 4; i++)
107 dst[j * linesize + i] = v[
get_bits1(gb)];
108 for (i = 0; i < 4; i++)
109 dst[(j + 1) * linesize + i] = v[
get_bits1(gb)];
113 for (j = 0; j < 4; j += 2)
114 for (i = 0; i < 4; i += 2)
115 decode2x2(gb, dst + j * linesize + i, linesize);
135 for (j = 7; j >= 0; j--)
136 for (i = 0; i < 8; i++)
137 dst[j * linesize + i] = v[
get_bits1(gb)];
140 for (j = 0; j < 8; j += 4)
141 for (i = 0; i < 8; i += 4)
142 decode4x4(gb, dst + j * linesize + i, linesize);
152 int video_size, video_type, i, j, ret;
162 if (video_size < 0 || video_size > avpkt->
size - 5) {
169 if (video_type == 0 || video_type == 1) {
173 for (j = 0; j < avctx->
height; j += 8)
174 for (i = 0; i < avctx->
width; i += 8)
180 }
else if (video_type == 2) {
182 for (j = 0; j < avctx->
height; j++)
187 "unsupported frame type %i\n", video_type);
195 s->
palette[i] = 0xFFU << 24 | pal << 2 | ((pal >> 4) & 0x30303);
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
This structure describes decoded (raw) audio or video data.
ptrdiff_t const GLvoid * data
static unsigned int get_bits(GetBitContext *s, int n)
Read 1-25 bits.
#define AV_LOG_WARNING
Something somehow does not look correct.
static av_cold int init(AVCodecContext *avctx)
av_cold void ff_blockdsp_init(BlockDSPContext *c, AVCodecContext *avctx)
static void decode8x8(GetBitContext *gb, uint8_t *dst, int linesize, BlockDSPContext *bdsp)
Decode 8x8 block.
enum AVPixelFormat pix_fmt
Pixel format, see AV_PIX_FMT_xxx.
static av_cold int decode_init(AVCodecContext *avctx)
static void decode(AVCodecContext *dec_ctx, AVPacket *pkt, AVFrame *frame, FILE *outfile)
int ff_reget_buffer(AVCodecContext *avctx, AVFrame *frame)
Identical in function to av_frame_make_writable(), except it uses ff_get_buffer() to allocate the buf...
AVFrame * av_frame_alloc(void)
Allocate an AVFrame and set its fields to default values.
8 bits with AV_PIX_FMT_RGB32 palette
uint32_t palette[AVPALETTE_COUNT]
int av_frame_ref(AVFrame *dst, const AVFrame *src)
Set up a new reference to the data described by the source frame.
bitstream reader API header.
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
void av_frame_free(AVFrame **frame)
Free the frame and any dynamically allocated objects in it, e.g.
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
const char * name
Name of the codec implementation.
static int decode_frame(AVCodecContext *avctx, void *data, int *got_frame, AVPacket *avpkt)
enum AVPictureType pict_type
Picture type of the frame.
int width
picture width / height.
Libavcodec external API header.
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_WL32 unsigned int_TMPL AV_WL24 unsigned int_TMPL AV_WL16 uint64_t_TMPL AV_WB64 unsigned int_TMPL AV_WB32 unsigned int_TMPL AV_RB24
int linesize[AV_NUM_DATA_POINTERS]
For video, size in bytes of each picture line.
main external API structure.
static unsigned int get_bits1(GetBitContext *s)
static int init_get_bits(GetBitContext *s, const uint8_t *buffer, int bit_size)
Initialize GetBitContext.
int palette_has_changed
Tell user application that palette has changed from previous frame.
static av_cold int decode_close(AVCodecContext *avctx)
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
static void decode2x2(GetBitContext *gb, uint8_t *dst, int linesize)
Decode 2x2 block.
common internal api header.
static void decode4x4(GetBitContext *gb, uint8_t *dst, int linesize)
Decode 4x4 block.
int key_frame
1 -> keyframe, 0-> not
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_RL32
This structure stores compressed data.
#define AV_CODEC_CAP_DR1
Codec uses get_buffer() for allocating buffers and supports custom allocators.
op_fill_func fill_block_tab[2]