From 683f42527e186daf0f022dd75766874f6d4a6d3c Mon Sep 17 00:00:00 2001 From: Flakebi Date: Mon, 9 Feb 2015 15:18:53 +0100 Subject: [PATCH] Add light effect when skidding --- src/karts/kart.cpp | 39 ++++++++++++++++++++++++++++++++++++++- src/karts/kart.hpp | 12 ++++++++++-- src/karts/skidding.cpp | 3 +++ 3 files changed, 51 insertions(+), 3 deletions(-) diff --git a/src/karts/kart.cpp b/src/karts/kart.cpp index ea446fe6e..a5c31e3f1 100644 --- a/src/karts/kart.cpp +++ b/src/karts/kart.cpp @@ -132,6 +132,8 @@ Kart::Kart (const std::string& ident, unsigned int world_kart_id, m_fire_clicked = 0; m_wrongway_counter = 0; m_nitro_light = NULL; + m_skidding_light_1 = NULL; + m_skidding_light_2 = NULL; m_type = RaceManager::KT_AI; 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); 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), - 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->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 m_node->setName( (getIdent()+"(lod-node)").c_str() ); #endif @@ -2739,4 +2754,26 @@ void Kart::setOnScreenText(const wchar_t *text) // when the parent is deleted. } // setOnScreenText +void Kart::activateSkidLight(unsigned int level) +{ + if (level > 0) + { + if (level == 1) + { + m_skidding_light_1->setVisible(true); + m_skidding_light_2->setVisible(false); + } + else + { + m_skidding_light_2->setVisible(true); + m_skidding_light_1->setVisible(false); + } + } + else + { + m_skidding_light_1->setVisible(false); + m_skidding_light_2->setVisible(false); + } +} + /* EOF */ diff --git a/src/karts/kart.hpp b/src/karts/kart.hpp index 7c685d66d..5342d9043 100644 --- a/src/karts/kart.hpp +++ b/src/karts/kart.hpp @@ -222,8 +222,14 @@ private: /** To prevent using nitro in too short bursts */ float m_min_nitro_time; + /** A light that's shown when the kart uses nitro. */ 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 handleMaterialSFX(const Material *material); void handleMaterialGFX(); @@ -250,8 +256,8 @@ public: virtual bool isInRest () const; virtual void applyEngineForce (float force); - virtual void flyUp(); - virtual void flyDown(); + virtual void flyUp(); + virtual void flyDown(); virtual void startEngineSFX (); virtual void adjustSpeed (float f); @@ -448,6 +454,8 @@ public: /** Counter which is used for displaying wrong way message after a delay */ float getWrongwayCounter() { return m_wrongway_counter; } void setWrongwayCounter(float counter) { m_wrongway_counter = counter; } + + void activateSkidLight(unsigned int level); }; // Kart diff --git a/src/karts/skidding.cpp b/src/karts/skidding.cpp index d3e02d413..a1014adff 100644 --- a/src/karts/skidding.cpp +++ b/src/karts/skidding.cpp @@ -77,6 +77,7 @@ void Skidding::reset() m_jump_speed = 0.0f; m_kart->getKartGFX()->setCreationRateAbsolute(KartGFX::KGFX_SKIDL, 0); m_kart->getKartGFX()->setCreationRateAbsolute(KartGFX::KGFX_SKIDR, 0); + m_kart->activateSkidLight(0); m_kart->getControls().m_skid = KartControl::SC_NONE; btVector3 rot(0, 0, 0); @@ -392,6 +393,7 @@ void Skidding::update(float dt, bool is_on_ground, { m_skid_bonus_ready = true; m_kart->getKartGFX()->setSkidLevel(level); + m_kart->activateSkidLight(level); } // If player stops skidding, trigger bonus, and change state to // SKID_SHOW_GFX_* @@ -445,6 +447,7 @@ void Skidding::update(float dt, bool is_on_ground, ->setCreationRateAbsolute(KartGFX::KGFX_SKIDL, 0); m_kart->getKartGFX() ->setCreationRateAbsolute(KartGFX::KGFX_SKIDR, 0); + m_kart->activateSkidLight(0); m_skid_state = SKID_NONE; } } // switch