Smooth rotating when skidding was stopped.

git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/main/trunk@14310 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
deveee 2013-10-26 09:33:41 +00:00
parent c04396e1c1
commit 6dd109dab0
2 changed files with 24 additions and 3 deletions

View File

@ -115,6 +115,16 @@ void Skidding::updateSteering(float steer, float dt)
m_visual_rotation = f; m_visual_rotation = f;
} }
break; break;
case SKID_BREAK:
m_real_steering = steer;
if (m_visual_rotation > 0.05f) m_visual_rotation -= 0.05;
else if (m_visual_rotation < -0.05f) m_visual_rotation += 0.05;
else
{
m_visual_rotation = 0;
reset();
}
break;
case SKID_ACCUMULATE_RIGHT: case SKID_ACCUMULATE_RIGHT:
{ {
float f = (1.0f+steer)*0.5f; // map [-1,1] --> [0, 1] float f = (1.0f+steer)*0.5f; // map [-1,1] --> [0, 1]
@ -139,6 +149,8 @@ void Skidding::updateSteering(float steer, float dt)
m_visual_rotation = m_skid_visual * m_real_steering; m_visual_rotation = m_skid_visual * m_real_steering;
break; break;
} }
} // switch m_skid_state } // switch m_skid_state
} // updateSteering } // updateSteering
@ -160,6 +172,7 @@ float Skidding::getSteeringWhenSkidding(float steering) const
case SKID_OLD: assert(false); break; case SKID_OLD: assert(false); break;
case SKID_SHOW_GFX_LEFT: case SKID_SHOW_GFX_LEFT:
case SKID_SHOW_GFX_RIGHT: case SKID_SHOW_GFX_RIGHT:
case SKID_BREAK:
case SKID_NONE: return steering; case SKID_NONE: return steering;
break; break;
case SKID_ACCUMULATE_RIGHT: case SKID_ACCUMULATE_RIGHT:
@ -201,7 +214,9 @@ void Skidding::update(float dt, bool is_on_ground,
// No skidding backwards or while stopped // No skidding backwards or while stopped
if(m_kart->getSpeed() < 0.001f) if(m_kart->getSpeed() < 0.001f)
{ {
reset(); m_skid_state = SKID_BREAK;
m_kart->getKartGFX()->setCreationRateAbsolute(KartGFX::KGFX_SKIDL, 0);
m_kart->getKartGFX()->setCreationRateAbsolute(KartGFX::KGFX_SKIDR, 0);
} }
m_skid_bonus_ready = false; m_skid_bonus_ready = false;
@ -337,6 +352,11 @@ void Skidding::update(float dt, bool is_on_ground,
#endif #endif
m_skid_time = 0; // fallthrough m_skid_time = 0; // fallthrough
} }
case SKID_BREAK:
{
updateSteering(steering, dt);
break;
}
case SKID_ACCUMULATE_LEFT: case SKID_ACCUMULATE_LEFT:
case SKID_ACCUMULATE_RIGHT: case SKID_ACCUMULATE_RIGHT:
{ {

View File

@ -81,10 +81,11 @@ public:
* SKID_ACCUMULATE_RIGHT: Similar for turning right * SKID_ACCUMULATE_RIGHT: Similar for turning right
* SKID_SHOW_GFX_LEFT: Shows the gfx, while the bonus is active, * SKID_SHOW_GFX_LEFT: Shows the gfx, while the bonus is active,
* and the kart was turning left. * and the kart was turning left.
* SKID_SHOW_GFX_RIGHT: Similar for turning right. */ * SKID_SHOW_GFX_RIGHT: Similar for turning right.
* SKID_BREAK: Skidding was stopped without bonus */
enum SkidState {SKID_OLD, SKID_NONE, SKID_ACCUMULATE_LEFT, enum SkidState {SKID_OLD, SKID_NONE, SKID_ACCUMULATE_LEFT,
SKID_ACCUMULATE_RIGHT, SKID_SHOW_GFX_LEFT, SKID_ACCUMULATE_RIGHT, SKID_SHOW_GFX_LEFT,
SKID_SHOW_GFX_RIGHT} ; SKID_SHOW_GFX_RIGHT, SKID_BREAK} ;
private: private:
/** The current skidding state. */ /** The current skidding state. */