X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=src%2Fbakapi.c;h=a08470bda3667ef240077d2bb1b25a912063129c;hb=579be865a2f1d2a84d5295506f3e8ea9815d11af;hp=00fc689f94c1be2db7d25c24bcad660cb87149b9;hpb=7b2ed51a7adf23448e6cfd31b303b4ba0bf03092;p=proj16%2F16.git diff --git a/src/bakapi.c b/src/bakapi.c index 00fc689f..a08470bd 100755 --- a/src/bakapi.c +++ b/src/bakapi.c @@ -1,5 +1,5 @@ /* Project 16 Source Code~ - * Copyright (C) 2012-2016 sparky4 & pngwen & andrius4669 & joncampbell123 & yakui-lover + * Copyright (C) 2012-2020 sparky4 & pngwen & andrius4669 & joncampbell123 & yakui-lover * * This file is part of Project 16. * @@ -25,19 +25,24 @@ /* * BAKAPEE! */ -global_game_variables_t gvar; static bakapee_t bakapee; word key,d,xpos,ypos,xdir,ydir; -sword vgamodex_mode = 1; // 320x240 default -int ch=0x0; +sword vgamodex_mode = 1; // 1 = 320x240 with buffer +void TL_VidInit(global_game_variables_t *gvar){} +//int ch=0x0; + void main(int argc, char *argvar[]) { + static global_game_variables_t gvar; + struct glob_game_vars *ggvv; char *a; - int i; - word panq=1, pand=0; - boolean panswitch=0; + int i,c; + word panq=1, pand=0,showding=0; + boolean panswitch=0,bptest=1,runding=1; + + ggvv=&gvar; // allow changing default mode from command line for (i=1;i < argc;) { @@ -66,64 +71,111 @@ main(int argc, char *argvar[]) } } - // 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; - } + // initiate doslib // + TL_DosLibStartup(&gvar); // main variables values d=4; // switch variable key=2; // default screensaver number - xpos=TILEWHD; - ypos=TILEWHD; - xdir=1; - ydir=1; + xpos=TILEWHD; ypos=TILEWHD; xdir=1; ydir=1; - VGAmodeX(vgamodex_mode, 1, &gvar); // TODO: Suggestion: Instead of magic numbers for the first param, might I suggest defining an enum or some #define constants that are easier to remember? --J.C. + VGAmodeX(vgamodex_mode, 0, &gvar); // TODO: Suggestion: Instead of magic numbers for the first param, might I suggest defining an enum or some #define constants that are easier to remember? --J.C. // this code is written around modex16 which so far is a better fit than using DOSLIB vga directly, so leave MXLIB code in. // we'll integrate DOSLIB vga into that part of the code instead for less disruption. -- J.C. + bakapee.xx = rand()&0%gvar.video.page[0].width; bakapee.yy = rand()&0%gvar.video.page[0].height; + bakapee.gq = 0; bakapee.sx=bakapee.sy=0; bakapee.bakax=bakapee.bakay=0; bakapee.coor=0; + //once where #defines + bakapee.tile=0; bakapee.bonk=400; bakapee.lgq=32; bakapee.hgq=55; + + switch(WCPU_detectcpu()) + { + case 0: + bakapee.tile=1; + break; + default: + bakapee.tile=0; + break; + } + + // setup camera and screen~ // + SETUPPAGEBAKAPI - bakapee.xx = rand()&0%gvar.video.page[0].width; - bakapee.yy = rand()&0%gvar.video.page[0].height; - bakapee.gq = 0; - bakapee.sx=0; - bakapee.sy=0; - bakapee.bakax=0; - bakapee.bakay=0; - bakapee.coor=0; - bakapee.tile=0; + VL_ShowPage(&gvar.video.page[0], 1, 0); + BAKAPIINITFIZZTEST - /* setup camera and screen~ */ - gvar.video.page[0] = modexDefaultPage(&gvar.video.page[0]); - textInit(); + while (bptest) + { +/* if (key > 0) + {*/ + while (!kbhit() && runding) + { + //{ word w; for(w=0;w<(gvar.video.page[0].width*gvar.video.page[0].height);w++) {}} + ding(&gvar.video.page[showding], &bakapee, 4); + } + if (kbhit()) +// { + getch(); // eat keyboard input +// break; +// } +// }*/ + + { + + c = getch(); + switch (c) + { + case 27: // Escape key // + case '0': + default: + bptest = false; + break; + case 'b': // test tile change // + switch (bakapee.tile) + { + case 0: + bakapee.tile=1; + break; + case 1: + bakapee.tile=0; + break; + } + break; + case 'r': + runding = false; + BAKAPIINITFIZZTEST + break; + case 'e': + runding = 1; + break; + case 'z': + runding = false; + FIZZFADEFUN +// runding = true; + break; + case '3': + case '4': + runding = 1; + showding = c - '0' - 3; + break; + case '1': + case '2': + // case '5': + // case '6': + // case '9': + key = c - '0' - 1; + VL_ShowPage(&gvar.video.page[key], 1, 0); + break; + } + } + } - //modexPalUpdate(bmp.palette); //____ - //modexDrawBmp(VGA, 0, 0, &bmp, 0); //____ - //getch(); //____ - modexShowPage(&gvar.video.page[0]); +//while(!kbhit()){} // screen savers -#ifdef BOINK +//#ifdef BOINK while(d>0) // on! { - int c; /* run screensaver routine until keyboard input */ while (key > 0) { if (kbhit()) { @@ -134,7 +186,13 @@ main(int argc, char *argvar[]) }else c=getch(); } - if(!panswitch) ding(&gvar.video.page[0], &bakapee, key); + if(!panswitch){ + if(key==9) + { + ding(&gvar.video.page[1], &bakapee, 4); + ding(&gvar.video.page[0], &bakapee, 4); + FIZZFADEFUN + }else ding(&gvar.video.page[0], &bakapee, key); } else ding(&gvar.video.page[0], &bakapee, 2); if(panswitch!=0) { @@ -145,7 +203,7 @@ main(int argc, char *argvar[]) if(panq<=(TILEWH/(4))) { gvar.video.page[0].dx++; - modexShowPage(&gvar.video.page[0]); + VL_ShowPage(&gvar.video.page[0], 0, 0); panq++; } else { panq = 1; pand = 0; } } @@ -156,7 +214,7 @@ main(int argc, char *argvar[]) if(panq<=(TILEWH/(4))) { gvar.video.page[0].dx--; - modexShowPage(&gvar.video.page[0]); + VL_ShowPage(&gvar.video.page[0], 0, 0); panq++; } else { panq = 1; pand = 0; } } @@ -167,7 +225,7 @@ main(int argc, char *argvar[]) if(panq<=(TILEWH/(4))) { gvar.video.page[0].dy++; - modexShowPage(&gvar.video.page[0]); + VL_ShowPage(&gvar.video.page[0], 0, 0); panq++; } else { panq = 1; pand = 0; } } @@ -178,10 +236,28 @@ main(int argc, char *argvar[]) if(panq<=(TILEWH/(4))) { gvar.video.page[0].dy--; - modexShowPage(&gvar.video.page[0]); + VL_ShowPage(&gvar.video.page[0], 0, 0); panq++; } else { panq = 1; pand = 0; } } + if((c==0x4d && pand == 0) || pand == 2) + { + if(pand == 0){ pand = 2; } + if(panq<=(TILEWH/(4))) + { + gvar.video.page[0].dx++; + VL_ShowPage(&gvar.video.page[0], 0, 0); + panq++; + } else { panq = 1; pand = 0; } + } + if(c==0x01+1) + { + VL_ShowPage(&gvar.video.page[0], 0, 0); + } + if(c==0x02+1) + { + VL_ShowPage(&gvar.video.page[1], 0, 0); + } if(c==0x71 || c==0xb1 || c=='p') { //getch(); // eat keyboard input @@ -196,6 +272,7 @@ main(int argc, char *argvar[]) // this code is written around modex16 which so far is a better fit than using DOSLIB vga directly, so leave MXLIB code in. // we'll integrate DOSLIB vga into that part of the code instead for less disruption. -- J.C. VGAmodeX(0, 0, &gvar); + clrscr(); //added to clear screen wwww // user imput switch //fprintf(stderr, "xx=%d yy=%d tile=%d\n", bakapee.xx, bakapee.yy, bakapee.tile); //fprintf(stderr, "dx=%d dy=%d ", gvar.video.page[0].dx, gvar.video.page[0].dy); @@ -209,17 +286,18 @@ main(int argc, char *argvar[]) printf("on. "); break; } - //printf("\n"); printf("Pan mode is "); switch (panswitch) { case 0: - printf("off.\n"); + printf("off."); break; case 1: - printf("on.\n"); + printf("on."); break; } + printf("\n"); + printf("Incrementation of color happens at every %uth plot.\n", bakapee.bonk); printf("Enter 1, 2, 3, 4, 5, 6, 8, or 9 to run a screensaver, or enter 0 to quit.\n"); pee: c = getch(); @@ -229,16 +307,17 @@ pee: d=0; break; case 'p': // test pan - switch (panswitch) - { - case 0: - panswitch=1; - break; - case 1: - panswitch=0; - break; - } - goto pee; + switch (panswitch) + { + case 0: + panswitch=1; + break; + case 1: + panswitch=0; + break; + } + key=0; + goto pee; break; case 'b': // test tile change switch (bakapee.tile) @@ -251,7 +330,7 @@ pee: break; } key=0; - break; + break; case '8': c+=8; case '1': @@ -263,18 +342,29 @@ pee: case '9': key = c - '0'; VGAmodeX(vgamodex_mode, 0, &gvar); - gvar.video.page[0] = modexDefaultPage(&gvar.video.page[0]); + SETUPPAGEBAKAPI // this code is written around modex16 which so far is a better fit than using DOSLIB vga directly, so leave MXLIB code in. // we'll integrate DOSLIB vga into that part of the code instead for less disruption. -- J.C. - modexShowPage(&gvar.video.page[0]); - break; + VL_ShowPage(&gvar.video.page[0], 0, 0); + break; + case '-': + if(bakapee.bonk>0) + bakapee.bonk-=100; + break; + case '=': + case '+': + if(bakapee.bonk<1000) + bakapee.bonk+=100; + break; default: key=0; - break; + break; } } } -#else // !defined(BOINK) + clrscr(); //added to clear screen wwww +#if 0 +//#else // !defined(BOINK) // FIXME: Does not compile. Do you want to remove this? // INFO: This is a testing section for textrendering and panning for project 16 --sparky4 while(1) @@ -310,5 +400,7 @@ pee: // printf("page.width=%u ", gvar.video.page[0].width); printf("page.height=%u\n", gvar.video.page[0].height); printf("bakapi ver. 1.04.16.04\nis made by sparky4i†ƒÖ…j feel free to use it ^^\nLicence: GPL v3\n"); printf("compiled on 2016/04/04\n"); +// printf("[%u]%dx%d [%dx%d] %u %u %u\n[%u %u %u]", key, bakapee.bakax, bakapee.bakay, bakapee.xx, bakapee.yy, +//bakapee.coor, bakapee.tile, bakapee.gq, bakapee.bonk, bakapee.lgq, bakapee.hgq); } //pee!