X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Fsector.hpp;h=cdc59b6f4d51efb1d229f02c944180f4586da1e4;hb=4587bd9c8fc5cbb20f1e442de76bc06571ab56ba;hp=cced7695220949e50e6f1d1b7021b5851b71c43b;hpb=5c21e01c30deee6285d7c08a226f5265390dc0d7;p=supertux.git diff --git a/src/sector.hpp b/src/sector.hpp index cced76952..cdc59b6f4 100644 --- a/src/sector.hpp +++ b/src/sector.hpp @@ -21,12 +21,15 @@ #include #include +#include #include #include #include "direction.hpp" #include "math/vector.hpp" #include "video/drawing_context.hpp" +#include "script_interface.hpp" +#include "scripting/ssector.hpp" namespace lisp { class Lisp; @@ -48,6 +51,7 @@ class SpawnPoint; class MovingObject; class CollisionHit; class Level; +class Portable; enum MusicType { LEVEL_MUSIC, @@ -59,7 +63,7 @@ enum MusicType { * This class holds a sector (a part of a level) and all the game objects in * the sector */ -class Sector +class Sector : public Scripting::SSector { public: Sector(Level* parent); @@ -106,10 +110,10 @@ public: void play_music(MusicType musictype); MusicType get_music_type(); - + bool add_bullet(const Vector& pos, float xm, Direction dir); bool add_smoke_cloud(const Vector& pos); - + /** get currently activated sector. */ static Sector* current() { return _current; } @@ -130,11 +134,25 @@ public: void collision_tilemap(collision::Constraints* constraints, const Vector& movement, const Rect& dest) const; - /** Checks if at the specified rectangle are gameobjects with STATIC flag set - * (or solid tiles from the tilemap). - * This does not(!) include badguys or players. + /** + * Checks if the specified rectangle is free of (solid) tiles. + * Note that this does not include static objects, e.g. bonus blocks. + */ + bool is_free_of_tiles(const Rect& rect) const; + /** + * Checks if the specified rectangle is free of both + * 1.) solid tiles and + * 2.) MovingObjects in COLGROUP_STATIC. + * Note that this does not include badguys or players. */ - bool is_free_space(const Rect& rect) const; + bool is_free_of_statics(const Rect& rect, const MovingObject* ignore_object = 0) const; + /** + * Checks if the specified rectangle is free of both + * 1.) solid tiles and + * 2.) MovingObjects in COLGROUP_STATIC, COLGROUP_MOVINGSTATIC or COLGROUP_MOVING. + * This includes badguys and players. + */ + bool is_free_of_movingstatics(const Rect& rect, const MovingObject* ignore_object = 0) const; /** * returns a list of players currently in the sector @@ -145,9 +163,34 @@ public: Rect get_active_region(); + /** + * returns the width (in px) of a sector) + */ + float get_width() const; + + /** + * returns the height (in px) of a sector) + */ + float get_height() const; + + /** + * globally changes solid tilemaps' tile ids + */ + void change_solid_tiles(uint32_t old_tile_id, uint32_t new_tile_id); + typedef std::vector GameObjects; typedef std::vector MovingObjects; typedef std::vector SpawnPoints; + typedef std::vector Portables; + + // --- Scripting --- + /** + * get/set color of ambient light + */ + void set_ambient_light(float red, float green, float blue); + float get_ambient_red(); + float get_ambient_green(); + float get_ambient_blue(); private: Level* level; /**< Parent level containing this sector */ @@ -158,12 +201,14 @@ private: void try_expose(GameObject* object); void try_unexpose(GameObject* object); - + void try_expose_me(); + void try_unexpose_me(); + /** Checks for all possible collisions. And calls the collision_handlers, which the collision_objects provide for this case (or not). */ void handle_collisions(); - + /** * Does collision detection between 2 objects and does instant * collision response handling in case of a collision @@ -183,13 +228,13 @@ private: const Vector& movement, const Rect& dest, GameObject& object); void collision_static_constrains(MovingObject& object); - + GameObject* parse_object(const std::string& name, const lisp::Lisp& lisp); void fix_old_tiles(); static Sector* _current; - + std::string name; std::vector bullets; @@ -198,7 +243,7 @@ private: /// container for newly created objects, they'll be added in Sector::update GameObjects gameobjects_new; - + MusicType currentmusic; HSQOBJECT sector_table; @@ -206,14 +251,17 @@ private: typedef std::vector ScriptList; ScriptList scripts; + Color ambient_light; + public: // TODO make this private again /// show collision rectangles of moving objects (for debugging) static bool show_collrects; static bool draw_solids_only; - + GameObjects gameobjects; MovingObjects moving_objects; - SpawnPoints spawnpoints; + SpawnPoints spawnpoints; + Portables portables; std::string music; float gravity; @@ -221,9 +269,8 @@ public: // TODO make this private again // some special objects, where we need direct access // (try to avoid accessing them directly) Player* player; - TileMap* solids; + std::list solid_tilemaps; Camera* camera; }; #endif -