#ifndef SUPERTUX_GAMEOBJS_H
#define SUPERTUX_GAMEOBJS_H
-#include "type.h"
-#include "texture.h"
-#include "timer.h"
+#include "special/base.h"
+#include "video/surface.h"
+#include "special/timer.h"
#include "scene.h"
-#include "physic.h"
+#include "math/physic.h"
#include "collision.h"
-#include "game_object.h"
-#include "drawable.h"
-#include "moving_object.h"
-#include "lispwriter.h"
+#include "special/game_object.h"
+#include "special/moving_object.h"
+#include "serializable.h"
+#include "utils/lispwriter.h"
/* Bounciness of distros: */
#define NO_BOUNCE 0
#define BOUNCE 1
-class BouncyDistro : public GameObject, public Drawable
+namespace SuperTux {
+class Sprite;
+}
+
+struct TileId;
+
+class BouncyDistro : public GameObject
{
public:
- BouncyDistro(DisplayManager& displaymanager, const Vector& pos);
+ BouncyDistro(const Vector& pos);
virtual void action(float elapsed_time);
- virtual void draw(Camera& viewport, int layer);
+ virtual void draw(DrawingContext& context);
private:
Vector position;
class Tile;
-class BrokenBrick : public GameObject, public Drawable
+class BrokenBrick : public GameObject
{
public:
- BrokenBrick(DisplayManager& displaymanager, Tile* tile,
- const Vector& pos, const Vector& movement);
+ BrokenBrick(Tile* tile, const Vector& pos, const Vector& movement);
virtual void action(float elapsed_time);
- virtual void draw(Camera& viewport, int layer);
+ virtual void draw(DrawingContext& context);
private:
Timer timer;
Vector movement;
};
-class BouncyBrick : public GameObject, public Drawable
+class BouncyBrick : public GameObject
{
public:
- BouncyBrick(DisplayManager& displaymanager, const Vector& pos);
+ BouncyBrick(const Vector& pos);
virtual void action(float elapsed_time);
- virtual void draw(Camera& viewport, int layer);
+ virtual void draw(DrawingContext& context);
private:
Vector position;
float offset;
float offset_m;
- int shape;
+ TileId& shape;
};
-class FloatingScore : public GameObject, public Drawable
+class FloatingScore : public GameObject
{
public:
- FloatingScore(DisplayManager& displaymanager, const Vector& pos, int s);
+ FloatingScore(const Vector& pos, int s);
virtual void action(float elapsed_time);
- virtual void draw(Camera& viewport, int layer);
+ virtual void draw(DrawingContext& context);
private:
Vector position;
Timer timer;
};
-class Trampoline : public MovingObject, public Drawable, public Serializable
+extern Sprite *img_trampoline;
+
+class Trampoline : public MovingObject, public Serializable
{
public:
- Trampoline(DisplayManager& displaymanager, LispReader& reader);
+ Trampoline(LispReader& reader);
+ Trampoline(float x, float y);
virtual void write(LispWriter& writer);
virtual void action(float frame_ratio);
- virtual void draw(Camera& viewport, int layer);
+ virtual void draw(DrawingContext& context);
virtual void collision(const MovingObject& other, int);
void collision(void *p_c_object, int c_object, CollisionType type);
unsigned int frame;
};
-class FlyingPlatform : public MovingObject, public Drawable, public Serializable
+extern Sprite *img_flying_platform;
+
+class FlyingPlatform : public MovingObject, public Serializable
{
public:
- FlyingPlatform(DisplayManager& displaymanager, LispReader& reader);
+ FlyingPlatform(LispReader& reader);
+ FlyingPlatform(int x, int y);
virtual void write(LispWriter& writer);
virtual void action(float frame_ratio);
- virtual void draw(Camera& viewport, int layer);
+ virtual void draw(DrawingContext& context);
virtual void collision(const MovingObject& other, int);
void collision(void *p_c_object, int c_object, CollisionType type);
unsigned int frame;
};
+extern Sprite *img_smoke_cloud;
+
+class SmokeCloud : public GameObject
+{
+public:
+ SmokeCloud(const Vector& pos);
+
+ virtual void action(float elapsed_time);
+ virtual void draw(DrawingContext& context);
+
+private:
+ Timer timer;
+ Vector position;
+};
+
void load_object_gfx();
#endif