-/*
- * 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 battle::Monster;
+using battle::PartyLayout;
+using graphics::Animation;
+using graphics::Sprite;
using geometry::Vector;
+using loader::FieldDescription;
+using loader::Interpreter;
+using loader::TypeDescription;
namespace map {
Entity::Entity()
: follower(0)
, animation(0)
+, sprite(0)
+, partyLayout(0)
+, monsters(0)
+, numMonsters(0)
, orientation(ORIENTATION_NORTH)
-, speed(0) {
+, speed(0)
+, flags(0) {
runner.SetFrameShift(1);
}
void Entity::SetOrientation(Orientation o) {
orientation = o;
UpdateVelocity();
- runner.SetColOffset(orientation);
+ if (CanTurn()) {
+ runner.SetColOffset(orientation);
+ }
}
void Entity::SetSpeed(float s) {
UpdateVelocity();
}
+
void Entity::StartAnimation(app::Application &ctrl) {
runner.Start(ctrl);
}
runner.Stop();
}
+
+void Entity::SetHandsFree() {
+ runner.SetRowOffset(0);
+}
+
+void Entity::SetCarrying() {
+ runner.SetRowOffset(2);
+}
+
+void Entity::SetPushing() {
+ runner.SetRowOffset(4);
+}
+
+
void Entity::AddFollower(Entity *f) {
if (follower) {
follower->AddFollower(f);
void Entity::SetAnimation(const graphics::Animation *a) {
animation = a;
runner.ChangeAnimation(animation);
+ if (!sprite) {
+ sprite = animation->GetSprite();
+ }
}
}
-bool Entity::TileLock(int width, int height) const {
- Vector<int> tilePosition(
- position.X() - (width / 2),
- position.Y());
- return (tilePosition.X() % width == 0) && (tilePosition.Y() % height == 0);
+bool Entity::TileLock(const geometry::Vector<int> &tileSize) const {
+ // TODO: change position to point to the top-left corner of a tile
+ Vector<int> tilePosition(position);
+ return (tilePosition.X() % tileSize.X() == 0) && (tilePosition.Y() % tileSize.Y() == 0);
}
void Entity::Render(SDL_Surface *dest, const Vector<int> &offset) const {
// TODO: configurable sprite offsets
if (runner.Running()) {
- runner.DrawCenter(dest, offset + position);
+ runner.Draw(dest, offset + position + spriteOffset);
} else {
- animation->GetSprite()->DrawCenter(dest, offset + position, orientation);
+ sprite->Draw(dest, offset + position + spriteOffset, CanTurn() ? orientation : 0);
+ }
+}
+
+
+void Entity::CreateTypeDescription() {
+ Entity e;
+
+ 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), 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) {
+ new (data) Entity;
+}
+
+void Entity::Load(void *data) {
+ Entity *entity(reinterpret_cast<Entity *>(data));
+ if (entity->animation) {
+ entity->runner.ChangeAnimation(entity->animation);
+ if (!entity->sprite) {
+ entity->sprite = entity->animation->GetSprite();
+ }
}
}