X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fmap%2FEntity.h;h=13044880121569cfa54c1ef4f7ce34dbc6a64457;hb=7011e3c622be7d4f24c0166a1ad5aeb4f8c5f851;hp=be3197d9da4010fa6e9fc2100171c3e3d44a2f62;hpb=a3ba4dc677ad7c92eeb78b20b642241563605c9d;p=l2e.git diff --git a/src/map/Entity.h b/src/map/Entity.h index be3197d..1304488 100644 --- a/src/map/Entity.h +++ b/src/map/Entity.h @@ -1,10 +1,17 @@ #ifndef MAP_ENTITY_H_ #define MAP_ENTITY_H_ -#include "../battle/fwd.h" -#include "../battle/Monster.h" +namespace app { + class Application; + class State; +} +namespace battle { + class Monster; + class PartyLayout; +} + +#include "../math/Fixed.h" #include "../math/Vector.h" -#include "../graphics/fwd.h" #include "../graphics/Animation.h" #include @@ -38,12 +45,12 @@ public: public: /// Pixel resolved position of the entity's top left corner on the map. - math::Vector &Position() { return position; } - const math::Vector &Position() const { return position; } + math::Vector > &Position() { return position; } + const math::Vector > &Position() const { return position; } /// Velocity of the entity in pixels per second. - math::Vector &Velocity() { return velocity; } - const math::Vector &Velocity() const { return velocity; } + math::Vector > &Velocity() { return velocity; } + const math::Vector > &Velocity() const { return velocity; } /// Offset of the entity's sprite's to left corner relative to Position(). math::Vector &SpriteOffset() { return spriteOffset; } @@ -79,7 +86,7 @@ public: Orientation GetOrientation() const { return orientation; } /// Set the entity's speed in pixels per second. /// This speed is then combined with the orientation to form a velocity. - void SetSpeed(float); + void SetSpeed(math::Fixed<8>); /// Change to a natural, relaxed animation state (row offset 0). void SetHandsFree(); @@ -127,7 +134,7 @@ public: bool TileLock(const math::Vector &tileSize) const; /// Integrate this entity's physical properties over given time interval. - void Update(float deltaT); + void Update(Uint32 deltaT); void Render(SDL_Surface *, const math::Vector &offset) const; @@ -148,14 +155,14 @@ private: graphics::AnimationRunner runner; math::Vector spriteOffset; math::Vector tilePosition; - math::Vector position; - math::Vector velocity; + math::Vector > position; + math::Vector > velocity; Orientation orientation; - float speed; + math::Fixed<8> speed; int flags; }; } -#endif /* MAP_ENTITY_H_ */ +#endif