X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fmap%2FArea.h;h=68f376b42ee120689e83e895a5e22db36b59ebd5;hb=4309d259becd96ead792678257e910c03a6b4a3d;hp=e2b6a1ede7a0a0dcbde2c8502bfd8df3b4180a41;hpb=be3b4e75c82b6e9d2b5c4300138d490ec1a4932a;p=l2e.git diff --git a/src/map/Area.h b/src/map/Area.h index e2b6a1e..68f376b 100644 --- a/src/map/Area.h +++ b/src/map/Area.h @@ -1,42 +1,59 @@ -/* - * Area.h - * - * Created on: Sep 26, 2012 - * Author: holy - */ - #ifndef MAP_AREA_H_ #define MAP_AREA_H_ -#include "fwd.h" -#include "../geometry/Vector.h" -#include "../graphics/Sprite.h" +namespace graphics { + class Sprite; +} +namespace map { + class Tile; +} + +#include "../math/Vector.h" #include namespace map { +/// Defines a rectangular section of a map. +/// Tiles are rendered ltr with a row break each width tiles. +/// Missing tiles in the last row are possible but don't fool yourself. class Area { +public: + static const int TYPE_ID = 601; + public: Area(); ~Area() { } public: + /// Get the width in tiles. int Width() const { return width; } + /// Get the height in tiles. int Height() const { return numTiles / width + (numTiles % width ? 1 : 0); } - geometry::Vector Size() const { return geometry::Vector(Width(), Height()); } - const Tile &TileAt(const geometry::Vector &) const; + /// Get the size in tiles. + math::Vector Size() const { return math::Vector(Width(), Height()); } + /// Get a tile by tile coordinates (not pixel coordinates!). + Tile *TileAt(const math::Vector &); + const Tile *TileAt(const math::Vector &) const; + + /// Get the default battle background for this area. + SDL_Surface *BattleBackground() { return battlebg; } + + void Render(SDL_Surface *dest, const graphics::Sprite *tileset, const math::Vector &offset) const; + void RenderDebug(SDL_Surface *dest, const graphics::Sprite *tileset, const math::Vector &offset) const; - void Render(SDL_Surface *dest, const graphics::Sprite *tileset, const geometry::Vector &offset) const; + static void CreateTypeDescription(); + static void Construct(void *); // temporary setters public: - void SetTiles(const Tile *t, int num) { tiles = t; numTiles = num; } + void SetTiles(Tile *t, int num) { tiles = t; numTiles = num; } void SetWidth(int w) { width = w; } private: - const Tile *tiles; + SDL_Surface *battlebg; + Tile *tiles; int numTiles; int width; @@ -44,4 +61,4 @@ private: } -#endif /* MAP_AREA_H_ */ +#endif