From a3d5057560895f1c31367114727a01ac57395e0f Mon Sep 17 00:00:00 2001 From: Vince Weaver Date: Mon, 10 Jul 2017 14:52:24 -0400 Subject: [PATCH] gr-utils: fix the RLE code was having edge-of-screen wrap issues --- gr-sim/backgrounds.h | 31 +++++++-------- gr-sim/gr-sim.c | 10 ++++- gr-sim/tfv.c | 22 +++++++++-- gr-utils/loadpng.c | 94 +++++++++++++++++++++++--------------------- gr-utils/png2rle.c | 44 +++++++++++++++------ 5 files changed, 124 insertions(+), 77 deletions(-) diff --git a/gr-sim/backgrounds.h b/gr-sim/backgrounds.h index d55114f7..bdc2994e 100644 --- a/gr-sim/backgrounds.h +++ b/gr-sim/backgrounds.h @@ -50,19 +50,18 @@ static unsigned char worldmap_rle[]= static unsigned char landing_rle[]= { 0x28,0x28, -0x03,0x66,0x01,0x56, -0x27,0x66,0x01,0x55,0x01,0xF5, -0x26,0x66,0x01,0x55,0x01,0xFF,0x01,0xF5, -0x25,0x66,0x01,0x55,0x02,0xFF,0x01,0xF5, -0x24,0x66,0x01,0x55,0x03,0xFF,0x01,0xF5,0x20,0x66, -0x01,0x46,0x01,0x24,0x01,0x44,0x01,0x55,0x0F,0xF5,0x04,0x22, -0x12,0x44,0x01,0x62,0x01,0x22,0x01,0x55,0x01,0xFF,0x03,0x11,0x01,0x44,0x03,0x22,0x01,0x44,0x03,0x22,0x03,0xFF,0x05,0x22, -0x11,0x44,0x01,0x22,0x01,0x26,0x01,0x55,0x02,0xFF,0x01,0x11,0x03,0x44,0x01,0x22,0x03,0x44,0x01,0x22,0x04,0xFF,0x06,0x22, -0x10,0x44,0x02,0x26,0x01,0x55,0x02,0xFF,0x01,0xF1,0x03,0xF4,0x01,0xF2,0x03,0xF4,0x01,0xF2,0x01,0xFF,0x02,0x8F,0x01,0xFF,0x07,0x22, -0x0F,0x44,0x01,0x62,0x01,0x26,0x01,0x55,0x0A,0x5F,0x02,0xFF,0x02,0x88,0x01,0xFF,0x08,0x22, -0x0E,0x44,0x01,0x22,0x01,0x42,0x01,0x55,0x09,0xFF,0x01,0x55,0x02,0xFF,0x02,0x88,0x0A,0xFF, -0x0F,0x44,0x03,0x45,0x01,0x85,0x09,0x45,0x02,0x85,0x04,0x45,0x01,0x85,0x05,0x45, -0x11,0x44,0x01,0x48,0x09,0x44,0x04,0x85,0x04,0x44,0x01,0x48, -0x1E,0x44,0x06,0x85, -0x104,0x44, -0xff,0xff,}; +0x03,0x66, 0x01,0x56, +0x27,0x66, 0x01,0x55, 0x01,0xF5, +0x26,0x66, 0x01,0x55, 0x01,0xFF, 0x01,0xF5, +0x25,0x66, 0x01,0x55, 0x02,0xFF, 0x01,0xF5, +0x24,0x66, 0x01,0x55, 0x03,0xFF, 0x01,0xF5, 0x20,0x66, +0x01,0x44, 0x01,0x24, 0x01,0x44, 0x01,0x55, 0x0F,0xF5, 0x04,0x22, +0x12,0x44, 0x01,0x62, 0x01,0x22, 0x01,0x55, 0x01,0xFF, 0x03,0x11, 0x01,0x44, 0x03,0x22, 0x01,0x44, 0x03,0x22, 0x03,0xFF, 0x05,0x22, +0x11,0x44, 0x01,0x22, 0x01,0x26, 0x01,0x55, 0x02,0xFF, 0x01,0x11, 0x03,0x44, 0x01,0x22, 0x03,0x44, 0x01,0x22, 0x04,0xFF, 0x06,0x22, +0x10,0x44, 0x02,0x26, 0x01,0x55, 0x02,0xFF, 0x01,0xF1, 0x03,0xF4, 0x01,0xF2, 0x03,0xF4, 0x01,0xF2, 0x01,0xFF, 0x02,0x8F, 0x01,0xFF, 0x07,0x22, +0x0F,0x44, 0x01,0x62, 0x01,0x26, 0x01,0x55, 0x0A,0x5F, 0x02,0xFF, 0x02,0x88, 0x01,0xFF, 0x08,0x22, +0x0E,0x44, 0x01,0x22, 0x01,0x42, 0x01,0x55, 0x09,0xFF, 0x01,0x55, 0x02,0xFF, 0x02,0x88, 0x0A,0xFF, +0x0F,0x44, 0x03,0x45, 0x01,0x85, 0x09,0x45, 0x02,0x85, 0x04,0x45, 0x01,0x85, 0x05,0x45, +0x11,0x44, 0x01,0x48, 0x09,0x44, 0x04,0x85, 0x04,0x44, 0x01,0x48, +0x1E,0x44, 0x06,0x85, +0xFE,0x44, 0x06,0x44, 0xFF,0xFF,}; diff --git a/gr-sim/gr-sim.c b/gr-sim/gr-sim.c index ea8c6756..70a089b2 100644 --- a/gr-sim/gr-sim.c +++ b/gr-sim/gr-sim.c @@ -671,16 +671,22 @@ int grsim_unrle(unsigned char *rle_data, int address) { y=0; ram[BASL]=address&0xff; - ram[BASH]=address>>8; + ram[BASH]=(address>>8)&0xff; ram[CV]=0; + + /* CH = xsize */ ram[CH]=rle_data[y_indirect(GBASL,y)]; y++; -// ysize=rle_data[1]; + + /* Skip ysize */ y++; while(1) { + /* Get run length into a */ a=rle_data[y_indirect(GBASL,y)]; + + /* 0xff is a special value meaning end */ if (a==0xff) break; ram[TEMP]=a; diff --git a/gr-sim/tfv.c b/gr-sim/tfv.c index 5f6d9f59..8b4614c2 100644 --- a/gr-sim/tfv.c +++ b/gr-sim/tfv.c @@ -462,6 +462,8 @@ static void print_byte(unsigned char value) { basic_print(temp); } +/* Enemies: */ +/* Killer Crab, Big Fish, Procrastinon */ static int do_battle(void) { @@ -542,6 +544,23 @@ static int do_battle(void) { return 0; } +/* In Town */ + + +/* Puzzle Room */ +/* Get through office */ +/* Have to run away? What happens if die? No save game? Code? */ + +/* Construct the LED circuit */ +/* Zaps through cloud */ +/* Susie joins your party */ + +/* Final Battle */ +/* Play music, lightning effects? */ +/* TFV only hit for one damage, susie for 100 */ + + + /* Map @@ -558,9 +577,6 @@ static int do_battle(void) { */ - - - static int world_map(void) { int ch; diff --git a/gr-utils/loadpng.c b/gr-utils/loadpng.c index c139bd81..a220d695 100644 --- a/gr-utils/loadpng.c +++ b/gr-utils/loadpng.c @@ -9,6 +9,36 @@ #include + +static int convert_color(int color) { + + int c=0; + + switch(color) { + case 0x000000: c=0; break; /* black */ + case 0xe31e60: c=1; break; /* magenta */ + case 0x604ebd: c=2; break; /* dark blue */ + case 0xff44fd: c=3; break; /* purple */ + case 0x00a360: c=4; break; /* dark green */ + case 0x9c9c9c: c=5; break; /* grey 1 */ + case 0x14cffd: c=6; break; /* medium blue */ + case 0xd0c3ff: c=7; break; /* light blue */ + case 0x607203: c=8; break; /* brown */ + case 0xff6a3c: c=9; break; /* orange */ + case 0x9d9d9d: c=10; break; /* grey 2 */ + case 0xffa0d0: c=11; break; /* pink */ + case 0x14f53c: c=12; break; /* bright green */ + case 0xd0dd8d: c=13; break; /* yellow */ + case 0x72ffd0: c=14; break; /* aqua */ + case 0xffffff: c=15; break; /* white */ + default: + printf("Unknown color %x\n",color); + break; + } + + return c; +} + /* expects a PNG where the xsize is *2 */ int loadpng(char *filename, unsigned char **image_ptr, int *xsize, int *ysize) { @@ -16,8 +46,9 @@ int loadpng(char *filename, unsigned char **image_ptr, int *xsize, int *ysize) { int color; FILE *infile; int debug=0; - unsigned char *image; + unsigned char *image,*out_ptr; int width, height; + int a2_color; png_byte bit_depth; png_structp png_ptr; @@ -84,63 +115,38 @@ int loadpng(char *filename, unsigned char **image_ptr, int *xsize, int *ysize) { fclose(infile); - image=calloc(width*height,sizeof(unsigned char)); + image=calloc(width*height/2,sizeof(unsigned char)); if (image==NULL) { fprintf(stderr,"Memory error!\n"); return -1; } + out_ptr=image; - for(y=0;y253)) { + fprintf(outfile,"0x%02X,0x%02X, ",run,last); + +// printf("%x,%x\n",run,last); + size+=2; run=0; last=next; @@ -59,19 +76,19 @@ int main(int argc, char **argv) { x++; - + /* Split up per-line */ enough++; if (enough>=xsize) { enough=0; - x+=xsize; fprintf(outfile,"\n"); } - - if (x>=xsize*ysize) { + /* If we reach the end */ + if (x>=xsize*(ysize/2)) { + run++; /* print tailing value */ if (run!=0) { - fprintf(outfile,"0x%02X,0x%02X,",run,last); + fprintf(outfile,"0x%02X,0x%02X, ",run,last); size+=2; } break; @@ -81,7 +98,10 @@ int main(int argc, char **argv) { } - fprintf(outfile,"0xff,0xff,"); + + /* Print closing marker */ + + fprintf(outfile,"0xFF,0xFF,"); size+=2; fprintf(outfile,"};\n");