X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Fsector.h;h=464a64f9cb4cda772df6e9220b8fc49eeae774c5;hb=1d16dc1efae67a26d41f302e9681e567492327c5;hp=5fb49f6efbf776375876369f7fc497907ace9884;hpb=c43ea9b0d5372718888138ea2cc4abcd5acb5299;p=supertux.git diff --git a/src/sector.h b/src/sector.h index 5fb49f6ef..464a64f9c 100644 --- a/src/sector.h +++ b/src/sector.h @@ -23,10 +23,10 @@ #include #include +#include "direction.h" #include "math/vector.h" #include "audio/musicref.h" #include "video/drawing_context.h" -#include "defines.h" using namespace SuperTux; @@ -46,8 +46,9 @@ class TileMap; class Bullet; class CollisionGrid; -struct SpawnPoint +class SpawnPoint { +public: std::string name; Vector pos; }; @@ -68,9 +69,8 @@ public: void write(lisp::Writer& writer); /// activates this sector (change music, intialize player class, ...) - void activate(const std::string& spawnpoint = "main"); - /// get best spawn point - Vector get_best_spawn_point(Vector pos); + void activate(const std::string& spawnpoint); + void activate(const Vector& player_pos); void action(float elapsed_time); void update_game_objects(); @@ -100,7 +100,7 @@ public: bool add_smoke_cloud(const Vector& pos); void add_floating_text(const Vector& pos, const std::string& text); - /** @evil@ but can#t always be avoided in current design... */ + /** @evil@ but can't always be avoided in current design... */ static Sector* current() { return _current; } @@ -138,6 +138,10 @@ private: public: // TODO make this private again typedef std::vector GameObjects; GameObjects gameobjects; + typedef std::vector SpawnPoints; + SpawnPoints spawnpoints; + + Rectangle get_active_region(); private: void fix_old_tiles(); @@ -145,9 +149,6 @@ private: /// container for newly created objects, they'll be added in Sector::action GameObjects gameobjects_new; - typedef std::vector SpawnPoints; - SpawnPoints spawnpoints; - int currentmusic; CollisionGrid* grid;