Play player_damage.ogg when recieving damage and additionally play player_falling_damage.ogg when recieving falling damage

This commit is contained in:
PilzAdam 2013-04-17 20:13:47 +02:00
parent 773471750d
commit 2cdf0ff4ab
2 changed files with 22 additions and 1 deletions

View File

@ -40,6 +40,7 @@ with this program; if not, write to the Free Software Foundation, Inc.,
#ifndef SERVER #ifndef SERVER
#include "clientmap.h" #include "clientmap.h"
#include "localplayer.h" #include "localplayer.h"
#include "event.h"
#endif #endif
#include "daynightratio.h" #include "daynightratio.h"
#include "map.h" #include "map.h"
@ -2190,8 +2191,11 @@ void ClientEnvironment::step(float dtime)
{ {
f32 damage_f = (speed - tolerance)/BS * post_factor; f32 damage_f = (speed - tolerance)/BS * post_factor;
u16 damage = (u16)(damage_f+0.5); u16 damage = (u16)(damage_f+0.5);
if(damage != 0) if(damage != 0){
damageLocalPlayer(damage, true); damageLocalPlayer(damage, true);
MtEvent *e = new SimpleTriggerEvent("PlayerFallingDamage");
m_gamedef->event()->put(e);
}
} }
} }

View File

@ -729,6 +729,18 @@ public:
sm->m_sound->playSound(sm->m_ndef->get(nde->n).sound_dug, false); sm->m_sound->playSound(sm->m_ndef->get(nde->n).sound_dug, false);
} }
static void playerDamage(MtEvent *e, void *data)
{
SoundMaker *sm = (SoundMaker*)data;
sm->m_sound->playSound(SimpleSoundSpec("player_damage", 0.5), false);
}
static void playerFallingDamage(MtEvent *e, void *data)
{
SoundMaker *sm = (SoundMaker*)data;
sm->m_sound->playSound(SimpleSoundSpec("player_falling_damage", 0.5), false);
}
void registerReceiver(MtEventManager *mgr) void registerReceiver(MtEventManager *mgr)
{ {
mgr->reg("ViewBobbingStep", SoundMaker::viewBobbingStep, this); mgr->reg("ViewBobbingStep", SoundMaker::viewBobbingStep, this);
@ -737,6 +749,8 @@ public:
mgr->reg("CameraPunchLeft", SoundMaker::cameraPunchLeft, this); mgr->reg("CameraPunchLeft", SoundMaker::cameraPunchLeft, this);
mgr->reg("CameraPunchRight", SoundMaker::cameraPunchRight, this); mgr->reg("CameraPunchRight", SoundMaker::cameraPunchRight, this);
mgr->reg("NodeDug", SoundMaker::nodeDug, this); mgr->reg("NodeDug", SoundMaker::nodeDug, this);
mgr->reg("PlayerDamage", SoundMaker::playerDamage, this);
mgr->reg("PlayerFallingDamage", SoundMaker::playerFallingDamage, this);
} }
void step(float dtime) void step(float dtime)
@ -2202,6 +2216,9 @@ void the_game(
player->hurt_tilt_timer = 1.5; player->hurt_tilt_timer = 1.5;
player->hurt_tilt_strength = event.player_damage.amount/2; player->hurt_tilt_strength = event.player_damage.amount/2;
player->hurt_tilt_strength = rangelim(player->hurt_tilt_strength, 2.0, 10.0); player->hurt_tilt_strength = rangelim(player->hurt_tilt_strength, 2.0, 10.0);
MtEvent *e = new SimpleTriggerEvent("PlayerDamage");
gamedef->event()->put(e);
} }
else if(event.type == CE_PLAYER_FORCE_MOVE) else if(event.type == CE_PLAYER_FORCE_MOVE)
{ {