- changed way badguy removal is handled (ie. with a flag now)
[supertux.git] / src / world.h
1 //  $Id$
2 // 
3 //  SuperTux
4 //  Copyright (C) 2000 Bill Kendrick <bill@newbreedsoftware.com>
5 //  Copyright (C) 2004 Tobias Glaesser <tobi.web@gmx.de>
6 //  Copyright (C) 2004 Ingo Ruhnke <grumbel@gmx.de>
7 //
8 //  This program is free software; you can redistribute it and/or
9 //  modify it under the terms of the GNU General Public License
10 //  as published by the Free Software Foundation; either version 2
11 //  of the License, or (at your option) any later version.
12 //
13 //  This program is distributed in the hope that it will be useful,
14 //  but WITHOUT ANY WARRANTY; without even the implied warranty of
15 //  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16 //  GNU General Public License for more details.
17 // 
18 //  You should have received a copy of the GNU General Public License
19 //  along with this program; if not, write to the Free Software
20 //  Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
21
22 #ifndef SUPERTUX_WORLD_H
23 #define SUPERTUX_WORLD_H
24
25 #include <vector>
26 #include <SDL.h>
27 #include "type.h"
28 #include "scene.h"
29 #include "special.h"
30 #include "badguy.h"
31 #include "particlesystem.h"
32 #include "gameobjs.h"
33
34 class Level;
35
36 /** The World class holds a level and all the game objects (badguys,
37     bouncy distros, etc) that are needed to run a game. */
38 class World
39 {
40 private:
41   typedef std::list<BadGuy*> BadGuys;
42   BadGuys bad_guys;
43   BadGuys bad_guys_to_add;
44   Level* level;
45   Player tux;
46
47   int distro_counter;
48   bool counting_distros;
49   int currentmusic;
50
51   static World* current_;
52 public:
53   std::vector<BouncyDistro> bouncy_distros;
54   std::vector<BrokenBrick>  broken_bricks;
55   std::vector<BouncyBrick>  bouncy_bricks;
56   std::vector<FloatingScore> floating_scores;
57
58   std::vector<Upgrade> upgrades;
59   std::vector<Bullet> bullets;
60   std::vector<ParticleSystem*> particle_systems;
61
62 public:
63   static World* current() { return current_; }
64   static void set_current(World* w) { current_ = w; }
65
66   World(const std::string& filename);
67   World(const std::string& subset, int level_nr);
68   World();
69   ~World();
70   
71   Level*  get_level() { return level; }
72   Player* get_tux() { return &tux; }
73
74   void set_defaults();
75
76   void draw();
77   void action(double frame_ratio);
78
79   void play_music(int musictype);
80   int get_music_type();
81   
82
83   /** Checks for all possible collisions. And calls the
84       collision_handlers, which the collision_objects provide for this
85       case (or not). */
86   void collision_handler();
87   
88   void activate_particle_systems();
89   void activate_bad_guys();
90
91   void add_score(float x, float y, int s);
92   void add_bouncy_distro(float x, float y);
93   void add_broken_brick(Tile* tile, float x, float y);
94   void add_broken_brick_piece(Tile* tile, float x, float y, float xm, float ym);
95   void add_bouncy_brick(float x, float y);
96
97   BadGuy* add_bad_guy(float x, float y, BadGuyKind kind, bool stay_on_platform = false);
98
99   void add_upgrade(float x, float y, Direction dir, UpgradeKind kind);
100   void add_bullet(float x, float y, float xm, Direction dir);
101
102   /** Try to grab the coin at the given coordinates */
103   void trygrabdistro(float x, float y, int bounciness);
104
105   /** Try to break the brick at the given coordinates */
106   void trybreakbrick(float x, float y, bool small);
107
108   /** Try to get the content out of a bonus box, thus emptying it */
109   void tryemptybox(float x, float y, Direction col_side);
110
111   /** Try to bumb a badguy that might we walking above Tux, thus shaking
112       the tile which the badguy is walking on an killing him this way */
113   void trybumpbadguy(float x, float y);
114 };
115
116 /** FIMXE: Workaround for the leveleditor mainly */
117 extern World global_world;
118
119 #endif /*SUPERTUX_WORLD_H*/
120
121 /* Local Variables: */
122 /* mode:c++ */
123 /* End: */
124