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