X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Ftilemap.h;h=8aa2b481a21f6a772d10d841ace1e101c680ac75;hb=6e843b1780f62f45b7021bd8c38181aa211588ee;hp=6f826421b0a4fb2cde3d7f8eee6291876badf143;hpb=f9c5c22959ac3020274f3be3531d176e413b0220;p=supertux.git diff --git a/src/tilemap.h b/src/tilemap.h index 6f826421b..8aa2b481a 100644 --- a/src/tilemap.h +++ b/src/tilemap.h @@ -21,25 +21,22 @@ #define SUPERTUX_TILEMAP_H #include +#include -#include "game_object.h" +#include "special/game_object.h" #include "serializable.h" -#include "vector.h" +#include "math/vector.h" + +using namespace SuperTux; + +namespace SuperTux { +class LispReader; +} class Level; class TileManager; -class LispReader; class Tile; -struct TileId -{ - TileId() : id(0), hidden(0) {} - explicit TileId(unsigned int i, bool hidden_ = false) : id(i), hidden(hidden_) {} - - unsigned id :31; - unsigned hidden :1; -}; - /** * This class is reponsible for drawing the level tiles */ @@ -48,6 +45,7 @@ class TileMap : public GameObject, public Serializable public: TileMap(); TileMap(LispReader& reader); + TileMap(int layer_, bool solid_, size_t width_, size_t height_); virtual ~TileMap(); virtual void write(LispWriter& writer); @@ -63,28 +61,33 @@ public: */ void resize(int newwidth, int newheight); + /** Flip the all tile map vertically. The purpose of this is to let + player to play the same level in a different way :) */ + void do_vertical_flip(); + size_t get_width() const { return width; } size_t get_height() const { return height; } + + int get_layer() const + { return layer; } bool is_solid() const { return solid; } - TileId& get_tile_id_at(const Vector& pos); - /// returns tile in row y and column y (of the tilemap) - Tile* get_tile(int x, int y) const; + const Tile* get_tile(int x, int y) const; /// returns tile at position pos (in world coordinates) - Tile* get_tile_at(const Vector& pos) const; + const Tile* get_tile_at(const Vector& pos) const; - void change(int x, int y, unsigned int newtile); + void change(int x, int y, uint32_t newtile); - void change_at(const Vector& pos, unsigned int newtile); + void change_at(const Vector& pos, uint32_t newtile); private: - std::vector tiles; + std::vector tiles; private: TileManager* tilemanager; @@ -92,6 +95,8 @@ private: float speed; int width, height; int layer; + + bool vertical_flip; }; #endif /*SUPERTUX_TILEMAP_H*/