X-Git-Url: http://4ch.mooo.com/gitweb/?a=blobdiff_plain;f=src%2Fplanrpcx.c;h=9de942b3f64504fa3116ccaed15b3d6c778629df;hb=876842a9edc283a9fd49858212fb39e8e9a2eb21;hp=d4b91e009101257bae68c3874e2d74cd14c4f608;hpb=4388d78db512b19cfb276402059633929b560dd3;p=16.git diff --git a/src/planrpcx.c b/src/planrpcx.c index d4b91e00..9de942b3 100755 --- a/src/planrpcx.c +++ b/src/planrpcx.c @@ -28,31 +28,37 @@ #include "src/lib/planar.h" global_game_variables_t gvar; -bitmap_t bmp; -planar_buf_t *p; +bitmap_t bmp, ptmpbt; +planar_buf_t *p, *ptmp; void main(int argc, char *argv[]) { int i; word start; int plane; - float t1, t2; + float t1, t2, tpee; int x,y; word px,py; sword baka; char *bakapeee; + byte l[1024]; + word j,chw,xp,col,bgcol; + + bakapeee = malloc(64); if(argv[1]) bakapeee = argv[1]; else bakapeee = "data/koishi~.pcx"; - if(argv[2]) baka = atoi(argv[2]); - else +// if(argv[2]) baka = atoi(argv[2]); +// else baka = 1; bmp = bitmapLoadPcx(bakapeee); p = planar_buf_from_bitmap(&bmp); + ptmpbt = bitmapLoadPcx("data/ptmp.pcx"); + ptmp = planar_buf_from_bitmap(&ptmpbt); VGAmodeX(baka, &gvar); gvar.video.page[0]=modexDefaultPage(&gvar.video.page[0]); @@ -71,7 +77,7 @@ baka = 1; start = *clockw; // oldDrawBmp(VGA, 20, 20, &bmp, 0); for(i=0; i<100 ;i++) { - modexDrawBmp(&gvar.video.page[0], 32, 32, &bmp); + modexDrawBmpPBuf(&gvar.video.page[0], 32, 32, p); } t1 = (*clockw-start) /18.2; // start = *clockw; @@ -79,9 +85,12 @@ baka = 1; // t2 = (*clockw-start)/18.2; start = *clockw; for(i=0; i<100 ;i++) { - DrawPBuf(&gvar.video.page[0], 0, 0, p, 0); + modexDrawPBuf(&gvar.video.page[0], 0, 0, p, 0); } t2 = (*clockw-start) /18.2; + /*getch(); + modexPalUpdate1(ptmpbt.palette); + modexDrawBmpPBufRegion(&gvar.video.page[0], 64, 64, 48, 32, 24, 32, ptmp);*/ while(!kbhit()) { } @@ -95,13 +104,34 @@ baka = 1; for(plane=0; plane < 4; plane++) { i=0; printf("Plane %d\n", plane); - for(py=0; py < p->height; py++) { - for(px=0; px < p->pwidth; px++) { - printf("%02X ", (int) p->plane[plane][i++]); + for(py=0; py < ptmp->height; py++) { + for(px=0; px < ptmp->pwidth; px++) { + printf("%02X ", (int) ptmp->plane[plane][i++]); } printf("\n"); } } + col=0x0d, bgcol=0; + /*for(i=0; i<8; i++) + { + //modexSelectPlane(PLANE(x)); + //j=1<<8; + //*bakapee=(l[i] & j ? col:bgcol); + //_fmemcpy(page->data + (((page->width/4) * (y+page->dy+i)) + ((x+page->dx+chw) / 4)), bakapee, 8); + j=4<<8; + fprintf(stderr, "j<<=%u\n", j); + xp=0; + while(j) + { + //modexputPixel(page, x+xp+chw, y+i, l[i] & j ? col:bgcol); + //fprintf(stderr, "%u", l[i] & j ? col:bgcol); + xp++; + j>>=4; + fprintf(stderr, " j>>=%u\n", j); + } + //fprintf(stderr, "\n"); + }*/ + chw += xp; fprintf(stderr,"Project 16 planrpcx.exe. This is just a test file!\n"); fprintf(stderr,"version %s\n", VERSION); fprintf(stderr,"%d\n", sizeof(p->plane)); @@ -112,8 +142,9 @@ baka = 1; fprintf(stderr,"%dx%d\n", gvar.video.page[0].sw-(p->width), gvar.video.page[0].sh-(p->height)); planar_buf_free(p); free(bakapeee); - fprintf(stderr, "modexDrawBmp: %f\n", t1); - fprintf(stderr, "DrawPBuf: %f\n", t2); + fprintf(stderr, "modexDrawBmpPBuf: %f\n", t1); + fprintf(stderr, "modexDrawPBuf: %f\n", t2); + fprintf(stderr, "speed difference %f\n", t2/t1); fprintf(stderr, "gvar.video.page[0].width: %u\n", gvar.video.page[0].width); fprintf(stderr, "gvar.video.page[0].height: %u\n", gvar.video.page[0].height); return;