X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Fgameloop.h;h=d98ff54f4ed798ff1a57ce15a1610296942562b7;hb=b524515944583916655a9f2cf1a667e55e7ed4ce;hp=cf001209bfb77faebf6c8f131455ed97fa0f9bd6;hpb=236df51d91f0845cd4e06b3269e262911d81f5db;p=supertux.git diff --git a/src/gameloop.h b/src/gameloop.h index cf001209b..d98ff54f4 100644 --- a/src/gameloop.h +++ b/src/gameloop.h @@ -23,8 +23,11 @@ #define SUPERTUX_GAMELOOP_H #include "special/timer.h" -#include "audio/sound.h" #include "special/base.h" +#include "special/frame_rate.h" +#include "statistics.h" + +using namespace SuperTux; /* GameLoop modes */ @@ -34,7 +37,6 @@ #define ST_GL_LOAD_LEVEL_FILE 3 #define ST_GL_DEMO_GAME 4 - enum GameMenuIDs { MNID_CONTINUE, MNID_ABORTLEVEL @@ -44,7 +46,11 @@ extern int game_started; class Level; class Sector; +class Statistics; + +namespace SuperTux { class DrawingContext; +} /** The GameSession class controlls the controll flow of a World, ie. present the menu on specifc keypresses, render and update it while @@ -61,10 +67,8 @@ private: int st_gl_mode; int levelnb; float fps_fps; - unsigned int last_update_time; - unsigned int update_time; + FrameRate frame_rate; int pause_menu_frame; - int debug_fps; /** If true the end_sequence will be played, user input will be ignored while doing that */ @@ -84,6 +88,7 @@ private: // the sector and spawnpoint we shoudl spawn after this frame std::string newsector; std::string newspawnpoint; + public: enum ExitStatus { ES_NONE, ES_LEVEL_FINISHED, ES_GAME_OVER, ES_LEVEL_ABORT }; private: @@ -92,7 +97,7 @@ public: DrawingContext* context; Timer time_left; - GameSession(const std::string& level, int mode, bool flip_level_ = false); + GameSession(const std::string& level, int mode, bool flip_level_ = false, Statistics* statistics = NULL); ~GameSession(); /** Enter the busy loop */ @@ -113,6 +118,17 @@ public: private: static GameSession* current_; + // for cheating + std::string last_keys; + // for fire works + Timer random_timer; + + // swap points + Vector last_swap_point; + Statistics last_swap_stats; + + Statistics* best_level_statistics; + void restart_level(); void check_end_conditions(); @@ -124,7 +140,6 @@ private: void drawendscreen(); void drawresultscreen(void); -private: void on_escape_press(); void process_menu(); };