X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Fobject%2Fscripted_object.cpp;h=65dffb49e45ee59e57f49e4f6e305b1be81a1887;hb=ab9eab4c870195c2b60ce76b77044c35b31e8806;hp=928b3504dc75bc3c66b0b0c6e617143c50ef2fdc;hpb=f3e5e57c9996168a4889ae8e195be25f8b7e629b;p=supertux.git diff --git a/src/object/scripted_object.cpp b/src/object/scripted_object.cpp index 928b3504d..65dffb49e 100644 --- a/src/object/scripted_object.cpp +++ b/src/object/scripted_object.cpp @@ -1,3 +1,21 @@ +// $Id$ +// +// SuperTux +// Copyright (C) 2006 Matthias Braun +// +// This program is free software; you can redistribute it and/or +// modify it under the terms of the GNU General Public License +// as published by the Free Software Foundation; either version 2 +// of the License, or (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program; if not, write to the Free Software +// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. #include #include @@ -5,28 +23,20 @@ #include "scripted_object.hpp" #include "video/drawing_context.hpp" -#include "sprite/sprite_manager.hpp" -#include "scripting/wrapper_util.hpp" +#include "scripting/squirrel_util.hpp" #include "resources.hpp" #include "object_factory.hpp" #include "math/vector.hpp" ScriptedObject::ScriptedObject(const lisp::Lisp& lisp) - : solid(true), physic_enabled(true), visible(true), new_vel_set(false), - layer(LAYER_OBJECTS) + : MovingSprite(lisp, LAYER_OBJECTS, COLGROUP_MOVING), + solid(true), physic_enabled(true), visible(true), new_vel_set(false) { lisp.get("name", name); if(name == "") throw std::runtime_error("Scripted object must have a name specified"); - - std::string spritename; - lisp.get("sprite", spritename); - if(spritename == "") - throw std::runtime_error("Scripted object must have a sprite name specified"); - sprite = sprite_manager->create(spritename); - - lisp.get("x", bbox.p1.x); - lisp.get("y", bbox.p1.y); + + // FIXME: do we need this? bbox is already set via .sprite file float width = sprite->get_width(); float height = sprite->get_height(); lisp.get("width", width); @@ -36,26 +46,29 @@ ScriptedObject::ScriptedObject(const lisp::Lisp& lisp) lisp.get("solid", solid); lisp.get("physic-enabled", physic_enabled); lisp.get("visible", visible); - lisp.get("layer", layer); - if(solid) - flags |= FLAG_SOLID; -} - -ScriptedObject::~ScriptedObject() -{ - delete sprite; + lisp.get("z-pos", layer); + if( solid ){ + if( physic_enabled ){ + set_group( COLGROUP_MOVING ); + } else { + set_group( COLGROUP_STATIC ); + } + } else { + set_group( COLGROUP_DISABLED ); + } } void -ScriptedObject::expose(HSQUIRRELVM vm, int table_idx) +ScriptedObject::expose(HSQUIRRELVM vm, SQInteger table_idx) { - Scripting::ScriptedObject* interface = static_cast (this); - expose_object(vm, table_idx, interface, name, false); + if (name.empty()) return; + expose_object(vm, table_idx, dynamic_cast(this), name, false); } void -ScriptedObject::unexpose(HSQUIRRELVM vm, int table_idx) +ScriptedObject::unexpose(HSQUIRRELVM vm, SQInteger table_idx) { + if (name.empty()) return; Scripting::unexpose_object(vm, table_idx, name); } @@ -68,7 +81,9 @@ ScriptedObject::move(float x, float y) void ScriptedObject::set_pos(float x, float y) { + printf("SetPos: %f %f\n", x, y); bbox.set_pos(Vector(x, y)); + physic.reset(); } float @@ -115,6 +130,28 @@ ScriptedObject::is_visible() } void +ScriptedObject::set_solid(bool solid) +{ + this->solid = solid; + if( solid ){ + if( physic_enabled ){ + set_group( COLGROUP_MOVING ); + } else { + set_group( COLGROUP_STATIC ); + } + } else { + set_group( COLGROUP_DISABLED ); + } +} + +bool +ScriptedObject::is_solid() +{ + return solid; +} + + +void ScriptedObject::set_action(const std::string& animation) { sprite->set_action(animation); @@ -123,7 +160,7 @@ ScriptedObject::set_action(const std::string& animation) std::string ScriptedObject::get_action() { - return sprite->get_action_name(); + return sprite->get_action(); } std::string @@ -154,30 +191,27 @@ ScriptedObject::draw(DrawingContext& context) sprite->draw(context, get_pos(), layer); } -HitResponse -ScriptedObject::collision(GameObject& other, const CollisionHit& hit) +void +ScriptedObject::collision_solid(const CollisionHit& hit) { if(!physic_enabled) - return FORCE_MOVE; - - if(!(other.get_flags() & FLAG_SOLID)) - return FORCE_MOVE; + return; - if(other.get_flags() & FLAG_SOLID) { - if(hit.normal.y < 0) { // landed on floor - if(physic.get_velocity_y() < 0) - physic.set_velocity_y(0); - } else if(hit.normal.y > 0) { // bumped against roof - physic.set_velocity_y(.1); - } + if(hit.bottom) { + if(physic.get_velocity_y() > 0) + physic.set_velocity_y(0); + } else if(hit.top) { + physic.set_velocity_y(.1); + } - if(fabsf(hit.normal.x) > .9) { // hit on side? - physic.set_velocity_x(0); - } - - return CONTINUE; + if(hit.left || hit.right) { + physic.set_velocity_x(0); } +} +HitResponse +ScriptedObject::collision(GameObject& , const CollisionHit& ) +{ return FORCE_MOVE; }