X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?a=blobdiff_plain;f=src%2Fscreen.c;h=2b551f46a667f3880b48599e75c185459df655fc;hb=134c9e63e9a7602cd2e0a3c05557edb0c9753c74;hp=927903b13af0bdeee9551be9524373b09e467fd1;hpb=562d5ba2221876479318073167c67ef74ca50c69;p=dosdemo diff --git a/src/screen.c b/src/screen.c index 927903b..2b551f4 100644 --- a/src/screen.c +++ b/src/screen.c @@ -9,8 +9,12 @@ struct screen *tunnel_screen(void); struct screen *fract_screen(void); struct screen *grise_screen(void); struct screen *polytest_screen(void); +struct screen *plasma_screen(void); +struct screen *bump_screen(void); +struct screen *thunder_screen(void); +struct screen *metaballs_screen(void); -#define NUM_SCR 32 +#define NUM_SCR 32 static struct screen *scr[NUM_SCR]; static int num_screens; @@ -33,25 +37,26 @@ int scr_init(void) if(!(scr[idx++] = polytest_screen())) { return -1; } + if (!(scr[idx++] = plasma_screen())) { + return -1; + } + if (!(scr[idx++] = bump_screen())) { + return -1; + } + if (!(scr[idx++] = thunder_screen())) { + return -1; + } + if(!(scr[idx++] = metaballs_screen())) { + return -1; + } num_screens = idx; assert(num_screens <= NUM_SCR); for(i=0; iinit(); - if(r == -1) { + if(scr[i]->init() == -1) { return -1; } - - /* Make the effect run first if it returns "CAFE" from ins init() */ - if (r == 0xCAFE) { - struct screen *tmp; - tmp = scr[i]; - scr[i] = scr[0]; - scr[0] = tmp; - printf("*** Screen %s displayed out of order ***\n", scr[0]->name); - } } return 0; } @@ -66,7 +71,7 @@ void scr_shutdown(void) void scr_update(void) { - if(prev) { /* we're in the middle of a transition */ + if(prev) { /* we're in the middle of a transition */ long interval = time_msec - trans_start; if(interval >= trans_dur) { if(next->start) { @@ -111,7 +116,7 @@ int scr_change(struct screen *s, long trans_time) if(s == cur) return 0; if(trans_time) { - trans_dur = trans_time / 2; /* half for each part transition out then in */ + trans_dur = trans_time / 2; /* half for each part transition out then in */ trans_start = time_msec; } else { trans_dur = 0;