]> 4ch.mooo.com Git - 16.git/blob - src/planrpcx.c
!!!!wwwwwwwwww
[16.git] / src / planrpcx.c
1 /* Project 16 Source Code~\r
2  * Copyright (C) 2012-2015 sparky4 & pngwen & andrius4669\r
3  *\r
4  * This file is part of Project 16.\r
5  *\r
6  * Project 16 is free software; you can redistribute it and/or modify\r
7  * it under the terms of the GNU General Public License as published by\r
8  * the Free Software Foundation; either version 3 of the License, or\r
9  * (at your option) any later version.\r
10  *\r
11  * Project 16 is distributed in the hope that it will be useful,\r
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of\r
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
14  * GNU General Public License for more details.\r
15  *\r
16  * You should have received a copy of the GNU General Public License\r
17  * along with this program.  If not, see <http://www.gnu.org/licenses/>, or\r
18  * write to the Free Software Foundation, Inc., 51 Franklin Street,\r
19  * Fifth Floor, Boston, MA 02110-1301 USA.\r
20  *\r
21  */\r
22 \r
23 #include <stdio.h>\r
24 #include <dos.h>\r
25 #include <string.h>\r
26 #include "src/lib/modex16.h"\r
27 #include "src/lib/bitmap.h"\r
28 #include "src/lib/planar.h"\r
29 \r
30 global_game_variables_t gvar;\r
31 bitmap_t bmp, ptmpbt;\r
32 //planar_buf_t *p, *ptmp;\r
33 planar_buf_t pnp, ptmpnp;\r
34 \r
35 void main(int argc, char *argv[])\r
36 {\r
37         int i;\r
38         word start;\r
39         int plane;\r
40         float t1, t2, tpee;\r
41         int x,y;\r
42         word px,py;\r
43         sword baka;\r
44         char *bakapeee;\r
45 \r
46         byte l[1024];\r
47         word j,chw,xp,col,bgcol;\r
48 \r
49 \r
50         bakapeee = malloc(64);\r
51 \r
52         if(argv[1]) bakapeee = argv[1];\r
53         else bakapeee = "data/koishi~.pcx";\r
54 \r
55 //      if(argv[2]) baka = atoi(argv[2]);\r
56 //      else\r
57 baka = 1;\r
58 \r
59         bmp = bitmapLoadPcx(bakapeee);\r
60         //p = planar_buf_from_bitmap(&bmp);\r
61         pnp = planar_buf_from_bitmap0(&bmp);\r
62         ptmpbt = bitmapLoadPcx("data/ptmp.pcx");\r
63         //ptmp = planar_buf_from_bitmap(&ptmpbt);\r
64         ptmpnp = planar_buf_from_bitmap0(&ptmpbt);\r
65         VGAmodeX(baka, &gvar);\r
66         gvar.video.page[0]=modexDefaultPage(&gvar.video.page[0]);\r
67 \r
68         /* fix up the palette and everything */\r
69         modexPalUpdate1(bmp.palette);\r
70 \r
71         /* clear and draw one sprite and one bitmap */\r
72         modexClearRegion(&gvar.video.page[0], 0, 0, gvar.video.page[0].sw, gvar.video.page[0].sh, 0);\r
73 \r
74         /* update display~*/\r
75         gvar.video.page[0].dx+=32;\r
76         gvar.video.page[0].dy+=32;\r
77         modexShowPage(&gvar.video.page[0]);\r
78 \r
79         /* non sprite comparison */\r
80         start = *clockw;\r
81 //              oldDrawBmp(VGA, 20, 20, &bmp, 0);\r
82         for(i=0; i<100 ;i++) {\r
83 //              modexDrawBmpPBufRegion  (&gvar.video.page[0], 32, 32, 0, 0, pnp.width, pnp.height, &pnp);\r
84                 modexDrawBmpPBuf                (&gvar.video.page[0], 32, 32, &pnp);\r
85         }\r
86         t1 = (*clockw-start) /18.2;\r
87 //      start = *clockw;\r
88 //              modexCopyPageRegion(&gvar.video.page[0], &gvar.video.page[0], 0, 0, 0, 0, 320, 240);\r
89 //      t2 = (*clockw-start)/18.2;\r
90         start = *clockw;\r
91         for(i=0; i<100 ;i++) {\r
92                 modexDrawPBuf(&gvar.video.page[0], 0, 0, &pnp, 0);\r
93         }\r
94         t2 = (*clockw-start) /18.2;\r
95         getch();\r
96         modexPalUpdate1(ptmpbt.palette);\r
97         //modexDrawBmpPBufRegion(&gvar.video.page[0], 64, 64, 48, 32, 24, 32, &ptmpnp);\r
98         modexDrawPBuf(&gvar.video.page[0], 64, 64, &ptmpnp, 0);\r
99         while(!kbhit())\r
100         {\r
101         }\r
102         VGAmodeX(0, &gvar);\r
103 \r
104         /* print out the contents of each plane */\r
105         for(plane=0; plane < 4; plane++) {\r
106                 i=0;\r
107                 printf("Plane %d\n", plane);\r
108                 for(py=0; py < ptmpnp.height; py++) {\r
109                         for(px=0; px < ptmpnp.pwidth; px++) {\r
110                                 printf("%02X ", (int) ptmpnp.plane[plane][i++]);\r
111                         }\r
112                         printf("\n");\r
113                 }\r
114         }\r
115         col=0x0d, bgcol=0;\r
116         /*for(i=0; i<8; i++)\r
117         {\r
118                 //modexSelectPlane(PLANE(x));\r
119                 //j=1<<8;\r
120                 //*bakapee=(l[i] & j ? col:bgcol);\r
121                 //_fmemcpy(page->data + (((page->width/4) * (y+page->dy+i)) + ((x+page->dx+chw) / 4)), bakapee, 8);\r
122                 j=4<<8;\r
123                 fprintf(stderr, "j<<=%u\n", j);\r
124                 xp=0;\r
125                 while(j)\r
126                 {\r
127                         //modexputPixel(page, x+xp+chw, y+i, l[i] & j ? col:bgcol);\r
128                         //fprintf(stderr, "%u", l[i] & j ? col:bgcol);\r
129                         xp++;\r
130                         j>>=4;\r
131                         fprintf(stderr, "       j>>=%u\n", j);\r
132                 }\r
133                 //fprintf(stderr, "\n");\r
134         }*/\r
135         chw += xp;\r
136         fprintf(stderr,"Project 16 planrpcx.exe. This is just a test file!\n");\r
137         fprintf(stderr,"version %s\n", VERSION);\r
138         fprintf(stderr,"%d\n", sizeof(pnp.plane));\r
139         fprintf(stderr,"pw=%d\n", pnp.width);\r
140         fprintf(stderr,"ph=%d\n", pnp.height);\r
141         fprintf(stderr,"ppw=%d\n", pnp.pwidth);\r
142         fprintf(stderr,"%d\n", sizeof(bmp));\r
143         fprintf(stderr,"%dx%d\n", gvar.video.page[0].sw-(pnp.width), gvar.video.page[0].sh-(pnp.height));\r
144         //planar_buf_free(p);\r
145         free(bakapeee);\r
146         fprintf(stderr, "modexDrawBmpPBuf:      %f\n", t1);\r
147         fprintf(stderr, "modexDrawPBuf: %f\n", t2);\r
148         fprintf(stderr, "speed difference       %f\n", t2/t1);\r
149         fprintf(stderr, "gvar.video.page[0].width: %u\n", gvar.video.page[0].width);\r
150         fprintf(stderr, "gvar.video.page[0].height: %u\n", gvar.video.page[0].height);\r
151         return;\r
152 }\r