New sound effect for bubblegum shield collisions

git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/main/trunk@14222 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
auria 2013-10-09 00:14:08 +00:00
parent 0183ed8507
commit b78c0e89c8
2 changed files with 23 additions and 7 deletions

View File

@ -157,6 +157,7 @@ Kart::Kart (const std::string& ident, unsigned int world_kart_id,
m_engine_sound = sfx_manager->createSoundSource(m_kart_properties->getEngineSfxType()); m_engine_sound = sfx_manager->createSoundSource(m_kart_properties->getEngineSfxType());
m_beep_sound = sfx_manager->createSoundSource( "horn" ); m_beep_sound = sfx_manager->createSoundSource( "horn" );
m_crash_sound = sfx_manager->createSoundSource( "crash" ); m_crash_sound = sfx_manager->createSoundSource( "crash" );
m_boing_sound = sfx_manager->createSoundSource( "boing" );
m_goo_sound = sfx_manager->createSoundSource( "goo" ); m_goo_sound = sfx_manager->createSoundSource( "goo" );
m_skid_sound = sfx_manager->createSoundSource( "skid" ); m_skid_sound = sfx_manager->createSoundSource( "skid" );
m_terrain_sound = NULL; m_terrain_sound = NULL;
@ -181,6 +182,7 @@ void Kart::init(RaceManager::KartType type)
m_goo_sound->volume( 1.0f / factor ); m_goo_sound->volume( 1.0f / factor );
m_skid_sound->volume( 1.0f / factor ); m_skid_sound->volume( 1.0f / factor );
m_crash_sound->volume( 1.0f / factor ); m_crash_sound->volume( 1.0f / factor );
m_boing_sound->volume( 1.0f / factor );
m_beep_sound->volume( 1.0f / factor ); m_beep_sound->volume( 1.0f / factor );
} }
else else
@ -189,6 +191,7 @@ void Kart::init(RaceManager::KartType type)
m_skid_sound->volume( 1.0f / race_manager->getNumberOfKarts() ); m_skid_sound->volume( 1.0f / race_manager->getNumberOfKarts() );
m_crash_sound->volume( 1.0f / race_manager->getNumberOfKarts() ); m_crash_sound->volume( 1.0f / race_manager->getNumberOfKarts() );
m_beep_sound->volume( 1.0f / race_manager->getNumberOfKarts() ); m_beep_sound->volume( 1.0f / race_manager->getNumberOfKarts() );
m_boing_sound->volume( 1.0f / race_manager->getNumberOfKarts() );
} }
} }
@ -244,6 +247,7 @@ Kart::~Kart()
sfx_manager->deleteSFX(m_skid_sound ); sfx_manager->deleteSFX(m_skid_sound );
sfx_manager->deleteSFX(m_goo_sound ); sfx_manager->deleteSFX(m_goo_sound );
sfx_manager->deleteSFX(m_beep_sound ); sfx_manager->deleteSFX(m_beep_sound );
sfx_manager->deleteSFX(m_boing_sound );
delete m_kart_gfx; delete m_kart_gfx;
if(m_terrain_sound) sfx_manager->deleteSFX(m_terrain_sound); if(m_terrain_sound) sfx_manager->deleteSFX(m_terrain_sound);
if(m_previous_terrain_sound) sfx_manager->deleteSFX(m_previous_terrain_sound); if(m_previous_terrain_sound) sfx_manager->deleteSFX(m_previous_terrain_sound);
@ -1171,6 +1175,7 @@ void Kart::update(float dt)
m_engine_sound->position ( getXYZ() ); m_engine_sound->position ( getXYZ() );
m_crash_sound->position ( getXYZ() ); m_crash_sound->position ( getXYZ() );
m_skid_sound->position ( getXYZ() ); m_skid_sound->position ( getXYZ() );
m_boing_sound->position ( getXYZ() );
// Check if a kart is (nearly) upside down and not moving much --> automatic rescue // Check if a kart is (nearly) upside down and not moving much --> automatic rescue
if(World::getWorld()->getTrack()->isAutoRescueEnabled() && if(World::getWorld()->getTrack()->isAutoRescueEnabled() &&
@ -1673,7 +1678,7 @@ void Kart::crashed(AbstractKart *k, bool update_attachments)
getAttachment()->handleCollisionWithKart(k); getAttachment()->handleCollisionWithKart(k);
} }
m_controller->crashed(k); m_controller->crashed(k);
crashed(); crashed(NULL, k);
} // crashed(Kart, update_attachments } // crashed(Kart, update_attachments
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------
@ -1813,13 +1818,15 @@ void Kart::crashed(const Material *m, const Vec3 &normal)
} // if(m && m->getCollisionReaction() != Material::NORMAL && } // if(m && m->getCollisionReaction() != Material::NORMAL &&
// !getKartAnimation()) // !getKartAnimation())
m_controller->crashed(m); m_controller->crashed(m);
crashed(); crashed(m, NULL);
} // crashed(Material) } // crashed(Material)
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------
/** Common code used when a kart or a material was hit. /** Common code used when a kart or a material was hit.
* @param m The material collided into, or NULL if none
* @param k The kart collided into, or NULL if none
*/ */
void Kart::crashed() void Kart::crashed(const Material* m, AbstractKart *k)
{ {
if(World::getWorld()->getTime()-m_time_last_crash < 0.5f) return; if(World::getWorld()->getTime()-m_time_last_crash < 0.5f) return;
@ -1833,8 +1840,16 @@ void Kart::crashed()
{ {
// In case that the sfx is longer than 0.5 seconds, only play it if // In case that the sfx is longer than 0.5 seconds, only play it if
// it's not already playing. // it's not already playing.
if(m_crash_sound->getStatus() != SFXManager::SFX_PLAYING) if (isShielded() || (k != NULL && k->isShielded()))
m_crash_sound->play(); {
if (m_boing_sound->getStatus() != SFXManager::SFX_PLAYING)
m_boing_sound->play();
}
else
{
if(m_crash_sound->getStatus() != SFXManager::SFX_PLAYING)
m_crash_sound->play();
}
} }
m_bounce_back_time = 0.1f; m_bounce_back_time = 0.1f;

View File

@ -130,7 +130,7 @@ private:
/** Current leaning of the kart. */ /** Current leaning of the kart. */
float m_current_lean; float m_current_lean;
/** If > 0 then bubble gum effect is on */ /** If > 0 then bubble gum effect is on. This is the sliding when hitting a gum on the floor, not the shield. */
float m_bubblegum_time; float m_bubblegum_time;
/** The torque to apply after hitting a bubble gum. */ /** The torque to apply after hitting a bubble gum. */
@ -211,6 +211,7 @@ private:
SFXBase *m_previous_terrain_sound; SFXBase *m_previous_terrain_sound;
SFXBase *m_skid_sound; SFXBase *m_skid_sound;
SFXBase *m_goo_sound; SFXBase *m_goo_sound;
SFXBase *m_boing_sound;
float m_time_last_crash; float m_time_last_crash;
/** To prevent using nitro in too short bursts */ /** To prevent using nitro in too short bursts */
@ -225,7 +226,7 @@ private:
void updateEngineSFX(); void updateEngineSFX();
void updateNitro(float dt); void updateNitro(float dt);
float getActualWheelForce(); float getActualWheelForce();
void crashed(); void crashed(const Material* m, AbstractKart *k);
void loadData(RaceManager::KartType type, bool animatedModel); void loadData(RaceManager::KartType type, bool animatedModel);
public: public: