#include <dos.h>\r
#include <string.h>\r
#include "src/lib/modex16.h"\r
-#include "src/lib/bitmap.h"\r
-#include "src/lib/planar.h"\r
\r
global_game_variables_t gvar;\r
-bitmap_t bmp, ptmpbt;\r
-planar_buf_t *p, *ptmp;\r
+planar_buf_t p, ptmp;\r
+int i;\r
+word start;//, w;\r
+int plane;\r
+float t1, t2, t3, t4, tpee;\r
+int x,y;\r
+word px,py;\r
+sword baka;\r
+char *bakapeee;\r
+\r
\r
void main(int argc, char *argv[])\r
{\r
- int i;\r
- word start;\r
- int plane;\r
- float t1, t2, tpee;\r
- int x,y;\r
- word px,py;\r
- sword baka;\r
- char *bakapeee;\r
\r
byte l[1024];\r
- word j,chw,xp,col,bgcol;\r
-\r
+ static byte e;\r
+ static word chx, chy, colpee;\r
+ byte pee[2];\r
\r
+//w=0;\r
+//printf("%u ", w++);\r
bakapeee = malloc(64);\r
\r
if(argv[1]) bakapeee = argv[1];\r
// if(argv[2]) baka = atoi(argv[2]);\r
// else\r
baka = 1;\r
+//fprintf(stderr, "%u ", w++);\r
+ p = planarLoadPcx(bakapeee);\r
+//fprintf(stderr, "%u ", w++);\r
+// ptmp = planarLoadPcx("data/ptmp.pcx");\r
+//fprintf(stderr, "%u ", w++);\r
+//fprintf(stderr, "^^;", w++);\r
+//getch();\r
\r
- bmp = bitmapLoadPcx(bakapeee);\r
- p = planar_buf_from_bitmap(&bmp);\r
- ptmpbt = bitmapLoadPcx("data/ptmp.pcx");\r
- ptmp = planar_buf_from_bitmap(&ptmpbt);\r
+ textInit();\r
VGAmodeX(baka, &gvar);\r
gvar.video.page[0]=modexDefaultPage(&gvar.video.page[0]);\r
\r
- /* fix up the palette and everything */\r
- modexPalUpdate1(bmp.palette);\r
+ //fix up the palette and everything\r
+ modexPalUpdate1(p.palette);\r
\r
- /* clear and draw one sprite and one bitmap */\r
+ //clear and draw one sprite and one bitmap\r
modexClearRegion(&gvar.video.page[0], 0, 0, gvar.video.page[0].sw, gvar.video.page[0].sh, 0);\r
\r
- /* update display~*/\r
+ //update display~\r
gvar.video.page[0].dx+=32;\r
gvar.video.page[0].dy+=32;\r
modexShowPage(&gvar.video.page[0]);\r
\r
- /* non sprite comparison */\r
+ //non sprite comparison\r
start = *clockw;\r
// oldDrawBmp(VGA, 20, 20, &bmp, 0);\r
for(i=0; i<100 ;i++) {\r
- modexDrawBmpPBuf(&gvar.video.page[0], 32, 32, p);\r
+ //modexDrawBmpPBuf (&gvar.video.page[0], 32, 32, &p);\r
}\r
t1 = (*clockw-start) /18.2;\r
+ for(i=0; i<100 ;i++) {\r
+ modexDrawBmpPBufRegion (&gvar.video.page[0], p.width+32, 32, p.width-(p.width/4), p.height-(p.height/4), p.width/4, p.height/4, &p);\r
+ }\r
+ t2 = (*clockw-start) /18.2;\r
+ getch();\r
// start = *clockw;\r
// modexCopyPageRegion(&gvar.video.page[0], &gvar.video.page[0], 0, 0, 0, 0, 320, 240);\r
// t2 = (*clockw-start)/18.2;\r
start = *clockw;\r
for(i=0; i<100 ;i++) {\r
- modexDrawPBuf(&gvar.video.page[0], 0, 0, p, 0);\r
+ modexDrawPBuf (&gvar.video.page[0], 0, 0, &p, 0);\r
}\r
- t2 = (*clockw-start) /18.2;\r
- /*getch();\r
- modexPalUpdate1(ptmpbt.palette);\r
- modexDrawBmpPBufRegion(&gvar.video.page[0], 64, 64, 48, 32, 24, 32, ptmp);*/\r
+ t3 = (*clockw-start) /18.2;\r
+getch();\r
+ for(i=0; i<100 ;i++) {\r
+ //(page_t *page, int x, int y, int rx, int ry, int rw, int rh, planar_buf_t *p, boolean sprite);\r
+ modexDrawPBufRegion (&gvar.video.page[0], p.width, 0, p.width-(p.width/4), p.height-(p.height/4), p.width/4, p.height/4, &p, 0);//(&gvar.video.page[0], 0, 0, 0+p.width, 0, p.width, p.height, &p, 0);\r
+ }\r
+ t4 = (*clockw-start) /18.2;\r
+ //++++ modexPalUpdate1(ptmp.palette);\r
+ //modexDrawBmpPBufRegion(&gvar.video.page[0], 64, 64, 48, 32, 24, 32, ptmp);\r
+ //modexDrawPBuf(&gvar.video.page[0], 64, 64, &ptmp, 0);\r
while(!kbhit())\r
{\r
}\r
VGAmodeX(0, &gvar);\r
- /*printf("\nmain=%Fp\n\n", &i);\r
- printf("bmp.data=%Fp\n", bmp.data);\r
- printf("*bmp.data=%Fp\n", *(bmp.data));\r
- printf("&bmp.data=%Fp\n", &(bmp.data));*/\r
\r
- /* print out the contents of each plane */\r
+ //print out the contents of each plane\r
for(plane=0; plane < 4; plane++) {\r
i=0;\r
printf("Plane %d\n", plane);\r
- for(py=0; py < ptmp->height; py++) {\r
- for(px=0; px < ptmp->pwidth; px++) {\r
- printf("%02X ", (int) ptmp->plane[plane][i++]);\r
+ for(py=0; py < p.height; py++) {\r
+ for(px=0; px < p.pwidth; px++) {\r
+ printf("%02X ", (int) p.plane[plane][i++]);\r
}\r
printf("\n");\r
}\r
}\r
- col=0x0d, bgcol=0;\r
- /*for(i=0; i<8; i++)\r
+\r
+ chx=0;\r
+ chy=0;\r
+ colpee=32;\r
+ for(e=0x00; e<=0xFE; e++)\r
{\r
- //modexSelectPlane(PLANE(x));\r
- //j=1<<8;\r
- //*bakapee=(l[i] & j ? col:bgcol);\r
- //_fmemcpy(page->data + (((page->width/4) * (y+page->dy+i)) + ((x+page->dx+chw) / 4)), bakapee, 8);\r
- j=4<<8;\r
- fprintf(stderr, "j<<=%u\n", j);\r
- xp=0;\r
- while(j)\r
+ if(chx+8>(gvar.video.page[0].width/2))\r
{\r
- //modexputPixel(page, x+xp+chw, y+i, l[i] & j ? col:bgcol);\r
- //fprintf(stderr, "%u", l[i] & j ? col:bgcol);\r
- xp++;\r
- j>>=4;\r
- fprintf(stderr, " j>>=%u\n", j);\r
+ chx=0;\r
+ chy+=8;\r
+ sprintf(pee,"%u", colpee);\r
+ modexprint(&gvar.video.page[0], 200, 200, 1, 47, 0, &pee, 0);\r
+ //getch();\r
}\r
- //fprintf(stderr, "\n");\r
- }*/\r
- chw += xp;\r
+ modexprint(&gvar.video.page[0], chx, chy, 1, 0, colpee, &e, 0);\r
+ chx+=9;\r
+ colpee++;\r
+ if(colpee>=32+24) colpee=32;\r
+ }\r
+\r
fprintf(stderr,"Project 16 planrpcx.exe. This is just a test file!\n");\r
fprintf(stderr,"version %s\n", VERSION);\r
- fprintf(stderr,"%d\n", sizeof(p->plane));\r
- fprintf(stderr,"pw=%d\n", p->width);\r
- fprintf(stderr,"ph=%d\n", p->height);\r
- fprintf(stderr,"ppw=%d\n", p->pwidth);\r
- fprintf(stderr,"%d\n", sizeof(bmp));\r
- fprintf(stderr,"%dx%d\n", gvar.video.page[0].sw-(p->width), gvar.video.page[0].sh-(p->height));\r
- planar_buf_free(p);\r
+ fprintf(stderr,"%d\n", sizeof(p.plane));\r
+ fprintf(stderr,"pw=%d\n", p.width);\r
+ fprintf(stderr,"ph=%d\n", p.height);\r
+ fprintf(stderr,"ppw=%d\n", p.pwidth);\r
+ fprintf(stderr,"%d\n", sizeof(p));\r
+ fprintf(stderr,"%dx%d\n", gvar.video.page[0].sw-(p.width), gvar.video.page[0].sh-(p.height));\r
free(bakapeee);\r
- fprintf(stderr, "modexDrawBmpPBuf: %f\n", t1);\r
- fprintf(stderr, "modexDrawPBuf: %f\n", t2);\r
- fprintf(stderr, "speed difference %f\n", t2/t1);\r
- fprintf(stderr, "gvar.video.page[0].width: %u\n", gvar.video.page[0].width);\r
- fprintf(stderr, "gvar.video.page[0].height: %u\n", gvar.video.page[0].height);\r
- return;\r
+ fprintf(stderr, "modexDrawBmpPBufRegion: %f\n", t2);\r
+ fprintf(stderr, "modexDrawPBufRegion: %f\n", t4);\r
+ fprintf(stderr, "speed difference %f\n", t2/t4);\r
+ //fprintf(stderr, "gvar.video.page[0].width: %u\n", gvar.video.page[0].width);\r
+ //fprintf(stderr, "gvar.video.page[0].height: %u\n", gvar.video.page[0].height);\r
}\r