36 #define CHARSET_CHARS 256
38 #define CROP_SCREENS 1
63 static const int mc_colors[5]={0x0,0xb,0xc,0xf,0x1};
72 int blockx, blocky, x, y;
78 for (blocky = 0; blocky <
C64YRES; blocky += 8) {
79 for (blockx = 0; blockx <
C64XRES; blockx += 8) {
80 for (y = blocky; y < blocky + 8 && y <
C64YRES; y++) {
81 for (x = blockx; x < blockx + 8 && x <
C64XRES; x += 2) {
82 if(x < width && y < height) {
85 luma = (src[(x + 0 + y * p->
linesize[0])] +
86 src[(x + 1 + y * p->
linesize[0])]) / 2;
88 luma = src[(x + y * p->
linesize[0])];
108 int lowdiff, highdiff;
118 for (a=0; a < 256; a++) {
119 if(i < c->mc_pal_size -1 && a == c->
mc_luma_vals[i + 1]) {
135 for (y = 0; y < 8; y++) {
137 for (x = 0; x < 4; x++) {
138 pix = best_cb[y * 4 + x];
141 if (index1[pix] >= 3)
151 row1 |= 3-(index2[pix] & 3);
153 row1 |= 3-(index1[pix] & 3);
156 row2 |= 3-(index2[pix] & 3);
158 row2 |= 3-(index1[pix] & 3);
162 row1 |= 3-(index2[pix] & 3);
164 row1 |= 3-(index1[pix] & 3);
167 charset[y+0x000] = row1;
171 if (highdiff > 0 && lowdiff > 0 && c->
mc_use_5col) {
172 if (lowdiff > highdiff) {
173 for (x = 0; x < 32; x++)
176 for (x = 0; x < 32; x++)
187 colrammap[charpos] = (highdiff > 0);
260 for (a = 0; a < 256; a++) {
261 temp = colram[charmap[a + 0x000]] << 0;
262 temp |= colram[charmap[a + 0x100]] << 1;
263 temp |= colram[charmap[a + 0x200]] << 2;
264 if (a < 0xe8) temp |= colram[charmap[a + 0x300]] << 3;
270 const AVFrame *p,
int *got_packet)
295 screen_size = b_width * b_height;
330 int alloc_size = charset_size + c->
mc_lifetime*(screen_size + colram_size);
349 memcpy(buf, charset, charset_size);
353 req_size += charset_size;
359 for (y = 0; y < b_height; y++) {
360 for (x = 0; x < b_width; x++) {
361 buf[y * b_width + x] = charmap[y * b_width + x];
366 req_size += screen_size;
373 req_size += colram_size;
391 pkt->
size = req_size;
393 *got_packet = !!req_size;
398 #if CONFIG_A64MULTI_ENCODER
399 AVCodec ff_a64multi_encoder = {
412 #if CONFIG_A64MULTI5_ENCODER
413 AVCodec ff_a64multi5_encoder = {
415 .long_name =
NULL_IF_CONFIG_SMALL(
"Multicolor charset for Commodore 64, extended with 5th color (colram)"),
const struct AVCodec * codec
This structure describes decoded (raw) audio or video data.
static av_cold int init(AVCodecContext *avctx)
void * av_mallocz(size_t size)
Allocate a memory block with alignment suitable for all memory accesses (including vectors if availab...
#define AV_CODEC_CAP_DELAY
Encoder or decoder requires flushing with NULL input at the end in order to give the complete and cor...
#define av_assert0(cond)
assert() equivalent, that is always enabled.
int64_t pts
Presentation timestamp in time_base units (time when frame should be shown to user).
uint8_t * extradata
some codecs need / can use extradata like Huffman tables.
int avpriv_do_elbg(int *points, int dim, int numpoints, int *codebook, int numCB, int max_steps, int *closest_cb, AVLFG *rand_state)
Implementation of the Enhanced LBG Algorithm Based on the paper "Neural Networks 14:1219-1237" that c...
#define AV_PKT_FLAG_KEY
The packet contains a keyframe.
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
static const uint8_t dither[8][8]
simple assert() macros that are a bit more flexible than ISO C assert().
a64 video encoder - tables used by a64 encoders
const char * name
Name of the codec implementation.
static void * av_mallocz_array(size_t nmemb, size_t size)
int flags
A combination of AV_PKT_FLAG values.
static float distance(float x, float y, int band)
static int a64multi_encode_frame(AVCodecContext *avctx, AVPacket *pkt, const AVFrame *p, int *got_packet)
unsigned mc_frame_counter
static void a64_compress_colram(unsigned char *buf, int *charmap, uint8_t *colram)
int width
picture width / height.
#define AV_LOG_INFO
Standard information.
static void render_charset(AVCodecContext *avctx, uint8_t *charset, uint8_t *colrammap)
int avpriv_init_elbg(int *points, int dim, int numpoints, int *codebook, int numCB, int max_steps, int *closest_cb, AVLFG *rand_state)
Initialize the **codebook vector for the elbg algorithm.
int linesize[AV_NUM_DATA_POINTERS]
For video, size in bytes of each picture line.
main external API structure.
unsigned int codec_tag
fourcc (LSB first, so "ABCD" -> ('D'<<24) + ('C'<<16) + ('B'<<8) + 'A').
static void to_meta_with_crop(AVCodecContext *avctx, const AVFrame *p, int *dest)
a64 video encoder - c64 colors in rgb
static const int mc_colors[5]
av_cold void av_lfg_init(AVLFG *c, unsigned int seed)
int ff_alloc_packet2(AVCodecContext *avctx, AVPacket *avpkt, int64_t size, int64_t min_size)
Check AVPacket size and/or allocate data.
static enum AVPixelFormat pix_fmts[]
int global_quality
Global quality for codecs which cannot change it per frame.
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
static av_cold int a64multi_encode_init(AVCodecContext *avctx)
common internal api header.
common internal and external API header
#define AV_INPUT_BUFFER_PADDING_SIZE
Required number of additionally allocated bytes at the end of the input bitstream for decoding...
static const uint8_t a64_palette[16][3]
static const uint8_t interlaced_dither_patterns[9][8][4]
#define FF_QP2LAMBDA
factor to convert from H.263 QP to lambda
static av_cold int a64multi_close_encoder(AVCodecContext *avctx)
int64_t dts
Decompression timestamp in AVStream->time_base units; the time at which the packet is decompressed...
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_RL32
AVPixelFormat
Pixel format.
This structure stores compressed data.
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.
static const uint8_t multi_dither_patterns[9][4][4]
dither patterns used vor rendering the multicolor charset