// // Created by trotfunky on 27/05/19. // #ifndef RAYCASTING_WORLD_H #define RAYCASTING_WORLD_H #include #include #include #include #include #include "Color.h" #include "Player.h" enum class BlockType { AIR, WALL, DOOR, WINDOW, }; struct RaycastResult { float distance; float hitX; float hitY; BlockType hitBlock; }; class World { public: Player player; World(int w, int h, sf::Color groundColor = Colors::Ground, sf::Color ceilingColor = Colors::Ceiling, std::vector worldMap = {}); int getW() const; int getH() const; void resizeWindow(const sf::FloatRect& resizedView); inline BlockType getBlock(int x, int y) const; inline BlockType getBlock(float x, float y) const; void setBlock(BlockType block, int x, int y, int width = 1, int height = 1); void render(sf::RenderWindow&); /** * Move the world one step forward. * @param stepTime delta time since last step, in seconds */ void step(const float& stepTime); friend std::ostream& operator<<(std::ostream& ostream, World const & world); private: int w; int h; std::vector renderColumns; std::vector map; sf::Color groundColor; sf::Color ceilingColor; void fillColumn(sf::RenderWindow&, unsigned int column, float scale, sf::Color fillColor = Colors::Wall); /** * Cast a ray from a given position and return its distance to the origin. * @param originX Ray X origin, strictly positive * @param originY Ray Y origin, strictly positive * @param orientation Angle to cast to, in degrees between 0 and 360 * @return Result struct containing information on the hit. */ RaycastResult castRay(float originX, float originY, float orientation) const; }; #endif //RAYCASTING_WORLD_H