/** * @file world.hpp * Manages the world systems * * Copyright (C) 2019 Belle-Isle, Andrew * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #ifndef SYSTEM_WORLD_HPP_ #define SYSTEM_WORLD_HPP_ #include #include #include #include "texture.hpp" struct WorldMeshData { float posX, posY, posZ; float texX, texY; float transparency; }; struct WorldMaterial { bool passable = false; Texture texture; Texture normal; WorldMaterial(sol::table tab) { if (tab["texture"] != nullptr) { sol::object t = tab["texture"]; texture = Texture(t); } if (tab["normal"] != nullptr) { sol::object n = tab["normal"]; normal = Texture(n); } if (tab["passable"] == sol::type::boolean) { passable = tab["passable"]; } } }; class World { private: unsigned int seed; unsigned int layers; unsigned int height; unsigned int width; std::vector>> data; std::unordered_map string_registry; std::vector registry; std::basic_string mesh; public: /* VARS */ sol::function generate; sol::function registerMat; World() {} World(sol::object ref); ~World() { registerMat = sol::nil; generate = sol::nil; registry.clear(); data.clear(); } /* REGISTRY */ void registerMaterial(std::string, sol::object); /* DATA */ void setData(unsigned int, unsigned int, unsigned int, std::string); /* SIZE */ std::tuple setSize(unsigned int, unsigned int, unsigned int); std::tuple getSize(); /* RENDERING */ void generateMesh(); /* SEED */ unsigned int getSeed(); unsigned int setSeed(unsigned int); }; /** * @class WorldSystem * Handles the game's world system */ class WorldSystem : public entityx::System { private: std::vector worlds; World* currentWorld; public: WorldSystem(void): currentWorld(nullptr) {} ~WorldSystem(void) { currentWorld = nullptr; worlds.clear(); } World* addWorld(sol::object); void cleanup() { worlds.clear(); } /** * Prepares the system for running. */ void configure(entityx::EntityManager& entities, entityx::EventManager& events) final; /** * Updates the world ticks (entity spawns and world events) */ void update(entityx::EntityManager& entites, entityx::EventManager& events, entityx::TimeDelta dt) final; }; #endif // SYSTEM_WORLD_HPP_