+void Map::RenderDebug(SDL_Surface *dest, const Vector<int> &inOffset) const {
+ // TODO: skip invisible areas
+ for (int i(0); i < numAreas; ++i) {
+ const Area &area(areas[i]);
+ Vector<int> offset(inOffset + Vector<int>::FromIndex(i, width) * area.Size() * tileset->Size());
+ area.RenderDebug(dest, tileset, offset);
+ }
+ for (int i(0); i < numTriggers; ++i) {
+ Vector<int> offset((triggers[i].TilePosition() * tileset->Size()) + inOffset);
+ switch (triggers[i].GetType()) {
+ case Trigger::TYPE_NORTH:
+ sdl::HorizontalLine(dest, offset + (tileset->Size() / 4), tileset->Width() / 2, SDL_MapRGB(dest->format, 0x00, 0xFF, 0xFF));
+ break;
+ case Trigger::TYPE_EAST:
+ sdl::VerticalLine(dest, offset + Vector<int>(tileset->Width() * 3 / 4, tileset->Height() / 4), tileset->Height() / 2, SDL_MapRGB(dest->format, 0x00, 0xFF, 0xFF));
+ break;
+ case Trigger::TYPE_SOUTH:
+ sdl::HorizontalLine(dest, offset + Vector<int>(tileset->Width() / 4, tileset->Height() * 3 / 4), tileset->Width() / 2, SDL_MapRGB(dest->format, 0x00, 0xFF, 0xFF));
+ break;
+ case Trigger::TYPE_WEST:
+ sdl::VerticalLine(dest, offset + (tileset->Size() / 4), tileset->Width() / 2, SDL_MapRGB(dest->format, 0x00, 0xFF, 0xFF));
+ break;
+ case Trigger::TYPE_CONTACT: {
+ SDL_Rect destRect;
+ destRect.x = offset.X() + (tileset->Width() / 4);
+ destRect.y = offset.Y() + (tileset->Height() / 4);
+ destRect.w = tileset->Width() / 2;
+ destRect.h = tileset->Height() / 2;
+ SDL_FillRect(dest, &destRect, SDL_MapRGB(dest->format, 0x00, 0xFF, 0xFF));
+ }
+ break;
+ }
+ }
+}
+
+
+void Map::CreateTypeDescription() {
+ Map m;
+
+ TypeDescription &td(TypeDescription::Create(TYPE_ID, "Map"));
+ td.SetConstructor(&Construct);
+ td.SetSize(sizeof(Map));
+
+ td.AddField("tileset", FieldDescription(((char *)&m.tileset) - ((char *)&m), Sprite::TYPE_ID).SetReferenced());
+ td.AddField("battlebg", FieldDescription(((char *)&m.battlebg) - ((char *)&m), Interpreter::IMAGE_ID).SetReferenced());
+ td.AddField("areas", FieldDescription(((char *)&m.areas) - ((char *)&m), Area::TYPE_ID).SetAggregate());
+ td.AddField("triggers", FieldDescription(((char *)&m.triggers) - ((char *)&m), Trigger::TYPE_ID).SetAggregate());
+ td.AddField("entities", FieldDescription(((char *)&m.entities) - ((char *)&m), Entity::TYPE_ID).SetAggregate());
+ td.AddField("width", FieldDescription(((char *)&m.width) - ((char *)&m), Interpreter::NUMBER_ID));
+}
+
+void Map::Construct(void *data) {
+ new (data) Map;
+}
+