1
0
Fork 0
Toy-Raytracer/World.h

61 lines
1.5 KiB
C
Raw Normal View History

2019-05-27 13:50:49 +02:00
//
// Created by trotfunky on 27/05/19.
//
#ifndef RAYCASTING_WORLD_H
#define RAYCASTING_WORLD_H
#include <vector>
#include <ostream>
#include <SFML/Graphics.hpp>
#include <iostream>
#include "Player.h"
2019-05-27 13:50:49 +02:00
enum class BlockType {
AIR,
WALL,
DOOR,
WINDOW,
};
class World {
public:
Player player;
2019-05-27 13:50:49 +02:00
2024-01-21 20:41:19 +00:00
World(int w, int h,
sf::Color groundColor = sf::Color{67, 137, 39},
sf::Color ceilingColor = sf::Color{39, 69, 137},
std::vector<BlockType> worldMap = {});
2019-05-27 13:50:49 +02:00
int getW() const;
int getH() const;
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&) const;
2019-05-27 13:50:49 +02:00
friend std::ostream& operator<<(std::ostream& ostream, World const & world);
private:
int w;
int h;
std::vector<BlockType> map;
sf::Color groundColor;
sf::Color ceilingColor;
2024-01-21 20:41:19 +00:00
void fillColumn(sf::RenderWindow&, int column, float scale,
sf::Color wallColor = sf::Color(84,56,34)) const;
/**
* Cast a ray from a given position and return the on-screen scale.
* @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 Scale on the screen of the hit wall.
*/
float castRay(float originX, float originY, float orientation) const;
2019-05-27 13:50:49 +02:00
};
#endif //RAYCASTING_WORLD_H