X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fmap%2FEntity.cpp;h=6bce2adfde82b28d092cd08a03eae7fd39246f7e;hb=667e1d9c6a78d0b608b518a4e5b5c31bc30e4e89;hp=99295344dbd52127a2f58c6e9f17ed27161d5a2c;hpb=7c43158af1abf38fa896a442cb3c6d8a5bc630e7;p=l2e.git diff --git a/src/map/Entity.cpp b/src/map/Entity.cpp index 9929534..6bce2ad 100644 --- a/src/map/Entity.cpp +++ b/src/map/Entity.cpp @@ -1,16 +1,20 @@ -/* - * Entity.cpp - * - * Created on: Sep 29, 2012 - * Author: holy - */ - #include "Entity.h" +#include "../battle/Monster.h" +#include "../battle/PartyLayout.h" +#include "../graphics/Animation.h" +#include "../graphics/Sprite.h" +#include "../loader/Interpreter.h" #include "../loader/TypeDescription.h" -using geometry::Vector; +using battle::Monster; +using battle::PartyLayout; +using graphics::Animation; +using graphics::Sprite; +using math::Fixed; +using math::Vector; using loader::FieldDescription; +using loader::Interpreter; using loader::TypeDescription; namespace map { @@ -22,6 +26,7 @@ Entity::Entity() , partyLayout(0) , monsters(0) , numMonsters(0) +, direction(ORIENTATION_NORTH) , orientation(ORIENTATION_NORTH) , speed(0) , flags(0) { @@ -31,13 +36,18 @@ Entity::Entity() void Entity::SetOrientation(Orientation o) { orientation = o; - UpdateVelocity(); if (CanTurn()) { - runner.SetColOffset(orientation); + runner.SetColOffset(o); } } -void Entity::SetSpeed(float s) { +void Entity::SetDirection(Orientation o) { + direction = o; + UpdateVelocity(); + SetOrientation(o); +} + +void Entity::SetSpeed(Fixed<8> s) { speed = s; UpdateVelocity(); } @@ -95,45 +105,43 @@ void Entity::SetAnimation(const graphics::Animation *a) { void Entity::UpdateVelocity() { - if (speed == 0.0f) { - velocity = Vector(); + if (speed == 0) { + velocity = Vector >(); return; } - switch (orientation) { + switch (direction) { case ORIENTATION_NORTH: - velocity = Vector(0.0f, -speed); + velocity = Vector >(0, -speed); break; case ORIENTATION_EAST: - velocity = Vector(speed, 0.0f); + velocity = Vector >(speed, 0); break; case ORIENTATION_SOUTH: - velocity = Vector(0.0f, speed); + velocity = Vector >(0, speed); break; case ORIENTATION_WEST: - velocity = Vector(-speed, 0.0f); + velocity = Vector >(-speed, 0); break; } } -bool Entity::TileLock(const geometry::Vector &tileSize) const { - // TODO: change position to point to the top-left corner of a tile - Vector tilePosition(position); - return (tilePosition.X() % tileSize.X() == 0) && (tilePosition.Y() % tileSize.Y() == 0); +bool Entity::TileLock(const math::Vector &tileSize) const { + Vector tilePosition(ToInt(position)); + return tilePosition % tileSize == Vector(); } -void Entity::Update(float deltaT) { +void Entity::Update(Uint32 deltaT) { position += velocity * deltaT; } void Entity::Render(SDL_Surface *dest, const Vector &offset) const { - // TODO: configurable sprite offsets if (runner.Running()) { - runner.Draw(dest, offset + position + spriteOffset); + runner.Draw(dest, offset + ToInt(position) + spriteOffset); } else { - sprite->Draw(dest, offset + position + spriteOffset, CanTurn() ? orientation : 0); + sprite->Draw(dest, offset + ToInt(position) + spriteOffset, CanTurn() ? orientation : 0); } } @@ -141,25 +149,18 @@ void Entity::Render(SDL_Surface *dest, const Vector &offset) const { void Entity::CreateTypeDescription() { Entity e; - int animationId(TypeDescription::GetTypeId("Animation")); - int monsterId(TypeDescription::GetTypeId("Monster")); - int numberId(TypeDescription::GetTypeId("Number")); - int partyLayoutId(TypeDescription::GetTypeId("PartyLayout")); - int spriteId(TypeDescription::GetTypeId("Sprite")); - int vectorId(TypeDescription::GetTypeId("Vector")); - - TypeDescription &td(TypeDescription::CreateOrGet("Entity")); + TypeDescription &td(TypeDescription::Create(TYPE_ID, "Entity")); td.SetConstructor(&Construct); td.SetLoader(&Load); td.SetSize(sizeof(Entity)); - td.AddField("animation", FieldDescription(((char *)&e.animation) - ((char *)&e), animationId).SetReferenced()); - td.AddField("sprite", FieldDescription(((char *)&e.sprite) - ((char *)&e), spriteId).SetReferenced()); - td.AddField("partyLayout", FieldDescription(((char *)&e.partyLayout) - ((char *)&e), partyLayoutId).SetReferenced()); - td.AddField("monsters", FieldDescription(((char *)&e.monsters) - ((char *)&e), monsterId).SetReferenced().SetAggregate()); - td.AddField("spriteOffset", FieldDescription(((char *)&e.spriteOffset) - ((char *)&e), vectorId)); - td.AddField("position", FieldDescription(((char *)&e.tilePosition) - ((char *)&e), vectorId)); - td.AddField("flags", FieldDescription(((char *)&e.flags) - ((char *)&e), numberId)); + td.AddField("animation", FieldDescription(((char *)&e.animation) - ((char *)&e), Animation::TYPE_ID).SetReferenced()); + td.AddField("sprite", FieldDescription(((char *)&e.sprite) - ((char *)&e), Sprite::TYPE_ID).SetReferenced()); + td.AddField("partyLayout", FieldDescription(((char *)&e.partyLayout) - ((char *)&e), PartyLayout::TYPE_ID).SetReferenced()); + td.AddField("monsters", FieldDescription(((char *)&e.monsters) - ((char *)&e), Monster::TYPE_ID).SetReferenced().SetAggregate()); + td.AddField("spriteOffset", FieldDescription(((char *)&e.spriteOffset) - ((char *)&e), Interpreter::VECTOR_ID)); + td.AddField("position", FieldDescription(((char *)&e.tilePosition) - ((char *)&e), Interpreter::VECTOR_ID)); + td.AddField("flags", FieldDescription(((char *)&e.flags) - ((char *)&e), Interpreter::NUMBER_ID)); } void Entity::Construct(void *data) {