… | |
… | |
29 | #ifndef MAP_H |
29 | #ifndef MAP_H |
30 | #define MAP_H |
30 | #define MAP_H |
31 | |
31 | |
32 | #include <tr1/unordered_map> |
32 | #include <tr1/unordered_map> |
33 | |
33 | |
|
|
34 | #include "region.h" |
34 | #include "cfperl.h" |
35 | #include "cfperl.h" |
35 | |
36 | |
36 | /* We set this size - this is to make magic map work properly on |
37 | /* We set this size - this is to make magic map work properly on |
37 | * tiled maps. There is no requirement that this matches the |
38 | * tiled maps. There is no requirement that this matches the |
38 | * tiled maps size - it just seemed like a reasonable value. |
39 | * tiled maps size - it just seemed like a reasonable value. |
… | |
… | |
186 | struct maptile : zero_initialised, attachable |
187 | struct maptile : zero_initialised, attachable |
187 | { |
188 | { |
188 | sint32 ACC (RW, width), ACC (RW, height); /* Width and height of map. */ |
189 | sint32 ACC (RW, width), ACC (RW, height); /* Width and height of map. */ |
189 | struct mapspace *spaces; /* Array of spaces on this map */ |
190 | struct mapspace *spaces; /* Array of spaces on this map */ |
190 | uint8 *regions; /* region index per mapspace, if != 0 */ |
191 | uint8 *regions; /* region index per mapspace, if != 0 */ |
191 | struct region **regionmap; /* index to region */ |
192 | region_ptr *regionmap; /* index to region */ |
192 | |
193 | |
193 | tstamp ACC (RW, last_access); /* last time this map was accessed somehow */ |
194 | tstamp ACC (RW, last_access); /* last time this map was accessed somehow */ |
194 | |
195 | |
195 | shstr ACC (RW, name); /* Name of map as given by its creator */ |
196 | shstr ACC (RW, name); /* Name of map as given by its creator */ |
196 | struct region *ACC (RW, default_region); /* What jurisdiction in the game world this map is ruled by |
197 | region_ptr ACC (RW, default_region); /* What jurisdiction in the game world this map is ruled by |
197 | * points to the struct containing all the properties of |
198 | * points to the struct containing all the properties of |
198 | * the region */ |
199 | * the region */ |
199 | double ACC (RW, reset_time); |
200 | double ACC (RW, reset_time); |
200 | uint32 ACC (RW, reset_timeout); /* How many seconds must elapse before this map |
201 | uint32 ACC (RW, reset_timeout); /* How many seconds must elapse before this map |
201 | * should be reset |
202 | * should be reset |
… | |
… | |
257 | MTH int change_map_light (int change); |
258 | MTH int change_map_light (int change); |
258 | static void change_all_map_light (int change); //PERL |
259 | static void change_all_map_light (int change); //PERL |
259 | MTH void set_darkness_map (); |
260 | MTH void set_darkness_map (); |
260 | MTH int estimate_difficulty () const; |
261 | MTH int estimate_difficulty () const; |
261 | |
262 | |
|
|
263 | MTH void play_sound (faceidx sound, int x, int y) const; |
|
|
264 | |
262 | // set the given flag on all objects in the map |
265 | // set the given flag on all objects in the map |
263 | MTH void set_object_flag (int flag, int value = 1); |
266 | MTH void set_object_flag (int flag, int value = 1); |
264 | |
267 | |
265 | MTH void link_multipart_objects (); |
268 | MTH void link_multipart_objects (); |
266 | MTH void clear_unique_items (); |
269 | MTH void clear_unique_items (); |
… | |
… | |
371 | object::ms () const |
374 | object::ms () const |
372 | { |
375 | { |
373 | return map->at (x, y); |
376 | return map->at (x, y); |
374 | } |
377 | } |
375 | |
378 | |
|
|
379 | inline void |
|
|
380 | object::play_sound (faceidx sound) const |
|
|
381 | { |
|
|
382 | if (map && sound) |
|
|
383 | map->play_sound (sound, x, y); |
|
|
384 | } |
|
|
385 | |
376 | #endif |
386 | #endif |
377 | |
387 | |