/** * @file world.hpp * @brief The world system */ #ifndef WORLD_HPP_ #define WORLD_HPP_ #include #include #include #include #include using namespace tinyxml2; #include #include #include #include #include /** * The line structure. * This structure is used to store the world's ground, stored in vertical * lines. Dirt color and grass properties are also kept track of here. */ struct WorldData { bool grassUnpressed; /**< squishes grass if false */ float grassHeight[2]; /**< height of the two grass blades */ float groundHeight; /**< height of the 'line' */ unsigned char groundColor; /**< a value that affects the ground's color */ }; /** * Defines how many game ticks it takes to go from day to night or vice versa. * Technically a half day cycle... */ constexpr const unsigned int DAY_CYCLE = 10000; /** * Defines the strongest pull gravity can have on an entity. * This is the most that can be subtracted from an entity's velocity in one * game tick. */ constexpr const float GRAVITY_CONSTANT = 0.001f; /** * Defines the thickness of the floor in an indoor world. */ constexpr const unsigned int INDOOR_FLOOR_THICKNESS = 50; /** * Defines how far each floor can be from the next (height). */ constexpr const unsigned int INDOOR_FLOOR_HEIGHTT = 400; /** * Gets a combined height of the floor and the area before it. * This value is commonly used for operations like moving between floors. */ constexpr const unsigned int INDOOR_FLOOR_HEIGHT = (INDOOR_FLOOR_HEIGHTT + INDOOR_FLOOR_THICKNESS); /** * World data. * Contains all necessary data for a world. An instance of this is kept in the * world system, and is populated through it's load() function. */ struct WorldData2 { // Data variables std::vector data; /**< The world's ground data. */ float startX; /**< The furthest left coordinate of the world. */ // Indoor variables bool indoor; /**< Set to true if this is an indoor world. */ Texture indoorTex; /**< The house's inside texture. */ std::string outdoor; /**< The file name of the outdoor world. */ vec2 outdoorCoords; /**< The coordinates the player should spawn to when exiting. */ // World linkage std::string toLeft, toRight; /**< File names of the worlds adjacent to this one. */ // Style variables std::string styleFolder; /**< The folder to get stylized textures from. */ // Music std::string bgm; /**< The path to the BGM file. */ }; /** * The world system * Does everything needed to take care of the world. */ class WorldSystem : public entityx::System, public entityx::Receiver { private: /** * The world's data. */ static WorldData2 world; /** * SDL's object for handling the background music. */ static Mix_Music *bgmObj; static std::string bgmCurrent; /** * Allows for iteration between background textures, for rendering. */ static TextureIterator bgTex; /** * An object to handle and parse world XML files. */ static XMLDocument xmlDoc; /** * The file path to the currently loaded world. */ static std::string currentXMLFile; static std::string toLoad; static std::vector stars; static int getLineIndex(float x); public: static std::thread thAmbient; explicit WorldSystem(void); ~WorldSystem(void); void configure(entityx::EventManager &ev) { ev.subscribe(*this); } static inline XMLDocument* getXML(void) { return &xmlDoc; } static inline float getWidth(void) //const { return world.startX * -2.0f; } static inline const std::string& getXMLFile(void) //const { return currentXMLFile; } static float isAboveGround(const vec2& p); //const; bool receive(const BGMToggleEvent &bte); void update(entityx::EntityManager &en, entityx::EventManager &ev, entityx::TimeDelta dt) override; static void render(void); void detect(entityx::TimeDelta dt); static void goWorldLeft(Position& p); static void goWorldRight(Position& p, Solid &d); static void goWorldPortal(Position& p); static void generate(LuaScript& script); static void generate(int width = 0); static bool save(void); static void load(const std::string& file); void fight(entityx::Entity entity); static void die(void); static void loader(void); static inline bool shouldLoad(void) { return !toLoad.empty(); } }; #endif // WORLD_HPP_