3 // SuperTux - A Jump'n Run
4 // Copyright (C) 2004 Matthias Braun <matze@braunis.de
6 // This program is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU General Public License
8 // as published by the Free Software Foundation; either version 2
9 // of the License, or (at your option) any later version.
11 // This program is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 // GNU General Public License for more details.
16 // You should have received a copy of the GNU General Public License
17 // along with this program; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
20 #ifndef SUPERTUX_TILEMAP_H
21 #define SUPERTUX_TILEMAP_H
25 #include "special/game_object.h"
26 #include "serializable.h"
27 #include "math/vector.h"
29 using namespace SuperTux;
41 TileId() : id(0), hidden(0) {}
42 explicit TileId(unsigned int i, bool hidden_ = false) : id(i), hidden(hidden_) {}
49 * This class is reponsible for drawing the level tiles
51 class TileMap : public GameObject, public Serializable
55 TileMap(LispReader& reader);
56 TileMap(int layer_, bool solid_, size_t width_, size_t height_);
59 virtual void write(LispWriter& writer);
61 virtual void action(float elapsed_time);
62 virtual void draw(DrawingContext& context);
64 void set(int width, int height, const std::vector<unsigned int>& vec,
65 int layer, bool solid);
67 /** resizes the tilemap to a new width and height (tries to not destroy the
70 void resize(int newwidth, int newheight);
72 /** Flip the all tile map vertically. The purpose of this is to let
73 player to play the same level in a different way :) */
74 void do_vertical_flip();
76 size_t get_width() const
79 size_t get_height() const
88 TileId& get_tile_id_at(const Vector& pos);
90 /// returns tile in row y and column y (of the tilemap)
91 Tile* get_tile(int x, int y) const;
92 /// returns tile at position pos (in world coordinates)
93 Tile* get_tile_at(const Vector& pos) const;
95 void change(int x, int y, unsigned int newtile);
97 void change_at(const Vector& pos, unsigned int newtile);
100 std::vector<TileId> tiles;
103 TileManager* tilemanager;
112 #endif /*SUPERTUX_TILEMAP_H*/