36 #define CHARSET_CHARS 256
38 #define CROP_SCREENS 1
63 static const int mc_colors[5]={0x0,0xb,0xc,0xf,0x1};
71 int blockx, blocky, x,
y;
77 for (blocky = 0; blocky <
C64YRES; blocky += 8) {
78 for (blockx = 0; blockx <
C64XRES; blockx += 8) {
79 for (y = blocky; y < blocky + 8 && y <
C64YRES; y++) {
80 for (x = blockx; x < blockx + 8 && x <
C64XRES; x += 2) {
81 if(x < width && y < height) {
84 luma = (src[(x + 0 + y * p->
linesize[0])] +
85 src[(x + 1 + y * p->
linesize[0])]) / 2;
87 luma = src[(x + y * p->
linesize[0])];
107 int lowdiff, highdiff;
117 for (a=0; a < 256; a++) {
118 if(i < c->mc_pal_size -1 && a == c->
mc_luma_vals[i + 1]) {
134 for (y = 0; y < 8; y++) {
136 for (x = 0; x < 4; x++) {
137 pix = best_cb[y * 4 + x];
140 if (index1[pix] >= 3)
150 row1 |= 3-(index2[pix] & 3);
152 row1 |= 3-(index1[pix] & 3);
155 row2 |= 3-(index2[pix] & 3);
157 row2 |= 3-(index1[pix] & 3);
161 row1 |= 3-(index2[pix] & 3);
163 row1 |= 3-(index1[pix] & 3);
166 charset[y+0x000] = row1;
170 if (highdiff > 0 && lowdiff > 0 && c->
mc_use_5col) {
171 if (lowdiff > highdiff) {
172 for (x = 0; x < 32; x++)
175 for (x = 0; x < 32; x++)
186 colrammap[charpos] = (highdiff > 0);
259 for (a = 0; a < 256; a++) {
260 temp = colram[charmap[a + 0x000]] << 0;
261 temp |= colram[charmap[a + 0x100]] << 1;
262 temp |= colram[charmap[a + 0x200]] << 2;
263 if (a < 0xe8) temp |= colram[charmap[a + 0x300]] << 3;
269 const AVFrame *p,
int *got_packet)
294 screen_size = b_width * b_height;
329 int alloc_size = charset_size + c->
mc_lifetime*(screen_size + colram_size);
348 memcpy(buf, charset, charset_size);
352 req_size += charset_size;
358 for (y = 0; y < b_height; y++) {
359 for (x = 0; x < b_width; x++) {
360 buf[y * b_width + x] = charmap[y * b_width + x];
365 req_size += screen_size;
372 req_size += colram_size;
390 pkt->
size = req_size;
392 *got_packet = !!req_size;
397 #if CONFIG_A64MULTI_ENCODER
398 AVCodec ff_a64multi_encoder = {
411 #if CONFIG_A64MULTI5_ENCODER
412 AVCodec ff_a64multi5_encoder = {
414 .long_name =
NULL_IF_CONFIG_SMALL(
"Multicolor charset for Commodore 64, extended with 5th color (colram)"),
int ff_alloc_packet2(AVCodecContext *avctx, AVPacket *avpkt, int64_t size)
Check AVPacket size and/or allocate data.
const struct AVCodec * codec
This structure describes decoded (raw) audio or video data.
static av_cold int init(AVCodecContext *avctx)
#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 CODEC_CAP_DELAY
Encoder or decoder requires flushing with NULL input at the end in order to give the complete and cor...
#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.
int flags
A combination of AV_PKT_FLAG values.
static float distance(float x, float y, int band)
#define FF_INPUT_BUFFER_PADDING_SIZE
Required number of additionally allocated bytes at the end of the input bitstream for decoding...
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').
BYTE int const BYTE int int int height
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 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
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...
static void * av_mallocz_array(size_t nmemb, size_t size)
uint64_t_TMPL AV_WL64 unsigned int_TMPL AV_RL32
AVPixelFormat
Pixel format.
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.
static const uint8_t multi_dither_patterns[9][4][4]
dither patterns used vor rendering the multicolor charset