Use the old method to create graphical attachment effects

See #3820
This commit is contained in:
Benau 2019-04-09 14:23:39 +08:00
parent de1cd8e982
commit 34f262b05b
3 changed files with 31 additions and 35 deletions

View File

@ -37,6 +37,7 @@
#include "karts/kart_properties.hpp" #include "karts/kart_properties.hpp"
#include "modes/world.hpp" #include "modes/world.hpp"
#include "network/network_string.hpp" #include "network/network_string.hpp"
#include "network/rewind_manager.hpp"
#include "physics/triangle_mesh.hpp" #include "physics/triangle_mesh.hpp"
#include "tracks/track.hpp" #include "tracks/track.hpp"
#include "physics/triangle_mesh.hpp" #include "physics/triangle_mesh.hpp"
@ -172,9 +173,9 @@ void Attachment::set(AttachmentType type, int ticks,
* takes care of resetting the owner kart's physics structures to account for * takes care of resetting the owner kart's physics structures to account for
* the updated mass. * the updated mass.
*/ */
void Attachment::clear(bool update_graphical_now) void Attachment::clear()
{ {
if(m_plugin) if (m_plugin)
{ {
delete m_plugin; delete m_plugin;
m_plugin = NULL; m_plugin = NULL;
@ -183,8 +184,6 @@ void Attachment::clear(bool update_graphical_now)
m_type = ATTACH_NOTHING; m_type = ATTACH_NOTHING;
m_ticks_left = 0; m_ticks_left = 0;
m_initial_speed = 0; m_initial_speed = 0;
if (update_graphical_now)
updateGraphicalTypeNow();
} // clear } // clear
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------
@ -304,6 +303,14 @@ void Attachment::hitBanana(ItemState *item_state)
case ATTACH_BOMB: case ATTACH_BOMB:
{ {
add_a_new_item = false; add_a_new_item = false;
if (!RewindManager::get()->isRewinding())
{
HitEffect* he = new Explosion(m_kart->getXYZ(), "explosion",
"explosion_bomb.xml");
if (m_kart->getController()->isLocalPlayerController())
he->setLocalPlayerKartHit();
projectile_manager->addHitEffect(he);
}
if (m_kart->getKartAnimation() == NULL) if (m_kart->getKartAnimation() == NULL)
ExplosionAnimation::create(m_kart); ExplosionAnimation::create(m_kart);
clear(); clear();
@ -411,7 +418,7 @@ void Attachment::handleCollisionWithKart(AbstractKart *other)
stk_config->m_bomb_time_increase), stk_config->m_bomb_time_increase),
m_kart); m_kart);
other->playCustomSFX(SFXManager::CUSTOM_ATTACH); other->playCustomSFX(SFXManager::CUSTOM_ATTACH);
clear(true/*update_graphical_now*/); clear();
} }
} }
} // type==BOMB } // type==BOMB
@ -429,7 +436,7 @@ void Attachment::handleCollisionWithKart(AbstractKart *other)
other->getAttachment()->getTicksLeft()+ other->getAttachment()->getTicksLeft()+
stk_config->time2Ticks(stk_config->m_bomb_time_increase), stk_config->time2Ticks(stk_config->m_bomb_time_increase),
other); other);
other->getAttachment()->clear(true/*update_graphical_now*/); other->getAttachment()->clear();
m_kart->playCustomSFX(SFXManager::CUSTOM_ATTACH); m_kart->playCustomSFX(SFXManager::CUSTOM_ATTACH);
} }
else else
@ -505,6 +512,14 @@ void Attachment::update(int ticks)
m_initial_speed = 0; m_initial_speed = 0;
if (m_ticks_left <= 0) if (m_ticks_left <= 0)
{ {
if (!RewindManager::get()->isRewinding())
{
HitEffect* he = new Explosion(m_kart->getXYZ(), "explosion",
"explosion_bomb.xml");
if (m_kart->getController()->isLocalPlayerController())
he->setLocalPlayerKartHit();
projectile_manager->addHitEffect(he);
}
if (m_kart->getKartAnimation() == NULL) if (m_kart->getKartAnimation() == NULL)
ExplosionAnimation::create(m_kart); ExplosionAnimation::create(m_kart);
} }
@ -515,6 +530,14 @@ void Attachment::update(int ticks)
m_initial_speed = 0; m_initial_speed = 0;
if (m_ticks_left <= 0) if (m_ticks_left <= 0)
{ {
if (!RewindManager::get()->isRewinding())
{
if (m_bubble_explode_sound) m_bubble_explode_sound->deleteSFX();
m_bubble_explode_sound =
SFXManager::get()->createSoundSource("bubblegum_explode");
m_bubble_explode_sound->setPosition(m_kart->getXYZ());
m_bubble_explode_sound->play();
}
if (!m_kart->isGhostKart()) if (!m_kart->isGhostKart())
ItemManager::get()->dropNewItem(Item::ITEM_BUBBLEGUM, m_kart); ItemManager::get()->dropNewItem(Item::ITEM_BUBBLEGUM, m_kart);
} }
@ -540,29 +563,7 @@ void Attachment::updateGraphics(float dt)
switch (m_type) switch (m_type)
{ {
case ATTACH_NOTHING: case ATTACH_NOTHING:
{
if (m_graphical_type == ATTACH_BOMB)
{
// Cleared a bomb
HitEffect *he = new Explosion(m_kart->getXYZ(), "explosion",
"explosion_bomb.xml");
if (m_kart->getController()->isLocalPlayerController())
he->setLocalPlayerKartHit();
projectile_manager->addHitEffect(he);
}
else if (m_graphical_type == ATTACH_BUBBLEGUM_SHIELD ||
m_graphical_type == ATTACH_NOLOK_BUBBLEGUM_SHIELD)
{
// Dropped a bubblegum
if (m_bubble_explode_sound)
m_bubble_explode_sound->deleteSFX();
m_bubble_explode_sound =
SFXManager::get()->createSoundSource("bubblegum_explode");
m_bubble_explode_sound->setPosition(m_kart->getXYZ());
m_bubble_explode_sound->play();
}
break; break;
}
case ATTACH_SWATTER: case ATTACH_SWATTER:
// Graphical model set in swatter class // Graphical model set in swatter class
break; break;

View File

@ -111,16 +111,11 @@ private:
/** Sound for exploding bubble gum shield */ /** Sound for exploding bubble gum shield */
SFXBase *m_bubble_explode_sound; SFXBase *m_bubble_explode_sound;
// ------------------------------------------------------------------------
/** Called in clear() to update m_graphical_type now, so for example
* the explosion sfx or bubblegum sound is not displayed or played when
* the bomb or shield is forcely cleared like in kart animation. */
void updateGraphicalTypeNow() { m_graphical_type = m_type; }
public: public:
Attachment(AbstractKart* kart); Attachment(AbstractKart* kart);
~Attachment(); ~Attachment();
void clear (bool update_graphical_now = false); void clear();
void hitBanana(ItemState *item); void hitBanana(ItemState *item);
void updateGraphics(float dt); void updateGraphics(float dt);

View File

@ -73,7 +73,7 @@ RescueAnimation::RescueAnimation(AbstractKart* kart, bool is_auto_rescue)
float velocity = max_height / timer; float velocity = max_height / timer;
init(rescue_transform, velocity); init(rescue_transform, velocity);
m_kart->getAttachment()->clear(true/*update_graphical_now*/); m_kart->getAttachment()->clear();
// Add a hit unless it was auto-rescue // Add a hit unless it was auto-rescue
if (race_manager->isBattleMode() && if (race_manager->isBattleMode() &&