summaryrefslogtreecommitdiff
path: root/src/net/manaserv/beinghandler.cpp
diff options
context:
space:
mode:
authorBertram <bertram@cegetel.net>2010-02-01 11:49:11 +0100
committerBertram <bertram@cegetel.net>2010-02-01 11:49:11 +0100
commit7e2a54bedefc6b5e2b34c9dafccb8322f46266e7 (patch)
tree8a016c196e36f94ac7454e2300226461e71305c8 /src/net/manaserv/beinghandler.cpp
parent3fe06a98c0af45d7fccce99f39f402485dae71be (diff)
downloadmana-client-7e2a54bedefc6b5e2b34c9dafccb8322f46266e7.tar.gz
mana-client-7e2a54bedefc6b5e2b34c9dafccb8322f46266e7.tar.bz2
mana-client-7e2a54bedefc6b5e2b34c9dafccb8322f46266e7.tar.xz
mana-client-7e2a54bedefc6b5e2b34c9dafccb8322f46266e7.zip
Reduced CPU consumption by setting speed per ticks value only once.
Diffstat (limited to 'src/net/manaserv/beinghandler.cpp')
-rw-r--r--src/net/manaserv/beinghandler.cpp16
1 files changed, 12 insertions, 4 deletions
diff --git a/src/net/manaserv/beinghandler.cpp b/src/net/manaserv/beinghandler.cpp
index 2db76255..09608891 100644
--- a/src/net/manaserv/beinghandler.cpp
+++ b/src/net/manaserv/beinghandler.cpp
@@ -202,10 +202,18 @@ void BeingHandler::handleBeingsMoveMessage(Net::MessageIn &msg)
}
if (speed)
{
- // The being's speed is transfered in tiles per second * 10
- // to keep it transferable in a Byte.
- // We set it back to tiles per second and in a float.
- being->setWalkSpeed((float) speed / 10);
+ /**
+ * The being's speed is transfered in tiles per second * 10
+ * to keep it transferable in a Byte.
+ * We set it back to tiles per second and in a float.
+ * Then, we translate it in pixels per ticks, to correspond
+ * with the Being::logic() function calls
+ * @see MILLISECONDS_IN_A_TICK
+ */
+ const float walkSpeedInTicks =
+ ((float)DEFAULT_TILE_SIDE_LENGTH * (float) speed / 10)
+ / 1000 * (float)MILLISECONDS_IN_A_TICK;
+ being->setWalkSpeed(walkSpeedInTicks);
}
// Ignore messages from the server for the local player