Merge remote-tracking branch 'Flakebi/skidding-light'
This commit is contained in:
commit
2ba46cff9e
@ -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 */
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user