39 if (buf[2] !=
':' || buf[5] !=
':' || buf[8] !=
'.')
46 return ms - packet_time;
52 int buf_size = avpkt->
size;
54 const uint8_t *buf_end = buf + buf_size;
57 int64_t packet_time = 0;
62 if (buf_size < 27 + 7 * 2 + 4 * (3 + has_alpha)) {
68 if (buf[0] !=
'[' || buf[13] !=
'-' || buf[26] !=
']') {
79 w = bytestream_get_le16(&
buf);
80 h = bytestream_get_le16(&
buf);
83 x = bytestream_get_le16(&
buf);
84 y = bytestream_get_le16(&
buf);
86 bytestream_get_le16(&
buf);
87 bytestream_get_le16(&
buf);
92 bytestream_get_le16(&
buf);
99 sub->rects[0] =
av_mallocz(
sizeof(*sub->rects[0]));
100 if (!sub->rects[0]) {
104 sub->rects[0]->x = x; sub->rects[0]->y =
y;
105 sub->rects[0]->w = w; sub->rects[0]->h =
h;
107 sub->rects[0]->pict.linesize[0] = w;
108 sub->rects[0]->pict.data[0] =
av_malloc(w *
h);
109 sub->rects[0]->nb_colors = 4;
111 if (!sub->rects[0]->pict.data[0] || !sub->rects[0]->pict.data[1]) {
112 av_freep(&sub->rects[0]->pict.data[1]);
113 av_freep(&sub->rects[0]->pict.data[0]);
121 for (i = 0; i < sub->rects[0]->nb_colors; i++)
122 ((uint32_t*)sub->rects[0]->pict.data[1])[i] = bytestream_get_be24(&
buf);
126 for (i = 1; i < sub->rects[0]->nb_colors; i++)
127 ((uint32_t *)sub->rects[0]->pict.data[1])[i] |= 0xff000000;
129 for (i = 0; i < sub->rects[0]->nb_colors; i++)
130 ((uint32_t *)sub->rects[0]->pict.data[1])[i] |= *
buf++ << 24;
135 bitmap = sub->rects[0]->pict.data[0];
136 for (
y = 0;
y <
h;
y++) {
138 if (
y == (h + 1) / 2) bitmap = sub->rects[0]->pict.data[0] + w;
139 for (x = 0; x < w; ) {
143 run =
FFMIN(run, w - x);
145 if (!run) run = w - x;
146 memset(bitmap, color, run);
ptrdiff_t const GLvoid * data
static unsigned int get_bits(GetBitContext *s, int n)
Read 1-25 bits.
enum AVPixelFormat pix_fmt
Pixel format, see AV_PIX_FMT_xxx.
8 bit with AV_PIX_FMT_RGB32 palette
static const uint8_t tc_muls[9]
bitstream reader API header.
const uint8_t ff_log2_tab[256]
int64_t av_rescale_q(int64_t a, AVRational bq, AVRational cq)
Rescale a 64-bit integer by 2 rational numbers.
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
static av_cold int decode_init(AVCodecContext *avctx)
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
static int decode_frame(AVCodecContext *avctx, void *data, int *data_size, AVPacket *avpkt)
static int64_t parse_timecode(const uint8_t *buf, int64_t packet_time)
const char * name
Name of the codec implementation.
static const uint8_t tc_offsets[9]
Libavcodec external API header.
int av_image_check_size(unsigned int w, unsigned int h, int log_offset, void *log_ctx)
Check if the given dimension of an image is valid, meaning that all bytes of the image can be address...
A bitmap, pict will be set.
static unsigned int show_bits(GetBitContext *s, int n)
Show 1-25 bits.
#define AV_TIME_BASE_Q
Internal time base represented as fractional value.
main external API structure.
unsigned int codec_tag
fourcc (LSB first, so "ABCD" -> ('D'<<24) + ('C'<<16) + ('B'<<8) + 'A').
rational number numerator/denominator
static int init_get_bits(GetBitContext *s, const uint8_t *buffer, int bit_size)
Initialize GetBitContext.
static const uint8_t * align_get_bits(GetBitContext *s)
#define MKTAG(a, b, c, d)
This structure stores compressed data.
void * av_mallocz(size_t size)
Allocate a block of size bytes with alignment suitable for all memory accesses (including vectors if ...
int64_t pts
Presentation timestamp in AVStream->time_base units; the time at which the decompressed packet will b...
#define AV_NOPTS_VALUE
Undefined timestamp value.