X-Git-Url: https://git.artsoft.org/?a=blobdiff_plain;f=src%2Fcartoons.c;h=1f430493f64334296300851c3f479f078fa7c8f7;hb=12a8eb6ca28aa97f422e7cf9317f01eb0dfc9a11;hp=eb43b98d309b5643c6c647f58ae73e5fd9d2db97;hpb=7119b5d2e756b1ab23818ea39d19aece0563bab0;p=rocksndiamonds.git diff --git a/src/cartoons.c b/src/cartoons.c index eb43b98d..1f430493 100644 --- a/src/cartoons.c +++ b/src/cartoons.c @@ -1,7 +1,7 @@ /*********************************************************** * Rocks'n'Diamonds -- McDuffin Strikes Back! * *----------------------------------------------------------* -* (c) 1995-2002 Artsoft Entertainment * +* (c) 1995-2006 Artsoft Entertainment * * Holger Schemel * * Detmolder Strasse 189 * * 33604 Bielefeld * @@ -17,362 +17,55 @@ /* values for toon definition */ -#if 0 -#define NUM_TOONS 18 -#else -#define NUM_TOONS 6 -#endif +#define MAX_NUM_TOONS 20 -#define DWARF_XSIZE 40 -#define DWARF_YSIZE 48 -#define DWARF_X 2 -#define DWARF_Y 72 -#define DWARF2_Y 186 -#define DWARF_FRAMES 8 -#define DWARF_DELAY 5 -#define DWARF_STEPSIZE 4 -#define JUMPER_XSIZE 48 -#define JUMPER_YSIZE 56 -#define JUMPER_X 2 -#define JUMPER_Y 125 -#define JUMPER_FRAMES 8 -#define JUMPER_DELAY 5 -#define JUMPER_STEPSIZE 4 -#define CLOWN_XSIZE 80 -#define CLOWN_YSIZE 110 -#define CLOWN_X 327 -#define CLOWN_Y 10 -#define CLOWN_FRAMES 1 -#define CLOWN_DELAY 5 -#define CLOWN_STEPSIZE 4 -#define BIRD_XSIZE 32 -#define BIRD_YSIZE 30 -#define BIRD1_X 2 -#define BIRD1_Y 2 -#define BIRD2_X 2 -#define BIRD2_Y 37 -#define BIRD_FRAMES 8 -#define BIRD_DELAY 2 -#define BIRD_STEPSIZE 4 +static struct ToonInfo toons[MAX_NUM_TOONS]; -struct ToonInfo toons[NUM_TOONS] = +static void PrepareBackbuffer() { -#if 0 - { - IMG_GLOBAL_TOONS, - DWARF_XSIZE, DWARF_YSIZE, - DWARF_X, DWARF_Y, - DWARF_FRAMES, - DWARF_DELAY, - DWARF_STEPSIZE, - ANIM_LOOP, - ANIMDIR_RIGHT, - ANIMPOS_DOWN - }, - { - IMG_GLOBAL_TOONS, - DWARF_XSIZE, DWARF_YSIZE, - DWARF_X, DWARF2_Y, - DWARF_FRAMES, - DWARF_DELAY, - DWARF_STEPSIZE, - ANIM_LOOP, - ANIMDIR_LEFT, - ANIMPOS_DOWN - }, - { - IMG_GLOBAL_TOONS, - JUMPER_XSIZE, JUMPER_YSIZE, - JUMPER_X, JUMPER_Y, - JUMPER_FRAMES, - JUMPER_DELAY, - JUMPER_STEPSIZE, - ANIM_LOOP, - ANIMDIR_RIGHT, - ANIMPOS_DOWN - }, - { - IMG_GLOBAL_TOONS, - CLOWN_XSIZE, CLOWN_YSIZE, - CLOWN_X, CLOWN_Y, - CLOWN_FRAMES, - CLOWN_DELAY, - CLOWN_STEPSIZE, - ANIM_LOOP, - ANIMDIR_UP, - ANIMPOS_ANY - }, - { - IMG_GLOBAL_TOONS, - BIRD_XSIZE, BIRD_YSIZE, - BIRD1_X, BIRD1_Y, - BIRD_FRAMES, - BIRD_DELAY, - BIRD_STEPSIZE, - ANIM_PINGPONG, - ANIMDIR_RIGHT, - ANIMPOS_UPPER - }, - { - IMG_GLOBAL_TOONS, - BIRD_XSIZE, BIRD_YSIZE, - BIRD2_X, BIRD2_Y, - BIRD_FRAMES, - BIRD_DELAY, - BIRD_STEPSIZE, - ANIM_PINGPONG, - ANIMDIR_LEFT, - ANIMPOS_UPPER - }, -#else - { - IMG_TOON_1, - -1, -1, - -1, -1, - -1, - -1, - -1, - -1, - ANIMDIR_RIGHT, - ANIMPOS_DOWN - }, - { - IMG_TOON_2, - -1, -1, - -1, -1, - -1, - -1, - -1, - -1, - ANIMDIR_LEFT, - ANIMPOS_DOWN - }, - { - IMG_TOON_3, - -1, -1, - -1, -1, - -1, - -1, - -1, - -1, - ANIMDIR_RIGHT, - ANIMPOS_DOWN - }, - { - IMG_TOON_4, - -1, -1, - -1, -1, - -1, - -1, - -1, - -1, - ANIMDIR_UP, - ANIMPOS_ANY - }, - { - IMG_TOON_5, - -1, -1, - -1, -1, - -1, - -1, - -1, - -1, - ANIMDIR_RIGHT, - ANIMPOS_UPPER - }, - { - IMG_TOON_6, - -1, -1, - -1, -1, - -1, - -1, - -1, - -1, - ANIMDIR_LEFT, - ANIMPOS_UPPER - }, -#endif + if (game_status != GAME_MODE_PLAYING) + return; -#if 0 - { - IMG_PLAYER1_MOVING_LEFT, - -1, -1, - -1, -1, - -1, - -1, - -1, - -1, - ANIMDIR_LEFT, - ANIMPOS_DOWN - }, - { - IMG_PLAYER1_MOVING_RIGHT, - -1, -1, - -1, -1, - -1, - -1, - -1, - -1, - ANIMDIR_RIGHT, - ANIMPOS_DOWN - }, - { - IMG_PENGUIN_MOVING_LEFT, - -1, -1, - -1, -1, - -1, - -1, - -1, - -1, - ANIMDIR_LEFT, - ANIMPOS_DOWN - }, - { - IMG_PENGUIN_MOVING_RIGHT, - -1, -1, - -1, -1, - -1, - -1, - -1, - -1, - ANIMDIR_RIGHT, - ANIMPOS_DOWN - }, - { - IMG_MOLE_MOVING_LEFT, - -1, -1, - -1, -1, - -1, - -1, - -1, - -1, - ANIMDIR_LEFT, - ANIMPOS_DOWN - }, - { - IMG_MOLE_MOVING_RIGHT, - -1, -1, - -1, -1, - -1, - -1, - -1, - -1, - ANIMDIR_RIGHT, - ANIMPOS_DOWN - }, - { - IMG_PIG_MOVING_LEFT, - -1, -1, - -1, -1, - -1, - -1, - -1, - -1, - ANIMDIR_LEFT, - ANIMPOS_DOWN - }, - { - IMG_PIG_MOVING_RIGHT, - -1, -1, - -1, -1, - -1, - -1, - -1, - -1, - ANIMDIR_RIGHT, - ANIMPOS_DOWN - }, - { - IMG_DRAGON_MOVING_LEFT, - -1, -1, - -1, -1, - -1, - -1, - -1, - -1, - ANIMDIR_LEFT, - ANIMPOS_DOWN - }, - { - IMG_DRAGON_MOVING_RIGHT, - -1, -1, - -1, -1, - -1, - -1, - -1, - -1, - ANIMDIR_RIGHT, - ANIMPOS_DOWN - }, - { - IMG_SATELLITE_MOVING, - -1, -1, - -1, -1, - -1, - -1, - -1, - -1, - ANIMDIR_LEFT, - ANIMPOS_ANY - }, +#if 1 + BlitScreenToBitmap(backbuffer); +#else + if (level.game_engine_type == GAME_ENGINE_TYPE_EM) { - IMG_SATELLITE_MOVING, - -1, -1, - -1, -1, - -1, - -1, - -1, - -1, - ANIMDIR_RIGHT, - ANIMPOS_ANY - }, -#endif - -}; - -static void PrepareBackbuffer() -{ - /* Fill empty backbuffer for animation functions */ - if (setup.direct_draw && game_status == PLAYING) + BlitScreenToBitmap_EM(backbuffer); + } + else if (level.game_engine_type == GAME_ENGINE_TYPE_SP) { - int xx,yy; - - SetDrawtoField(DRAW_BACKBUFFER); - - for(xx=0; xx= 0 && global.num_toons < MAX_NUM_TOONS) + num_toons = global.num_toons; + + for (i = 0; i < num_toons; i++) { - int graphic = toons[i].graphic; + int graphic = IMG_TOON_1 + i; + struct FileInfo *image = getImageListEntryFromImageID(graphic); toons[i].bitmap = graphic_info[graphic].bitmap; @@ -389,11 +82,18 @@ void InitToons() toons[i].step_offset = graphic_info[graphic].step_offset; toons[i].step_delay = graphic_info[graphic].step_delay; + + toons[i].direction = image->parameter[GFX_ARG_DIRECTION]; + toons[i].position = image->parameter[GFX_ARG_POSITION]; } +#if 1 + InitToonScreen(bitmap_db_toons, +#else InitToonScreen(bitmap_db_door, +#endif BackToFront, PrepareBackbuffer, ToonNeedsRedraw, - toons, NUM_TOONS, + toons, num_toons, REAL_SX, REAL_SY, FULL_SXSIZE, FULL_SYSIZE, GAME_FRAME_DELAY); }