summaryrefslogtreecommitdiff
path: root/src/being.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/being.cpp')
-rw-r--r--src/being.cpp123
1 files changed, 50 insertions, 73 deletions
diff --git a/src/being.cpp b/src/being.cpp
index 749dcce0..7bd1ad2d 100644
--- a/src/being.cpp
+++ b/src/being.cpp
@@ -25,8 +25,6 @@
#include <sstream>
-#include <guichan/imagefont.hpp>
-
#include "game.h"
#include "graphics.h"
#include "log.h"
@@ -363,16 +361,13 @@ Being::logic()
}
}
- if (getType() == MONSTER)
+ if (getType() == MONSTER && action != STAND)
{
- if (action != STAND)
- {
- mFrame = (get_elapsed_time(walk_time) * 4) / mWalkSpeed;
+ mFrame = (get_elapsed_time(walk_time) * 4) / mWalkSpeed;
- if (mFrame >= 4 && action != MONSTER_DEAD)
- {
- nextStep();
- }
+ if (mFrame >= 4 && action != MONSTER_DEAD)
+ {
+ nextStep();
}
}
@@ -418,8 +413,8 @@ Being::drawSpeech(Graphics *graphics, Sint32 offsetX, Sint32 offsetY)
}
int textY = (getType() == PLAYER) ? 70 : 32;
- int dt = get_elapsed_time(damage_time);
- float a = (dt > 1500) ? 1.0 - (dt - 1500) / 1500.0 : 1.0;
+ int ft = get_elapsed_time(damage_time) - 1500;
+ float a = (ft > 0) ? 1.0 - ft / 1500.0 : 1.0;
graphics->setColor(gcn::Color(255, 255, 255, (int)(255 * a)));
graphics->drawText(damage,
@@ -485,23 +480,22 @@ void Being::setWeaponById(Uint16 weapon)
int
Being::getXOffset() const
{
- int offset = 0;
+ // Only beings walking to the left or the right have an x offset
+ if (action != WALK || direction == NORTH || direction == SOUTH) {
+ return 0;
+ }
- if (action == WALK)
- {
- if (direction != NORTH && direction != SOUTH)
- {
- offset = (get_elapsed_time(walk_time) * 32) / mWalkSpeed;
- if (offset > 32) offset = 32;
+ int offset = (get_elapsed_time(walk_time) * 32) / mWalkSpeed;
- if (direction == WEST || direction == NW || direction == SW) {
- offset = -offset;
- offset += 32;
- }
- else {
- offset -= 32;
- }
- }
+ // We calculate the offset _from_ the _target_ location
+ offset -= 32;
+ if (offset > 0) {
+ offset = 0;
+ }
+
+ // Going to the right? Invert the offset.
+ if (direction == WEST || direction == NW || direction == SW) {
+ offset = -offset;
}
return offset;
@@ -510,23 +504,21 @@ Being::getXOffset() const
int
Being::getYOffset() const
{
- int offset = 0;
+ // Only beings walking up or down have an y offset
+ if (action != WALK || direction == EAST || direction == WEST) {
+ return 0;
+ }
- if (action == WALK)
- {
- if (direction != EAST && direction != WEST)
- {
- offset = (get_elapsed_time(walk_time) * 32) / mWalkSpeed;
- if (offset > 32) offset = 32;
+ int offset = (get_elapsed_time(walk_time) * 32) / mWalkSpeed;
- if (direction == NORTH || direction == NW || direction == NE) {
- offset = -offset;
- offset += 32;
- }
- else {
- offset -= 32;
- }
- }
+ // We calculate the offset _from_ the _target_ location
+ offset -= 32;
+ if (offset > 0) {
+ offset = 0;
+ }
+
+ if (direction == NORTH || direction == NW || direction == NE) {
+ offset = -offset;
}
return offset;
@@ -543,13 +535,13 @@ Being::draw(Graphics *graphics, int offsetX, int offsetY)
switch (getType())
{
case PLAYER:
- if (action == SIT || action == DEAD)
+ frame = action;
+
+ if (action != SIT && action != DEAD)
{
- frame = 0;
+ frame += mFrame;
}
- frame = mFrame + action;
-
if (action == ATTACK && getWeapon() > 0)
{
frame += 4 * (getWeapon() - 1);
@@ -581,6 +573,12 @@ Being::draw(Graphics *graphics, int offsetX, int offsetY)
graphics->drawImage(emotionset->spriteset[emotion - 1],
px + 3, py - 90);
}
+
+ // Draw player name
+ if (this != player_node) {
+ graphics->setFont(speechFont);
+ graphics->drawText(mName, px + 15, py + 30, gcn::Graphics::CENTER);
+ }
break;
case NPC:
@@ -593,37 +591,16 @@ Being::draw(Graphics *graphics, int offsetX, int offsetY)
mFrame = 3;
}
- frame = mFrame + action;
-
- if (action == MONSTER_DEAD)
- {
- graphics->drawImage(
- monsterset[job - 1002]->spriteset[dir + 4 * MONSTER_DEAD],
- px - 12, py - 25);
- }
- else
- {
- graphics->drawImage(
- monsterset[job-1002]->spriteset[dir + 4 * frame],
- px - 12, py - 25);
-
- /*
- if (x == mouseTileX && y == mouseTileY)
- {
- graphics->drawImage(attackTarget, px + 4, py - 33);
- }
- */
+ frame = action;
+ if (action != MONSTER_DEAD) {
+ frame += mFrame;
}
+ graphics->drawImage(
+ monsterset[job-1002]->spriteset[dir + 4 * frame],
+ px - 12, py - 25);
break;
default:
break;
}
-
- // Draw player name
- if (getType() == PLAYER && this != player_node)
- {
- graphics->setFont(speechFont);
- graphics->drawText(mName, px + 15, py + 30, gcn::Graphics::CENTER);
- }
}