1 /* Project 16 Source Code~
\r
2 * Copyright (C) 2012-2016 sparky4 & pngwen & andrius4669 & joncampbell123 & yakui-lover
\r
4 * This file is part of Project 16.
\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
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
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
24 #include "src/lib/16_vl.h"
\r
25 #include "src/lib/16_in.h"
\r
26 #include "src/lib/scroll16.h"
\r
27 #include "src/lib/bakapee.h"
\r
29 #define PCXBMPVAR player[0].data
\r
30 #define PCXBMP *PCXBMPVAR
\r
31 #define PCXBMPPTR PCXBMPVAR
\r
33 static word far* clockw= (word far*) 0x046C; /* 18.2hz clock */
\r
35 void main(int argc, char *argv[])
\r
37 static global_game_variables_t gvar;
\r
38 static player_t player[MaxPlayers];
\r
44 word startclk, endclk;
\r
46 //====byte *pal, *pal2;
\r
49 //====word colo=LGQ;
\r
53 if(argv[1]) bakapee = atoi(argv[1]);
\r
56 // DOSLIB: check our environment
\r
59 // DOSLIB: what CPU are we using?
\r
60 // NTS: I can see from the makefile Sparky4 intends this to run on 8088 by the -0 switch in CFLAGS.
\r
61 // So this code by itself shouldn't care too much what CPU it's running on. Except that other
\r
62 // parts of this project (DOSLIB itself) rely on CPU detection to know what is appropriate for
\r
63 // the CPU to carry out tasks. --J.C.
\r
66 // DOSLIB: check for VGA
\r
68 printf("VGA probe failed\n");
\r
71 // hardware must be VGA or higher!
\r
72 if (!(vga_state.vga_flags & VGA_IS_VGA)) {
\r
73 printf("This program requires VGA or higher graphics hardware\n");
\r
77 if (_DEBUG_INIT() == 0) {
\r
79 printf("WARNING: Failed to initialize DEBUG output\n");
\r
82 _DEBUG("Serial debug output started\n"); // NTS: All serial output must end messages with newline, or DOSBox-X will not emit text to log
\r
83 _DEBUGF("Serial debug output printf test %u %u %u\n",1U,2U,3U);*/
\r
85 PCXBMP = bitmapLoadPcx("data/chikyuu.pcx", &gvar); // load sprite
\r
87 /* save the palette */
\r
88 //====pal = modexNewPal();
\r
89 //====modexPalSave(pal);
\r
90 //====modexFadeOff(1, pal);
\r
91 //====modexPalBlack();
\r
94 IN_Default(0,&player,ctrl_Keyboard1);
\r
95 IN_initplayer(&player, 0);
\r
97 VGAmodeX(bakapee, 1, &gvar);
\r
98 //====modexPalBlack();
\r
100 /* load our palette */
\r
101 //====modexLoadPalFile("data/default.pal", &pal2);
\r
103 /* overscan show */
\r
104 //modexPalOverscan(44+1);
\r
106 /* set up the page, but with 16 pixels on all borders in offscreen mem */
\r
107 modexHiganbanaPageSetup(&gvar.video);
\r
108 ZC_MVSetup(&mv, &map, &gvar);
\r
110 /* fill the page with one color, but with a black border */
\r
111 /*modexClearRegion(&gvar.video.page[1], 0, 0, gvar.video.page[1].width, gvar.video.page[1].height, 15);
\r
112 modexClearRegion(&gvar.video.page[1], 16, 16, gvar.video.page[1].sw, gvar.video.page[1].sh, 128);
\r
113 modexClearRegion(&gvar.video.page[1], 32, 32, gvar.video.page[1].sw-32, gvar.video.page[1].sh-32, 42);
\r
114 modexClearRegion(&gvar.video.page[1], 48, 48, gvar.video.page[1].sw-64, gvar.video.page[1].sh-64, 128);
\r
115 modexShowPage(&gvar.video.page[1]);
\r
116 modexClearRegion(&gvar.video.page[0], 0, 0, gvar.video.page[0].width, gvar.video.page[0].height, 15);
\r
117 modexClearRegion(&gvar.video.page[0], 16, 16, gvar.video.page[0].sw, gvar.video.page[0].sh, 128);
\r
118 modexClearRegion(&gvar.video.page[0], 32, 32, gvar.video.page[0].sw-32, gvar.video.page[0].sh-32, 42);
\r
119 modexClearRegion(&gvar.video.page[0], 48, 48, gvar.video.page[0].sw-64, gvar.video.page[0].sh-64, 128);
\r
120 modexShowPage(&gvar.video.page[0]);*/
\r
123 modexClearRegion(&gvar.video.page[0], 0, 0, gvar.video.page[0].width, gvar.video.page[0].height, 15);
\r
124 modexClearRegion(&gvar.video.page[0], 16, 16, gvar.video.page[0].sw, gvar.video.page[0].sh, 128);
\r
125 modexClearRegion(&gvar.video.page[0], 32, 32, gvar.video.page[0].sw-32, gvar.video.page[0].sh-32, 42);
\r
126 modexClearRegion(&gvar.video.page[0], 48, 48, gvar.video.page[0].sw-64, gvar.video.page[0].sh-64, 128);
\r
127 modexCopyPageRegion(&gvar.video.page[1], &gvar.video.page[0], 0, 0, 0, 0, gvar.video.page[0].width, gvar.video.page[0].height);
\r
128 modexClearRegion(&gvar.video.page[2], 0, 0, gvar.video.page[2].sw, gvar.video.page[2].sh, 47);
\r
129 modexClearRegion(&gvar.video.page[3], 0, 0, gvar.video.page[3].sw, gvar.video.page[3].sh, 45);
\r
133 //====modexFadeOn(1, pal2);
\r
136 startclk = *clockw;
\r
137 while(!IN_KeyDown(sc_Escape))
\r
139 IN_ReadControl(0,&player);
\r
140 ZC_panPageManual(&mv, &player, 0);
\r
141 //[gvar.video.panp]
\r
150 gvar.video.page[gvar.video.panp].dx++;
\r
151 if(i==5){ if(j>=31){ i++; j=0; goto baka; }else j++; }else
\r
152 if(j>=32){ k++; j=0; }else j++;
\r
156 gvar.video.page[gvar.video.panp].dx--;
\r
157 if(j>=32){ k++; j=0; }else j++;
\r
161 gvar.video.page[gvar.video.panp].dy++;
\r
162 if(j>=32){ k++; j=0; }else j++;
\r
166 gvar.video.page[gvar.video.panp].dy--;
\r
167 if(j>=32){ k=0; j=0; i++; }else j++;
\r
176 modexClearRegion(&gvar.video.page[1], 0, gvar.video.page[0].height/2, gvar.video.page[0].width-32, 16, 45);*/
\r
177 // if(IN_KeyDown(6))
\r
179 // modexClearRegion(&gvar.video.page[1], gvar.video.page[1].sw, 16, 8, 4, 45);
\r
181 // if(IN_KeyDown(4+1)){
\r
182 // modexClearRegion(&gvar.video.page[1], 16, 16, gvar.video.page[1].sw, gvar.video.page[1].sh, 128);
\r
183 // modexClearRegion(&gvar.video.page[1], 32, 32, gvar.video.page[1].sw-32, gvar.video.page[1].sh-32, 42);
\r
184 // modexClearRegion(&gvar.video.page[1], 48, 48, gvar.video.page[1].sw-64, gvar.video.page[1].sh-64, 128);
\r
188 if(IN_KeyDown(12)) modexClearRegion(&gvar.video.page[0], (gvar.video.page[0].width/2)-4, (gvar.video.page[0].height/2)-16, 24, 32, 15);
\r
189 if(IN_KeyDown(13)) modexClearRegion(&gvar.video.page[1], (gvar.video.page[1].width/2)-4, (gvar.video.page[1].height/2)-16, 24, 32, 15);
\r
190 /*==== if(IN_KeyDown(7)){
\r
193 pal2[i] = rand()%64;
\r
194 modexPalUpdate1(pal2);
\r
196 if(colo>HGQ) colo=LGQ;
\r
198 // if(i>PAL_SIZE) i=0;
\r
200 if(IN_KeyDown(25)){ modexpdump(&gvar.video.page[gvar.video.panp]); IN_UserInput(1,1); }//p
\r
201 //VL_ShowPage(&gvar.video.page[gvar.video.panp], 0, 0);
\r
202 ZC_ShowMV(&mv, 0, 0);
\r
207 /* fade back to text mode */
\r
208 //====modexFadeOff(1, pal2);
\r
209 //====modexPalBlack();
\r
210 VGAmodeX(0, 1, &gvar);
\r
212 printf("Project 16 test.exe. This is just a test file!\n");
\r
213 printf("version %s\n", VERSION);
\r
214 modexprintmeminfo(&gvar.video);
\r
215 printf("tx=%d ", mv[gvar.video.panp].tx); printf("ty=%d ", mv[gvar.video.panp].ty); printf("player.d=%d\n", player[0].d);
\r
217 //====modexPalBlack();
\r
218 //====modexFadeOn(1, pal);
\r