X-Git-Url: http://4ch.mooo.com/gitweb/?a=blobdiff_plain;f=src%2Ftest.c;h=8c30c94ea4b7b6ef0baab9daa4fb8f6502c40cc4;hb=e3b220f5349f8282bd426fdca00c64c8c7e831cd;hp=8227979b2056f41bc417cdef5185476b364b9bf3;hpb=71c021406f2917a95443149eb883edd44ed5a647;p=16.git diff --git a/src/test.c b/src/test.c index 8227979b..8c30c94e 100755 --- a/src/test.c +++ b/src/test.c @@ -1,5 +1,5 @@ /* Project 16 Source Code~ - * Copyright (C) 2012-2015 sparky4 & pngwen & andrius4669 + * Copyright (C) 2012-2016 sparky4 & pngwen & andrius4669 & joncampbell123 * * This file is part of Project 16. * @@ -23,14 +23,18 @@ #include #include "src/lib/modex16.h" #include "src/lib/16_in.h" +#include "src/lib/scroll16.h" global_game_variables_t gvar; player_t player[MaxPlayers]; +map_view_t mv[2]; +pan_t pan; void main(int argc, char *argv[]) { - int i, j, k; - word start, end; + int i, j; + word startclk, endclk; + word k; byte *pal, *pal2; sword bakapee; @@ -38,6 +42,28 @@ void main(int argc, char *argv[]) if(argv[1]) bakapee = atoi(argv[1]); else bakapee = 1; + + // DOSLIB: check our environment + probe_dos(); + + // DOSLIB: what CPU are we using? + // NTS: I can see from the makefile Sparky4 intends this to run on 8088 by the -0 switch in CFLAGS. + // So this code by itself shouldn't care too much what CPU it's running on. Except that other + // parts of this project (DOSLIB itself) rely on CPU detection to know what is appropriate for + // the CPU to carry out tasks. --J.C. + cpu_probe(); + + // DOSLIB: check for VGA + if (!probe_vga()) { + printf("VGA probe failed\n"); + return; + } + // hardware must be VGA or higher! + if (!(vga_state.vga_flags & VGA_IS_VGA)) { + printf("This program requires VGA or higher graphics hardware\n"); + return; + } + /* load our palette */ modexLoadPalFile("data/default.pal", &pal2); @@ -47,71 +73,119 @@ void main(int argc, char *argv[]) modexFadeOff(1, pal); modexPalBlack(); - VGAmodeX(bakapee, &gvar); - modexPalBlack(); - IN_Startup(); - IN_Default(0,&player,ctrl_Joystick); + IN_Default(0,&player,ctrl_Keyboard1); + IN_initplayer(&player, 0); + + textInit(); + VGAmodeX(bakapee, 1, &gvar); + modexPalBlack(); /* set up the page, but with 16 pixels on all borders in offscreen mem */ - gvar.video.page[0]=modexDefaultPage(&gvar.video.page[0]); - gvar.video.page[1] = modexNextPage(&gvar.video.page[0]); - gvar.video.page[0].width += 32; - gvar.video.page[0].height += 32; + modexHiganbanaPageSetup(&gvar.video); + for(i=0;i=31){ i++; j=0; goto baka; }else j++; }else + if(j>=32){ k++; j=0; }else j++; + break; + case 1: + // go left + gvar.video.page[pan.pn].dx--; + if(j>=32){ k++; j=0; }else j++; + break; + case 2: + // go up + gvar.video.page[pan.pn].dy++; + if(j>=32){ k++; j=0; }else j++; + break; + case 3: + // go down + gvar.video.page[pan.pn].dy--; + if(j>=32){ k=0; j=0; i++; }else j++; + break; + default: + + break; + }}else{ + if(i==5) goto pee; + baka: + i++; + modexClearRegion(&gvar.video.page[1], 0, gvar.video.page[0].height/2, gvar.video.page[0].width-32, 16, 45);*/ + if(IN_KeyDown(6)) + { + modexClearRegion(&gvar.video.page[1], gvar.video.page[1].sw, 16, 8, 4, 45); + } + if(IN_KeyDown(4+1)){ + modexClearRegion(&gvar.video.page[1], 16, 16, gvar.video.page[1].sw, gvar.video.page[1].sh, 128); + modexClearRegion(&gvar.video.page[1], 32, 32, gvar.video.page[1].sw-32, gvar.video.page[1].sh-32, 42); + modexClearRegion(&gvar.video.page[1], 48, 48, gvar.video.page[1].sw-64, gvar.video.page[1].sh-64, 128); + } + //} + if(IN_KeyDown(2)) pan.pn=0; + if(IN_KeyDown(3)) pan.pn=1; + if(IN_KeyDown(25)){ + modexpdump(&gvar.video.page[pan.pn]); + }//p + modexShowPage(&gvar.video.page[pan.pn]); } - /* go down */ - for(j=0; j<32; j++) { - gvar.video.page[0].dy--; - modexShowPage(&gvar.video.page[0]); - } -// switch (j) -// { -// case 31: -// case 32: -// j=0; -// break; -// } - i++; - } - - end = *clockw; + endclk = *clockw; /* fade back to text mode */ modexFadeOff(1, pal2); modexPalBlack(); - VGAmodeX(0, &gvar); + VGAmodeX(0, 1, &gvar); + printf("Project 16 test.exe. This is just a test file!\n"); + printf("version %s\n", VERSION); + printf("video memory remaining: %ld\n", gvar.video.vmem_remain); + printf("page "); + for(i=0; i