X-Git-Url: https://git.artsoft.org/?p=rocksndiamonds.git;a=blobdiff_plain;f=src%2Fgame.h;h=22ea2e7ee74e1aa2ae49a9b2d38555d46eec6f25;hp=e6b3f396a293aa124a4518cf0012489a18664799;hb=3ff2e8a0b5c27b99a9920bdf5ed82bc41bf40181;hpb=266e2ba566bc95aa4e4d727ea8d585ee92ecf086 diff --git a/src/game.h b/src/game.h index e6b3f396..22ea2e7e 100644 --- a/src/game.h +++ b/src/game.h @@ -1,15 +1,13 @@ -/*********************************************************** -* Rocks'n'Diamonds -- McDuffin Strikes Back! * -*----------------------------------------------------------* -* (c) 1995-2006 Artsoft Entertainment * -* Holger Schemel * -* Detmolder Strasse 189 * -* 33604 Bielefeld * -* Germany * -* e-mail: info@artsoft.org * -*----------------------------------------------------------* -* game.h * -***********************************************************/ +// ============================================================================ +// Rocks'n'Diamonds - McDuffin Strikes Back! +// ---------------------------------------------------------------------------- +// (c) 1995-2014 by Artsoft Entertainment +// Holger Schemel +// info@artsoft.org +// http://www.artsoft.org/ +// ---------------------------------------------------------------------------- +// game.h +// ============================================================================ #ifndef GAME_H #define GAME_H @@ -30,7 +28,6 @@ #define NUM_PANEL_ELEMENTS 8 #define NUM_PANEL_CE_SCORE 8 -#if 1 struct GamePanelInfo { struct TextPosInfo level_number; @@ -47,6 +44,7 @@ struct GamePanelInfo struct TextPosInfo time_hh; struct TextPosInfo time_mm; struct TextPosInfo time_ss; + struct TextPosInfo frame; struct TextPosInfo shield_normal; struct TextPosInfo shield_normal_time; struct TextPosInfo shield_deadly; @@ -88,26 +86,17 @@ struct GamePanelInfo struct GameButtonInfo { - struct MenuPosInfo stop; - struct MenuPosInfo pause; - struct MenuPosInfo play; - struct MenuPosInfo sound_music; - struct MenuPosInfo sound_loops; - struct MenuPosInfo sound_simple; -}; + struct Rect stop; + struct Rect pause; + struct Rect play; -#else + struct Rect sound_music; + struct Rect sound_loops; + struct Rect sound_simple; -struct GamePanelInfo -{ - struct XY level; - struct XY gems; - struct XY inventory; - struct XY keys; - struct XY score; - struct XY time; + struct Rect save; + struct Rect load; }; -#endif struct GameInfo { @@ -117,9 +106,11 @@ struct GameInfo /* values for graphics engine customization */ boolean use_native_emc_graphics_engine; + boolean use_native_sp_graphics_engine; boolean use_masked_pushing; int forced_scroll_delay_value; int scroll_delay_value; + int tile_size; /* values for engine initialization */ int default_push_delay_fixed; @@ -132,6 +123,10 @@ struct GameInfo int initial_move_delay_value[MAX_PLAYERS]; int initial_push_delay_value; + /* flag for single or multi-player mode (needed for playing tapes) */ + /* (when playing/recording games, this is identical to "setup.team_mode" */ + boolean team_mode; + /* flags to handle bugs in and changes between different engine versions */ /* (for the latest engine version, these flags should always be "FALSE") */ boolean use_change_when_pushing_bug; @@ -153,6 +148,7 @@ struct GameInfo boolean gravity; boolean explosions_delayed; boolean envelope_active; + boolean no_time_limit; /* (variable only in very special case) */ /* values for the new EMC elements */ int lenses_time_left; @@ -175,7 +171,7 @@ struct GameInfo boolean set_centered_player; /* values for random number generator initialization after snapshot */ - unsigned long num_random_calls; + unsigned int num_random_calls; }; struct PlayerInfo @@ -275,7 +271,7 @@ struct PlayerInfo int push_delay; int push_delay_value; - unsigned long actual_frame_counter; + unsigned int actual_frame_counter; int drop_delay; int drop_pressed_delay; @@ -328,7 +324,7 @@ void Moving2Blocked(int, int, int *, int *); void Blocked2Moving(int, int, int *, int *); void DrawDynamite(int, int); -void StartGameActions(boolean, boolean, long); +void StartGameActions(boolean, boolean, int); void GameActions(void); void GameActions_EM_Main(); @@ -339,6 +335,7 @@ void ScrollLevel(int, int); void InitPlayLevelSound(); void PlayLevelSound_EM(int, int, int, int); +void PlayLevelSound_SP(int, int, int, int); void RaiseScore(int); void RaiseScoreElement(int); @@ -346,7 +343,7 @@ void RaiseScoreElement(int); void RequestQuitGameExt(boolean, boolean, char *); void RequestQuitGame(boolean); -unsigned int InitEngineRandom_RND(long); +unsigned int InitEngineRandom_RND(int); unsigned int RND(int); void FreeEngineSnapshot(); @@ -356,7 +353,10 @@ boolean CheckEngineSnapshot(); void CreateGameButtons(); void FreeGameButtons(); +void MapGameButtons(); void UnmapGameButtons(); void RedrawGameButtons(); +void HandleSoundButtonKeys(Key); + #endif