X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Ftile.cpp;h=ac98f0df4e8be7a1118a1a37091d012d59f85587;hb=1735ae9ea3b0d48f39f84fcefad5ec74275d4943;hp=fa0b8349da484766268850d570cfc1be77f614fb;hpb=a113d3bd1feddd510e3b2852b0d42522735eee40;p=supertux.git diff --git a/src/tile.cpp b/src/tile.cpp index fa0b8349d..ac98f0df4 100644 --- a/src/tile.cpp +++ b/src/tile.cpp @@ -20,13 +20,14 @@ // 02111-1307, USA. #include -#include -#include +#include +#include #include #include #include "lisp/lisp.hpp" #include "tile.hpp" +#include "tile_set.hpp" #include "resources.hpp" #include "timer.hpp" #include "math/vector.hpp" @@ -34,13 +35,13 @@ #include "log.hpp" -Tile::Tile() - : id(0), attributes(0), data(0), anim_fps(1) +Tile::Tile(const TileSet *new_tileset) + : tileset(new_tileset), attributes(0), data(0), anim_fps(1) { } -Tile::Tile(unsigned int id, Uint32 attributes, const ImageSpec& imagespec) - : id(id), attributes(attributes), data(0), anim_fps(1) +Tile::Tile(const TileSet *new_tileset, Uint32 attributes, const ImageSpec& imagespec) + : tileset(new_tileset), attributes(attributes), data(0), anim_fps(1) { imagespecs.push_back(imagespec); } @@ -53,9 +54,10 @@ Tile::~Tile() } } -void +uint32_t Tile::parse(const lisp::Lisp& reader) { + uint32_t id; if(!reader.get("id", id)) { throw std::runtime_error("Missing tile-id."); } @@ -73,6 +75,8 @@ Tile::parse(const lisp::Lisp& reader) attributes |= WATER; if(reader.get("hurts", value) && value) attributes |= HURTS; + if(reader.get("fire", value) && value) + attributes |= FIRE; if(reader.get("fullbox", value) && value) attributes |= FULLBOX; if(reader.get("coin", value) && value) @@ -101,6 +105,8 @@ Tile::parse(const lisp::Lisp& reader) const lisp::Lisp* images = reader.get_lisp("images"); if(images) parse_images(*images); + + return id; } void @@ -114,7 +120,8 @@ Tile::parse_images(const lisp::Lisp& images_lisp) cur->get(file); imagespecs.push_back(ImageSpec(file, Rect(0, 0, 0, 0))); } else if(cur->get_type() == lisp::Lisp::TYPE_CONS && - cur->get_car()->get_type() == lisp::Lisp::TYPE_SYMBOL) { + cur->get_car()->get_type() == lisp::Lisp::TYPE_SYMBOL && + cur->get_car()->get_symbol() == "region") { const lisp::Lisp* ptr = cur->get_cdr(); std::string file; @@ -135,14 +142,16 @@ Tile::parse_images(const lisp::Lisp& images_lisp) } void -Tile::load_images(const std::string& tilesetpath) +Tile::load_images() { + const std::string& tiles_path = tileset->tiles_path; + assert(images.size() == 0); for(std::vector::iterator i = imagespecs.begin(); i != imagespecs.end(); ++i) { const ImageSpec& spec = *i; Surface* surface; - std::string file = tilesetpath + spec.file; + std::string file = tiles_path + spec.file; if(spec.rect.get_width() <= 0) { surface = new Surface(file); } else {