X-Git-Url: https://git.dogcows.com/gitweb?p=chaz%2Fyoink;a=blobdiff_plain;f=src%2FCharacter.hh;h=28e588b627da8ccc0b45b49dc80cbac1b37fc258;hp=2f175ad65d3b7c90aeafaa03a7f6f6de3ba9c5b6;hb=2fdb5f5824826a6c54f5afde8c62eafd24c1a152;hpb=79becf045222f385da5a1b9eb79081f6f5266c86 diff --git a/src/Character.hh b/src/Character.hh index 2f175ad..28e588b 100644 --- a/src/Character.hh +++ b/src/Character.hh @@ -29,29 +29,57 @@ #ifndef _CHARACTER_HH_ #define _CHARACTER_HH_ +#include + +#include +#include +#include +#include +#include +#include + +#include "Animation.hh" +#include "Tilemap.hh" + + + +class Character; +typedef boost::shared_ptr CharacterP; + + /** - * @file Character.hh - * Parent class of animate objects with "personalities." + * Parent class of animate objects with "personalities." This basically + * includes the heroine herself and the bad guys. */ - -class Character : public dc::resource, public dc::drawable +class Character : public Mf::RigidBody2, public Mf::OctreeInsertable { public: - struct exception : public std::runtime_error - { - explicit exception(const std::string& what_arg) : - std::runtime_error(what_arg) {} - }; Character(const std::string& name); + virtual ~Character() {} + + virtual void update(Mf::Scalar t, Mf::Scalar dt); + virtual void draw(Mf::Scalar alpha) const; + + void setZCoord(Mf::Scalar z); + + void addImpulse(Mf::Vector2 impulse); + void addForce(Mf::Vector2 force); + void setPosition(Mf::Vector2 position); - void draw(dc::scalar alpha); + virtual int getOctant(const Mf::Aabb& aabb) const; - dc::tilemap* texture; - dc::animation* anim; + Tilemap tilemap; + Animation animation; + +private: + + mutable Mf::Scalar mZCoord; }; #endif // _CHARACTER_HH_ +/** vim: set ts=4 sw=4 tw=80: *************************************************/ +