diff options
author | Clyne Sullivan <tullivan99@gmail.com> | 2016-12-21 21:40:05 -0500 |
---|---|---|
committer | Clyne Sullivan <tullivan99@gmail.com> | 2016-12-21 21:40:05 -0500 |
commit | ae9ceadaa184f5e9775135ae264c8bbffd4efa9d (patch) | |
tree | 3707642bda2646ede6d4c77f33b9d8a0326b0636 /include/config.hpp | |
parent | a44540462145212f7f2cc3ea2690308c58f60358 (diff) | |
parent | fa802f8fbc62910b37002bcdd2f7c110f488e392 (diff) |
Merge branch 'master' of https://github.com/tcsullivan/gamedev
Diffstat (limited to 'include/config.hpp')
-rw-r--r-- | include/config.hpp | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/include/config.hpp b/include/config.hpp index bc9d052..908c376 100644 --- a/include/config.hpp +++ b/include/config.hpp @@ -1,23 +1,72 @@ +/** + * @file config.hpp + * @brief Functions for loading/saving game settings. + */ + #ifndef CONFIG_H #define CONFIG_H #include <string> namespace game { + /** + * The size of an HLINE, according to the save file. + * This is the default "unit of measurement" in the game. Drawing scales to + * this, and it is used in game logic. + */ extern unsigned int HLINE; + + /** + * The width of the screen, in pixels. + */ extern unsigned int SCREEN_WIDTH; + + /** + * The height of the screen, in pixels. + */ extern unsigned int SCREEN_HEIGHT; + + /** + * The window is fullscreen if this is true. + */ extern bool FULLSCREEN; namespace config { + /** + * The current volume level of the master channel. + * Volumes are percentages, 0 to 100. + */ extern float VOLUME_MASTER; + + /** + * Volume level of the background music (BGM). + */ extern float VOLUME_MUSIC; + + /** + * Volume level of game sound effects. + */ extern float VOLUME_SFX; + /** + * The path of the folder to load world XML files from. + */ extern std::string xmlFolder; + /** + * Reads the settings file (config/settings.xml) into the game. + * Default values are hardcoded in (see src/config.cpp). + */ void read(void); + + /** + * Updates settings with the current values. + */ void update(void); + + /** + * Saves the current settings to the settings file. + */ void save(void); } } |