4 // Copyright (C) 2004 Tobias Glaesser <tobi.web@gmx.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
25 #include "video/surface.hpp"
26 #include "math/rect.hpp"
27 #include "lisp/lisp.hpp"
37 /// bitset for tile attributes
39 /** solid tile that is indestructable by Tux */
41 /** uni-directional solid tile */
43 /** a brick that can be destroyed by jumping under it */
45 /** an ice brick that makes tux sliding more than usual */
47 /** a water tile in which tux starts to swim */
49 /** a tile that hurts the player if he touches it */
51 /** Bonusbox, content is stored in \a data */
55 /** the level should be finished when touching a goaltile.
56 * if data is 0 then the endsequence should be triggered, if data is 1
57 * then we can finish the level instantly.
66 WORLDMAP_NORTH = 0x0001,
67 WORLDMAP_SOUTH = 0x0002,
68 WORLDMAP_EAST = 0x0004,
69 WORLDMAP_WEST = 0x0008,
71 WORLDMAP_STOP = 0x0010
75 ImageSpec(const std::string& newfile, const Rect& newrect)
76 : file(newfile), rect(newrect)
86 std::vector<ImageSpec> imagespecs;
87 std::vector<Surface*> images;
89 std::string editor_imagefile;
90 Surface* editor_image;
92 /** tile attributes */
95 /** General purpose data attached to a tile (content of a box, type of coin)*/
103 /** Draw a tile on the screen */
104 void draw(DrawingContext& context, const Vector& pos, int layer) const;
106 Surface* get_editor_image() const;
108 unsigned int getID() const
111 Uint32 getAttributes() const
112 { return attributes; }
117 /// returns the width of the tile in pixels
122 return (int) images[0]->get_width();
125 /// returns the height of the tiles in pixels
126 int getHeight() const
130 return (int) images[0]->get_height();
134 friend class TileManager;
136 Tile(unsigned int id, Uint32 attributes, const ImageSpec& imagespec);
138 void load_images(const std::string& tilesetpath);
140 /// parses the tile and returns it's id number
141 void parse(const lisp::Lisp& reader);
142 void parse_images(const lisp::Lisp& cur);