Merge remote-tracking branch 'Flakebi/skidding-light'

This commit is contained in:
Marianne Gagnon 2015-02-10 20:09:03 -05:00
commit 2ba46cff9e
3 changed files with 35 additions and 3 deletions

View File

@ -132,6 +132,8 @@ Kart::Kart (const std::string& ident, unsigned int world_kart_id,
m_fire_clicked = 0; m_fire_clicked = 0;
m_wrongway_counter = 0; m_wrongway_counter = 0;
m_nitro_light = NULL; m_nitro_light = NULL;
m_skidding_light_1 = NULL;
m_skidding_light_2 = NULL;
m_type = RaceManager::KT_AI; m_type = RaceManager::KT_AI;
m_view_blocked_by_plunger = 0; m_view_blocked_by_plunger = 0;
@ -2393,11 +2395,24 @@ void Kart::loadData(RaceManager::KartType type, bool is_animated_model)
bool always_animated = (type == RaceManager::KT_PLAYER && race_manager->getNumPlayers() == 1); bool always_animated = (type == RaceManager::KT_PLAYER && race_manager->getNumPlayers() == 1);
m_node = m_kart_model->attachModel(is_animated_model, always_animated); m_node = m_kart_model->attachModel(is_animated_model, always_animated);
// Create nitro light
m_nitro_light = irr_driver->addLight(core::vector3df(0.0f, 0.5f, m_kart_model->getLength()*-0.5f - 0.05f), m_nitro_light = irr_driver->addLight(core::vector3df(0.0f, 0.5f, m_kart_model->getLength()*-0.5f - 0.05f),
0.6f /* force */, 5.0f /* radius */, 0.0f, 0.4f, 1.0f, false, m_node); 0.4f /* force */, 5.0f /* radius */, 0.0f, 0.4f, 1.0f, false, m_node);
m_nitro_light->setVisible(false); m_nitro_light->setVisible(false);
m_nitro_light->setName( ("nitro emitter (" + getIdent() + ")").c_str() ); m_nitro_light->setName( ("nitro emitter (" + getIdent() + ")").c_str() );
// Create skidding lights
// For the first skidding level
m_skidding_light_1 = irr_driver->addLight(core::vector3df(0.0f, 0.1f, m_kart_model->getLength()*-0.5f - 0.05f),
0.3f /* force */, 3.0f /* radius */, 1.0f, 0.6f, 0.0f, false, m_node);
m_skidding_light_1->setVisible(false);
m_skidding_light_1->setName( ("skidding emitter 1 (" + getIdent() + ")").c_str() );
// For the second skidding level
m_skidding_light_2 = irr_driver->addLight(core::vector3df(0.0f, 0.1f, m_kart_model->getLength()*-0.5f - 0.05f),
0.4f /* force */, 4.0f /* radius */, 1.0f, 0.0f, 0.0f, false, m_node);
m_skidding_light_2->setVisible(false);
m_skidding_light_2->setName( ("skidding emitter 2 (" + getIdent() + ")").c_str() );
#ifdef DEBUG #ifdef DEBUG
m_node->setName( (getIdent()+"(lod-node)").c_str() ); m_node->setName( (getIdent()+"(lod-node)").c_str() );
#endif #endif
@ -2739,4 +2754,10 @@ void Kart::setOnScreenText(const wchar_t *text)
// when the parent is deleted. // when the parent is deleted.
} // setOnScreenText } // setOnScreenText
void Kart::activateSkidLight(unsigned int level)
{
m_skidding_light_1->setVisible(level == 1);
m_skidding_light_2->setVisible(level > 1);
}
/* EOF */ /* EOF */

View File

@ -222,8 +222,14 @@ private:
/** To prevent using nitro in too short bursts */ /** To prevent using nitro in too short bursts */
float m_min_nitro_time; float m_min_nitro_time;
/** A light that's shown when the kart uses nitro. */
scene::ISceneNode* m_nitro_light; scene::ISceneNode* m_nitro_light;
/** Lights that are shown when the kart is skidding. */
scene::ISceneNode* m_skidding_light_1;
/** A light that's shown on the second skid-level with another color. */
scene::ISceneNode* m_skidding_light_2;
void updatePhysics(float dt); void updatePhysics(float dt);
void handleMaterialSFX(const Material *material); void handleMaterialSFX(const Material *material);
void handleMaterialGFX(); void handleMaterialGFX();
@ -250,8 +256,8 @@ public:
virtual bool isInRest () const; virtual bool isInRest () const;
virtual void applyEngineForce (float force); virtual void applyEngineForce (float force);
virtual void flyUp(); virtual void flyUp();
virtual void flyDown(); virtual void flyDown();
virtual void startEngineSFX (); virtual void startEngineSFX ();
virtual void adjustSpeed (float f); virtual void adjustSpeed (float f);
@ -448,6 +454,8 @@ public:
/** Counter which is used for displaying wrong way message after a delay */ /** Counter which is used for displaying wrong way message after a delay */
float getWrongwayCounter() { return m_wrongway_counter; } float getWrongwayCounter() { return m_wrongway_counter; }
void setWrongwayCounter(float counter) { m_wrongway_counter = counter; } void setWrongwayCounter(float counter) { m_wrongway_counter = counter; }
void activateSkidLight(unsigned int level);
}; // Kart }; // Kart

View File

@ -77,6 +77,7 @@ void Skidding::reset()
m_jump_speed = 0.0f; m_jump_speed = 0.0f;
m_kart->getKartGFX()->setCreationRateAbsolute(KartGFX::KGFX_SKIDL, 0); m_kart->getKartGFX()->setCreationRateAbsolute(KartGFX::KGFX_SKIDL, 0);
m_kart->getKartGFX()->setCreationRateAbsolute(KartGFX::KGFX_SKIDR, 0); m_kart->getKartGFX()->setCreationRateAbsolute(KartGFX::KGFX_SKIDR, 0);
m_kart->activateSkidLight(0);
m_kart->getControls().m_skid = KartControl::SC_NONE; m_kart->getControls().m_skid = KartControl::SC_NONE;
btVector3 rot(0, 0, 0); btVector3 rot(0, 0, 0);
@ -392,6 +393,7 @@ void Skidding::update(float dt, bool is_on_ground,
{ {
m_skid_bonus_ready = true; m_skid_bonus_ready = true;
m_kart->getKartGFX()->setSkidLevel(level); m_kart->getKartGFX()->setSkidLevel(level);
m_kart->activateSkidLight(level);
} }
// If player stops skidding, trigger bonus, and change state to // If player stops skidding, trigger bonus, and change state to
// SKID_SHOW_GFX_* // SKID_SHOW_GFX_*
@ -445,6 +447,7 @@ void Skidding::update(float dt, bool is_on_ground,
->setCreationRateAbsolute(KartGFX::KGFX_SKIDL, 0); ->setCreationRateAbsolute(KartGFX::KGFX_SKIDL, 0);
m_kart->getKartGFX() m_kart->getKartGFX()
->setCreationRateAbsolute(KartGFX::KGFX_SKIDR, 0); ->setCreationRateAbsolute(KartGFX::KGFX_SKIDR, 0);
m_kart->activateSkidLight(0);
m_skid_state = SKID_NONE; m_skid_state = SKID_NONE;
} }
} // switch } // switch