X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Fobject%2Fscripted_object.hpp;h=e7d6f9dbffcb30843c506780af4c74ec27d98d9f;hb=04a3157ef478169b5a3fc05dae00ed6ee6a1fae2;hp=5bebd0c95244c1fe38d5ac1fb03ae04b67f5a415;hpb=fe138b9ec292ca9679b43cf5c4555f0193bab25d;p=supertux.git diff --git a/src/object/scripted_object.hpp b/src/object/scripted_object.hpp index 5bebd0c95..e7d6f9dbf 100644 --- a/src/object/scripted_object.hpp +++ b/src/object/scripted_object.hpp @@ -22,24 +22,25 @@ #include #include "physic.hpp" -#include "sprite/sprite.hpp" #include "lisp/lisp.hpp" -#include "moving_object.hpp" +#include "object/moving_sprite.hpp" #include "script_interface.hpp" #include "scripting/scripted_object.hpp" -class ScriptedObject : public MovingObject, public Scripting::ScriptedObject, - public ScriptInterface +class ScriptedObject : public MovingSprite, public UsesPhysic, + public Scripting::ScriptedObject, public ScriptInterface { public: ScriptedObject(const lisp::Lisp& lisp); - virtual ~ScriptedObject(); + virtual ScriptedObject* clone() const { return new ScriptedObject(*this); } virtual void expose(HSQUIRRELVM vm, SQInteger table_idx); virtual void unexpose(HSQUIRRELVM vm, SQInteger table_idx); void update(float elapsed_time); void draw(DrawingContext& context); + + void collision_solid(const CollisionHit& hit); HitResponse collision(GameObject& other, const CollisionHit& hit); // --- Scripting Interface stuff --- @@ -56,6 +57,8 @@ public: float get_velocity_y(); void set_visible(bool visible); bool is_visible(); + void set_solid(bool solid); + bool is_solid(); std::string get_name(); @@ -65,11 +68,7 @@ private: bool physic_enabled; bool visible; bool new_vel_set; - int z_pos; Vector new_vel; - Physic physic; - Sprite* sprite; }; #endif -