parent
3fcf0e3db7
commit
76cb5801f6
57
sixel.c
57
sixel.c
@ -212,16 +212,15 @@ sixel_parser_set_default_color(sixel_state_t *st)
|
|||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
sixel_parser_finalize(sixel_state_t *st, unsigned char *pixels)
|
sixel_parser_finalize(sixel_state_t *st, unsigned char **pixels)
|
||||||
{
|
{
|
||||||
int status = (-1);
|
int status = (-1);
|
||||||
int sx;
|
|
||||||
int sy;
|
|
||||||
sixel_image_t *image = &st->image;
|
sixel_image_t *image = &st->image;
|
||||||
int x, y;
|
int x, y;
|
||||||
sixel_color_no_t *src;
|
sixel_color_no_t *src;
|
||||||
unsigned char *dst;
|
unsigned char *dst;
|
||||||
int color;
|
int color;
|
||||||
|
int w, h;
|
||||||
|
|
||||||
if (++st->max_x < st->attributed_ph)
|
if (++st->max_x < st->attributed_ph)
|
||||||
st->max_x = st->attributed_ph;
|
st->max_x = st->attributed_ph;
|
||||||
@ -229,51 +228,35 @@ sixel_parser_finalize(sixel_state_t *st, unsigned char *pixels)
|
|||||||
if (++st->max_y < st->attributed_pv)
|
if (++st->max_y < st->attributed_pv)
|
||||||
st->max_y = st->attributed_pv;
|
st->max_y = st->attributed_pv;
|
||||||
|
|
||||||
sx = (st->max_x + st->grid_width - 1) / st->grid_width * st->grid_width;
|
|
||||||
sy = (st->max_y + st->grid_height - 1) / st->grid_height * st->grid_height;
|
|
||||||
|
|
||||||
if (image->width > sx || image->height > sy) {
|
|
||||||
status = image_buffer_resize(image, sx, sy);
|
|
||||||
if (status < 0)
|
|
||||||
goto end;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (image->use_private_register && image->ncolors > 2 && !image->palette_modified) {
|
if (image->use_private_register && image->ncolors > 2 && !image->palette_modified) {
|
||||||
status = set_default_color(image);
|
status = set_default_color(image);
|
||||||
if (status < 0)
|
if (status < 0)
|
||||||
goto end;
|
goto end;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
w = st->max_x < image->width ? st->max_x : image->width;
|
||||||
|
h = st->max_y < image->height ? st->max_y : image->height;
|
||||||
|
|
||||||
|
*pixels = malloc(w * h * 4);
|
||||||
|
if (*pixels == NULL)
|
||||||
|
goto end;
|
||||||
|
|
||||||
src = st->image.data;
|
src = st->image.data;
|
||||||
dst = pixels;
|
dst = *pixels;
|
||||||
for (y = 0; y < st->image.height; ++y) {
|
for (y = 0; y < h; y++) {
|
||||||
for (x = 0; x < st->image.width; ++x) {
|
src = st->image.data + image->width * y;
|
||||||
|
for (x = 0; x < w; ++x) {
|
||||||
color = st->image.palette[*src++];
|
color = st->image.palette[*src++];
|
||||||
*dst++ = color >> 16 & 0xff; /* b */
|
*dst++ = color >> 16 & 0xff; /* b */
|
||||||
*dst++ = color >> 8 & 0xff; /* g */
|
*dst++ = color >> 8 & 0xff; /* g */
|
||||||
*dst++ = color >> 0 & 0xff; /* r */
|
*dst++ = color >> 0 & 0xff; /* r */
|
||||||
*dst++ = color >> 24 & 0xff; /* a */
|
*dst++ = color >> 24 & 0xff; /* a */
|
||||||
}
|
}
|
||||||
/* fill right padding with bgcolor */
|
|
||||||
for (; x < st->image.width; ++x) {
|
|
||||||
color = st->image.palette[0]; /* bgcolor */
|
|
||||||
*dst++ = color >> 16 & 0xff; /* b */
|
|
||||||
*dst++ = color >> 8 & 0xff; /* g */
|
|
||||||
*dst++ = color >> 0 & 0xff; /* r */
|
|
||||||
*dst++ = color >> 24 & 0xff; /* a */
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/* fill bottom padding with bgcolor */
|
|
||||||
for (; y < st->image.height; ++y) {
|
|
||||||
for (x = 0; x < st->image.width; ++x) {
|
|
||||||
color = st->image.palette[0]; /* bgcolor */
|
|
||||||
*dst++ = color >> 16 & 0xff; /* b */
|
|
||||||
*dst++ = color >> 8 & 0xff; /* g */
|
|
||||||
*dst++ = color >> 0 & 0xff; /* r */
|
|
||||||
*dst++ = color >> 24 & 0xff; /* a */
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
image->width = w;
|
||||||
|
image->height = h;
|
||||||
|
|
||||||
status = (0);
|
status = (0);
|
||||||
|
|
||||||
end:
|
end:
|
||||||
@ -371,7 +354,7 @@ sixel_parser_parse(sixel_state_t *st, unsigned char *p, size_t len)
|
|||||||
if (st->pos_x + st->repeat_count > image->width)
|
if (st->pos_x + st->repeat_count > image->width)
|
||||||
st->repeat_count = image->width - st->pos_x;
|
st->repeat_count = image->width - st->pos_x;
|
||||||
|
|
||||||
if (st->repeat_count > 0 && st->pos_y - 5 < image->height) {
|
if (st->repeat_count > 0 && st->pos_y + 5 < image->height) {
|
||||||
bits = *p - '?';
|
bits = *p - '?';
|
||||||
if (bits != 0) {
|
if (bits != 0) {
|
||||||
sixel_vertical_mask = 0x01;
|
sixel_vertical_mask = 0x01;
|
||||||
@ -477,8 +460,10 @@ sixel_parser_parse(sixel_state_t *st, unsigned char *p, size_t len)
|
|||||||
if (image->height > st->attributed_pv)
|
if (image->height > st->attributed_pv)
|
||||||
sy = image->height;
|
sy = image->height;
|
||||||
|
|
||||||
sx = (sx + st->grid_width - 1) / st->grid_width * st->grid_width;
|
/* the height of the image buffer must be divisible by 6
|
||||||
sy = (sy + st->grid_height - 1) / st->grid_height * st->grid_height;
|
* to avoid unnecessary resizing of the image buffer in
|
||||||
|
* sixel_parser_parse() */
|
||||||
|
sy = (sy + 5) / 6 * 6;
|
||||||
|
|
||||||
if (sx > DECSIXEL_WIDTH_MAX)
|
if (sx > DECSIXEL_WIDTH_MAX)
|
||||||
sx = DECSIXEL_WIDTH_MAX;
|
sx = DECSIXEL_WIDTH_MAX;
|
||||||
|
2
sixel.h
2
sixel.h
@ -52,7 +52,7 @@ typedef struct parser_context {
|
|||||||
int sixel_parser_init(sixel_state_t *st, sixel_color_t fgcolor, sixel_color_t bgcolor, unsigned char use_private_register, int cell_width, int cell_height);
|
int sixel_parser_init(sixel_state_t *st, sixel_color_t fgcolor, sixel_color_t bgcolor, unsigned char use_private_register, int cell_width, int cell_height);
|
||||||
int sixel_parser_parse(sixel_state_t *st, unsigned char *p, size_t len);
|
int sixel_parser_parse(sixel_state_t *st, unsigned char *p, size_t len);
|
||||||
int sixel_parser_set_default_color(sixel_state_t *st);
|
int sixel_parser_set_default_color(sixel_state_t *st);
|
||||||
int sixel_parser_finalize(sixel_state_t *st, unsigned char *pixels);
|
int sixel_parser_finalize(sixel_state_t *st, unsigned char **pixels);
|
||||||
void sixel_parser_deinit(sixel_state_t *st);
|
void sixel_parser_deinit(sixel_state_t *st);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
12
st.c
12
st.c
@ -2650,16 +2650,16 @@ strhandle(void)
|
|||||||
term.mode &= ~MODE_SIXEL;
|
term.mode &= ~MODE_SIXEL;
|
||||||
new_image = malloc(sizeof(ImageList));
|
new_image = malloc(sizeof(ImageList));
|
||||||
memset(new_image, 0, sizeof(ImageList));
|
memset(new_image, 0, sizeof(ImageList));
|
||||||
|
if (sixel_parser_finalize(&sixel_st, &new_image->pixels) != 0) {
|
||||||
|
perror("sixel_parser_finalize() failed");
|
||||||
|
sixel_parser_deinit(&sixel_st);
|
||||||
|
free(new_image);
|
||||||
|
return;
|
||||||
|
}
|
||||||
new_image->x = term.c.x;
|
new_image->x = term.c.x;
|
||||||
new_image->y = term.c.y;
|
new_image->y = term.c.y;
|
||||||
new_image->width = sixel_st.image.width;
|
new_image->width = sixel_st.image.width;
|
||||||
new_image->height = sixel_st.image.height;
|
new_image->height = sixel_st.image.height;
|
||||||
new_image->pixels = malloc(new_image->width * new_image->height * 4);
|
|
||||||
if (sixel_parser_finalize(&sixel_st, new_image->pixels) != 0) {
|
|
||||||
perror("sixel_parser_finalize() failed");
|
|
||||||
sixel_parser_deinit(&sixel_st);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
sixel_parser_deinit(&sixel_st);
|
sixel_parser_deinit(&sixel_st);
|
||||||
if (term.images) {
|
if (term.images) {
|
||||||
ImageList *im;
|
ImageList *im;
|
||||||
|
Loading…
Reference in New Issue
Block a user