dos33fsprogs/gr-utils/loadpng.c
2017-05-03 22:21:19 -04:00

169 lines
4.0 KiB
C

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <stdarg.h>
#include <png.h>
/* expects a PNG where the xsize is *2 */
int loadpng(char *filename, unsigned char **image_ptr, int *xsize, int *ysize) {
int x,y;
int color;
FILE *infile;
int debug=0;
unsigned char *image;
int width, height;
png_byte bit_depth;
png_structp png_ptr;
png_infop info_ptr;
png_bytep *row_pointers;
// png_byte color_type;
// int number_of_passes;
unsigned char header[8];
/* open file and test for it being a png */
infile = fopen(filename, "rb");
if (infile==NULL) {
fprintf(stderr,"Error! Could not open %s\n",filename);
return -1;
}
/* Check the header */
fread(header, 1, 8, infile);
if (png_sig_cmp(header, 0, 8)) {
fprintf(stderr,"Error! %s is not a PNG file\n",filename);
return -1;
}
/* initialize stuff */
png_ptr = png_create_read_struct(PNG_LIBPNG_VER_STRING, NULL, NULL, NULL);
if (!png_ptr) {
fprintf(stderr,"Error create_read_struct\n");
exit(-1);
}
info_ptr = png_create_info_struct(png_ptr);
if (!info_ptr) {
fprintf(stderr,"Error png_create_info_struct\n");
exit(-1);
}
png_init_io(png_ptr, infile);
png_set_sig_bytes(png_ptr, 8);
png_read_info(png_ptr, info_ptr);
width = png_get_image_width(png_ptr, info_ptr);
height = png_get_image_height(png_ptr, info_ptr);
*xsize=width/2;
*ysize=height;
// color_type = png_get_color_type(png_ptr, info_ptr);
bit_depth = png_get_bit_depth(png_ptr, info_ptr);
if (debug) {
printf("PNG: width=%d height=%d depth=%d\n",width,height,bit_depth);
}
// number_of_passes = png_set_interlace_handling(png_ptr);
png_read_update_info(png_ptr, info_ptr);
row_pointers = (png_bytep*) malloc(sizeof(png_bytep) * height);
for (y=0; y<height; y++) {
row_pointers[y] = (png_byte*) malloc(png_get_rowbytes(png_ptr,info_ptr));
}
png_read_image(png_ptr, row_pointers);
fclose(infile);
image=calloc(width*height,sizeof(unsigned char));
if (image==NULL) {
fprintf(stderr,"Memory error!\n");
return -1;
}
for(y=0;y<height;y++) {
for(x=0;x<width/2;x++) {
color= (row_pointers[y][x*2*4]<<16)+
(row_pointers[y][x*2*4+1]<<8)+
(row_pointers[y][x*2*4+2]);
if (debug) {
printf("%x ",color);
// printf("(%x,%x,%x,%x) ",
// row_pointers[y][x*2*4],
// row_pointers[y][x*2*4+1],
// row_pointers[y][x*2*4+2],
// row_pointers[y][x*2*4+3]);
}
switch(color) {
case 0: image[(y*width/2)+x]=0; /* black */
break;
case 0xe31e60: image[(y*width/2)+x]=1; /* magenta */
break;
case 0x604ebd: image[(y*width/2)+x]=2; /* dark blue */
break;
case 0xff44fd: image[(y*width/2)+x]=3; /* purple */
break;
case 0xa360: image[(y*width/2)+x]=4; /* dark green */
break;
case 0x9c9c9c: image[(y*width/2)+x]=5; /* grey 1 */
break;
case 0x14cffd: image[(y*width/2)+x]=6; /* medium blue */
break;
case 0xd0c3ff: image[(y*width/2)+x]=7; /* light blue */
break;
case 0x607203: image[(y*width/2)+x]=8; /* brown */
break;
case 0xff6a3c: image[(y*width/2)+x]=9; /* orange */
break;
case 0x9d9d9d: image[(y*width/2)+x]=10; /* grey 2 */
break;
case 0xffa0d0: image[(y*width/2)+x]=11; /* pink */
break;
case 0x14f53c: image[(y*width/2)+x]=12; /* bright green */
break;
case 0xd0dd8d: image[(y*width/2)+x]=13; /* yellow */
break;
case 0x72ffd0: image[(y*width/2)+x]=14; /* aqua */
break;
case 0xffffff: image[(y*width/2)+x]=15; /* white */
break;
default:
printf("Unknown color %x\n",color);
image[(y*width/2)+x]=0; break;
}
}
if (debug) printf("\n");
}
/* Stripe test image */
// for(x=0;x<40;x++) for(y=0;y<40;y++) image[(y*width)+x]=y%16;
/*
Addr Row /80 %40
$400 0 0 0 0
$428 28 16 0
$450 50 32 0
$480 80 2 1
$4A8 a8 18 1
$4D0 d0 34 1
$500 100 3 2
0,0 0,1 0,2....0,39 16,0 16,1 ....16,39 32,0..32,39, X X X X X X X X
*/
*image_ptr=image;
return 0;
}