X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fmap%2FArea.cpp;h=1b9488a01120d045e2eddbeb0df94e402c0797a8;hb=2ccc2369d32fb680a3047519d79c17de34c4e10a;hp=9c066d646f021a0b8d0d644bb6806fbb5f98622d;hpb=ed792d6d00d822384d79d049e644e372f7c3b4cd;p=l2e.git diff --git a/src/map/Area.cpp b/src/map/Area.cpp index 9c066d6..1b9488a 100644 --- a/src/map/Area.cpp +++ b/src/map/Area.cpp @@ -9,22 +9,35 @@ #include "Tile.h" #include "../graphics/Sprite.h" +#include "../loader/TypeDescription.h" #include "../sdl/utility.h" #include using geometry::Vector; +using loader::FieldDescription; +using loader::TypeDescription; namespace map { Area::Area() -: tiles(0) +: battlebg(0) +, tiles(0) , numTiles(0) , width(0) { } +Tile *Area::TileAt(const geometry::Vector &offset) { + int tileIndex(offset.Y() * width + offset.X()); + if (tileIndex < numTiles) { + return tiles +tileIndex; + } else { + return 0; + } +} + const Tile *Area::TileAt(const geometry::Vector &offset) const { int tileIndex(offset.Y() * width + offset.X()); if (tileIndex < numTiles) { @@ -76,4 +89,25 @@ void Area::RenderDebug(SDL_Surface *dest, const graphics::Sprite *tileset, const } } + +void Area::CreateTypeDescription() { + Area a; + + int imageId(TypeDescription::GetTypeId("Image")); + int numberId(TypeDescription::GetTypeId("Number")); + int tileId(TypeDescription::GetTypeId("Tile")); + + TypeDescription &td(TypeDescription::CreateOrGet("Area")); + td.SetConstructor(&Construct); + td.SetSize(sizeof(Area)); + + td.AddField("battlebg", FieldDescription(((char *)&a.battlebg) - ((char *)&a), imageId).SetReferenced()); + td.AddField("tiles", FieldDescription(((char *)&a.tiles) - ((char *)&a), tileId).SetReferenced().SetAggregate()); + td.AddField("width", FieldDescription(((char *)&a.width) - ((char *)&a), numberId)); +} + +void Area::Construct(void *data) { + new (data) Area; +} + }