1 /* Project 16 Source Code~
\r
2 * Copyright (C) 2012-2017 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_vlpal.h"
\r
26 #include "src/lib/16_in.h"
\r
27 #include "src/lib/scroll16.h"
\r
32 static word far* clockw= (word far*) 0x046C; /* 18.2hz clock */
\r
34 void drawboxesmodex(page_t *pg)
\r
36 modexClearRegion(pg, 0, 0, pg->width, pg->height, 1);
\r
37 modexClearRegion(pg, 16, 16, pg->sw, pg->sh, 2);
\r
38 modexClearRegion(pg, 32, 32, pg->sw-32, pg->sh-32, 3);
\r
39 modexClearRegion(pg, 48, 48, pg->sw-64, pg->sh-64, 2);
\r
42 void copyboxesmodex(page_t *page, boolean pn)
\r
44 modexCopyPageRegion(&page[pn], &page[!pn], 0, 0, 0, 0, page[pn].width, page[pn].height);
\r
47 void main(int argc, char *argv[])
\r
49 static word paloffset=0;
\r
50 static global_game_variables_t gvar;
\r
52 // map_view_t mv[4];
\r
56 word startclk, endclk;
\r
59 imgtestpal_t bmp1, bmp2;
\r
62 bmp1.width=bmp2.width= 40;
\r
63 bmp1.width=bmp2.height= 30;
\r
65 //====word colo=LGQ;
\r
67 // DOSLIB: check our environment
\r
70 // DOSLIB: what CPU are we using?
\r
71 // NTS: I can see from the makefile Sparky4 intends this to run on 8088 by the -0 switch in CFLAGS.
\r
72 // So this code by itself shouldn't care too much what CPU it's running on. Except that other
\r
73 // parts of this project (DOSLIB itself) rely on CPU detection to know what is appropriate for
\r
74 // the CPU to carry out tasks. --J.C.
\r
77 // DOSLIB: check for VGA
\r
79 printf("VGA probe failed\n");
\r
82 // hardware must be VGA or higher!
\r
83 if (!(vga_state.vga_flags & VGA_IS_VGA)) {
\r
84 printf("This program requires VGA or higher graphics hardware\n");
\r
88 if (_DEBUG_INIT() == 0) {
\r
90 printf("WARNING: Failed to initialize DEBUG output\n");
\r
93 _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
94 _DEBUGF("Serial debug output printf test %u %u %u\n",1U,2U,3U);*/
\r
97 /* save the palette */
\r
98 //====modexPalSave(pal);
\r
99 //====modexFadeOff(1, pal);
\r
100 //====modexPalBlack();
\r
103 IN_Default(0,&gvar.player[0],ctrl_Keyboard1, &gvar);
\r
104 EN_initPlayer(&gvar.player[0], &gvar.video);
\r
106 VGAmodeX(1, 1, &gvar);
\r
109 /* load our palette */
\r
110 VL_LoadPalFile("data/16.pal", &gvar.video.palette, &gvar);
\r
111 bmp1.offset=(paloffset/3);
\r
112 VL_palette(&bmp1, &gvar.video.palette, &paloffset, 0, 0, &gvar);
\r
114 //VL_LoadPalFilewithoffset("data/default.pal", &palette, paloffset);
\r
115 modexLoadPalFile("data/16t.pal", &gvar.video.dpal);
\r
116 bmp2.offset=(paloffset/3);
\r
117 VL_palette(&bmp2, &gvar.video.dpal, &paloffset, 0, 0, &gvar);
\r
118 //====modexLoadPalFile("data/default.pal", &pal2);
\r
120 /* overscan show */
\r
121 //modexPalOverscan(44+1);
\r
123 /* set up the page, but with 16 pixels on all borders in offscreen mem */
\r
124 modexHiganbanaPageSetup(&gvar);
\r
125 ZC_MVSetup(&gvar.mv, &map, &gvar);
\r
127 /* fill the page with one color, but with a black border */
\r
128 /*modexClearRegion(&gvar.video.page[1], 0, 0, gvar.video.page[1].width, gvar.video.page[1].height, 15);
\r
129 modexClearRegion(&gvar.video.page[1], 16, 16, gvar.video.page[1].sw, gvar.video.page[1].sh, 128);
\r
130 modexClearRegion(&gvar.video.page[1], 32, 32, gvar.video.page[1].sw-32, gvar.video.page[1].sh-32, 42);
\r
131 modexClearRegion(&gvar.video.page[1], 48, 48, gvar.video.page[1].sw-64, gvar.video.page[1].sh-64, 128);
\r
132 modexShowPage(&gvar.video.page[1]);
\r
133 modexClearRegion(&gvar.video.page[0], 0, 0, gvar.video.page[0].width, gvar.video.page[0].height, 15);
\r
134 modexClearRegion(&gvar.video.page[0], 16, 16, gvar.video.page[0].sw, gvar.video.page[0].sh, 128);
\r
135 modexClearRegion(&gvar.video.page[0], 32, 32, gvar.video.page[0].sw-32, gvar.video.page[0].sh-32, 42);
\r
136 modexClearRegion(&gvar.video.page[0], 48, 48, gvar.video.page[0].sw-64, gvar.video.page[0].sh-64, 128);
\r
137 modexShowPage(&gvar.video.page[0]);*/
\r
139 drawboxesmodex(&gvar.video.page[0]);
\r
140 copyboxesmodex(&gvar.video.page, 1);
\r
141 modexClearRegion(&gvar.video.page[2], 0, 0, gvar.video.page[2].sw, gvar.video.page[2].sh, 4);
\r
142 modexClearRegion(&gvar.video.page[3], 0, 0, gvar.video.page[3].sw, gvar.video.page[3].sh, 6);
\r
146 //====modexFadeOn(1, pal2);
\r
149 startclk = *clockw;
\r
150 while(!gvar.in.inst->Keyboard[sc_Escape])
\r
152 IN_ReadControl(&gvar.player[0], &gvar);
\r
153 ZC_panPageManual(&gvar.mv, &gvar.player, 0);
\r
154 // if(gvar.in.inst->Keyboard[sc_5)){ modexClearRegion(&gvar.video.page[1], gvar.video.page[1].sw, 16, 8, 4, 45); }
\r
155 // if(gvar.in.inst->Keyboard[sc_4)){
\r
156 // modexClearRegion(&gvar.video.page[1], 16, 16, gvar.video.page[1].sw, gvar.video.page[1].sh, 128);
\r
157 // modexClearRegion(&gvar.video.page[1], 32, 32, gvar.video.page[1].sw-32, gvar.video.page[1].sh-32, 42);
\r
158 // modexClearRegion(&gvar.video.page[1], 48, 48, gvar.video.page[1].sw-64, gvar.video.page[1].sh-64, 128);
\r
161 if(gvar.in.inst->Keyboard[12]) modexClearRegion(&gvar.video.page[0], (gvar.video.page[0].width/2)-4, (gvar.video.page[0].height/2)-16, 24, 32, 15);
\r
162 if(gvar.in.inst->Keyboard[13]) modexClearRegion(&gvar.video.page[1], (gvar.video.page[1].width/2)-4, (gvar.video.page[1].height/2)-16, 24, 32, 15);
\r
163 /*==== if(gvar.in.inst->Keyboard[7)){
\r
166 pal2[i] = rand()%64;
\r
167 modexPalUpdate(pal2);
\r
169 if(colo>HGQ) colo=LGQ;
\r
171 // if(i>PAL_SIZE) i=0;
\r
173 if(gvar.in.inst->Keyboard[25]){ modexpdump(gvar.video.sp, &gvar); IN_UserInput(1, &gvar); }//p
\r
174 if(gvar.in.inst->Keyboard[sc_I]){ drawboxesmodex(&gvar.video.page[gvar.video.sp]); IN_UserInput(1, &gvar); }//i
\r
175 if(gvar.in.inst->Keyboard[sc_O]){ copyboxesmodex(&gvar.video.page, !gvar.video.sp); IN_UserInput(1, &gvar); }//o
\r
176 VL_ShowPage(&gvar.video.page[gvar.video.sp], 0, 0);
\r
177 //ZC_ShowMV(&gvar.mv, 0, 0);
\r
182 /* fade back to text mode */
\r
183 //====modexFadeOff(1, pal2);
\r
184 //====modexPalBlack();
\r
185 VGAmodeX(0, 1, &gvar);
\r
187 printf("Project 16 vidtest.exe. This is just a test file!\n");
\r
188 printf("version %s\n", VERSION);
\r
189 VL_PrintmodexmemInfo(&gvar.video);
\r
190 printf("tx=%d ", gvar.mv[gvar.video.sp].tx); printf("ty=%d ", gvar.mv[gvar.video.sp].ty); printf("gvar.player.d=%d\n", gvar.player[0].enti.d);
\r
191 printf("\n====\n");
\r
192 printf("0 paloffset= %d\n", paloffset/3);
\r
193 printf("====\n\n");
\r
195 //====modexPalBlack();
\r
196 //====modexFadeOn(1, pal);
\r