Completely removed the usage of a physical wheel radius in the physics, it was

never really necessary, the phsyics are basically the same). Wheel rotation is
was refactored to be completely done in KartModel now.
This commit is contained in:
hiker 2015-07-09 23:59:53 +10:00
parent 0345565ea8
commit 93282f8abf
11 changed files with 46 additions and 85 deletions

View File

@ -394,12 +394,12 @@
exp-spring-response="false" max-force="12000"/> exp-spring-response="false" max-force="12000"/>
<!-- Wheel related parameters: damping-relaxation/compression: for <!-- Wheel related parameters: damping-relaxation/compression: for
bullet, damping parameters. Radius and width of wheel. bullet, damping parameters.
front-right, front-left, rear-right and rear-left give the front-right, front-left, rear-right and rear-left give the
position of the physics raycast wheels relative to the center of position of the physics raycast wheels relative to the center of
gravity. Default is to use the corners of the chassis to attach gravity. Default is to use the corners of the chassis to attach
the wheels to. --> the wheels to. -->
<wheels damping-relaxation="35" damping-compression="5" radius="0.25"> <wheels damping-relaxation="35" damping-compression="5">
<front-right position="0.38 0 0.6" /> <front-right position="0.38 0 0.6" />
<front-left position="-0.38 0 0.6" /> <front-left position="-0.38 0 0.6" />
<rear-right position="0.38 0 -0.6" /> <rear-right position="0.38 0 -0.6" />

View File

@ -118,7 +118,7 @@ void btRaycastVehicle::updateWheelTransform( int wheelIndex , bool interpolatedT
btQuaternion steeringOrn(up,steering);//wheel.m_steering); btQuaternion steeringOrn(up,steering);//wheel.m_steering);
btMatrix3x3 steeringMat(steeringOrn); btMatrix3x3 steeringMat(steeringOrn);
btQuaternion rotatingOrn(right,-wheel.m_rotation); btQuaternion rotatingOrn(right,0);
btMatrix3x3 rotatingMat(rotatingOrn); btMatrix3x3 rotatingMat(rotatingOrn);
btMatrix3x3 basis2( btMatrix3x3 basis2(
@ -345,17 +345,7 @@ void btRaycastVehicle::updateVehicle( btScalar step )
fwd -= wheel.m_raycastInfo.m_contactNormalWS * proj; fwd -= wheel.m_raycastInfo.m_contactNormalWS * proj;
btScalar proj2 = fwd.dot(vel); btScalar proj2 = fwd.dot(vel);
wheel.m_deltaRotation = (proj2 * step) / (wheel.m_wheelsRadius);
wheel.m_rotation += wheel.m_deltaRotation;
} else
{
wheel.m_rotation += wheel.m_deltaRotation;
} }
wheel.m_deltaRotation *= btScalar(0.99);//damping of rotation when not in contact
} }

View File

@ -67,8 +67,6 @@ struct btWheelInfo
btScalar m_wheelsDampingRelaxation;//const btScalar m_wheelsDampingRelaxation;//const
btScalar m_frictionSlip; btScalar m_frictionSlip;
btScalar m_steering; btScalar m_steering;
btScalar m_rotation;
btScalar m_deltaRotation;
btScalar m_rollInfluence; btScalar m_rollInfluence;
btScalar m_maxSuspensionForce; btScalar m_maxSuspensionForce;
@ -99,8 +97,6 @@ struct btWheelInfo
m_frictionSlip = ci.m_frictionSlip; m_frictionSlip = ci.m_frictionSlip;
m_steering = btScalar(0.); m_steering = btScalar(0.);
m_engineForce = btScalar(0.); m_engineForce = btScalar(0.);
m_rotation = btScalar(0.);
m_deltaRotation = btScalar(0.);
m_brake = btScalar(0.); m_brake = btScalar(0.);
m_rollInfluence = btScalar(0.1); m_rollInfluence = btScalar(0.1);
m_bIsFrontWheel = ci.m_bIsFrontWheel; m_bIsFrontWheel = ci.m_bIsFrontWheel;

View File

@ -142,8 +142,6 @@ Kart::Kart (const std::string& ident, unsigned int world_kart_id,
// Set position and heading: // Set position and heading:
m_reset_transform = init_transform; m_reset_transform = init_transform;
m_speed = 0.0f; m_speed = 0.0f;
m_wheel_rotation = 0;
m_wheel_rotation_dt = 0;
m_kart_model->setKart(this); m_kart_model->setKart(this);
@ -347,7 +345,6 @@ void Kart::reset()
m_node->setScale(core::vector3df(1.0f, 1.0f, 1.0f)); m_node->setScale(core::vector3df(1.0f, 1.0f, 1.0f));
m_collected_energy = 0; m_collected_energy = 0;
m_has_started = false; m_has_started = false;
m_wheel_rotation = 0;
m_bounce_back_time = 0.0f; m_bounce_back_time = 0.0f;
m_brake_time = 0.0f; m_brake_time = 0.0f;
m_time_last_crash = 0.0f; m_time_last_crash = 0.0f;
@ -385,22 +382,6 @@ void Kart::reset()
{ {
m_vehicle->reset(); m_vehicle->reset();
} }
// Randomize wheel rotation if needed
if (m_kart_properties->hasRandomWheels() && m_vehicle && m_kart_model)
{
scene::ISceneNode** graphic_wheels = m_kart_model->getWheelNodes();
// FIXME Hardcoded i < 4 comes from the arrays in KartModel
for (int i = 0; i < m_vehicle->getNumWheels() && i < 4; i++)
{
// Physics
btWheelInfo& wheel = m_vehicle->getWheelInfo(i);
wheel.m_rotation = btScalar(rand() % 360);
// And graphics
core::vector3df wheel_rotation(wheel.m_rotation, 0, 0);
if (graphic_wheels[i])
graphic_wheels[i]->setRotation(wheel_rotation);
} // for wheels
} // if random wheel rotation
setTrans(m_reset_transform); setTrans(m_reset_transform);
@ -618,17 +599,12 @@ void Kart::createPhysics()
// All wheel positions are relative to the center of // All wheel positions are relative to the center of
// the collision shape. // the collision shape.
wheel_pos[index].setX(x*0.5f*kart_width); wheel_pos[index].setX(x*0.5f*kart_width);
float radius = getKartProperties()->getWheelRadius();
// The y position of the wheels (i.e. the points where // The y position of the wheels (i.e. the points where
// the suspension is attached to) is just at the // the suspension is attached to) is just at the
// bottom of the kart. That is half the kart height // bottom of the kart. That is half the kart height
// down. The wheel radius is added to the suspension // down.
// length in the physics, so we move the connection wheel_pos[index].setY(- 0.5f*kart_height);
// point 'radius' up. That means that if the suspension wheel_pos[index].setZ((0.5f*kart_length-0.25f)* z);
// is fully compressed (0), the wheel will just be at
// the bottom of the kart chassis and touch the ground
wheel_pos[index].setY(- 0.5f*kart_height + radius);
wheel_pos[index].setZ((0.5f*kart_length - radius)* z);
} }
else else
@ -683,7 +659,6 @@ void Kart::createPhysics()
// Add wheels // Add wheels
// ---------- // ----------
float wheel_radius = m_kart_properties->getWheelRadius();
float suspension_rest = m_kart_properties->getSuspensionRest(); float suspension_rest = m_kart_properties->getSuspensionRest();
btVector3 wheel_direction(0.0f, -1.0f, 0.0f); btVector3 wheel_direction(0.0f, -1.0f, 0.0f);
@ -702,7 +677,8 @@ void Kart::createPhysics()
btWheelInfo& wheel = m_vehicle->addWheel( btWheelInfo& wheel = m_vehicle->addWheel(
wheel_pos[i]+cs, wheel_pos[i]+cs,
wheel_direction, wheel_axle, suspension_rest, wheel_direction, wheel_axle, suspension_rest,
wheel_radius, tuning, is_front_wheel); m_kart_model->getWheelGraphicsRadius(i),
tuning, is_front_wheel);
wheel.m_suspensionStiffness = m_kart_properties->getSuspensionStiffness(); wheel.m_suspensionStiffness = m_kart_properties->getSuspensionStiffness();
wheel.m_wheelsDampingRelaxation = m_kart_properties->getWheelDampingRelaxation(); wheel.m_wheelsDampingRelaxation = m_kart_properties->getWheelDampingRelaxation();
wheel.m_wheelsDampingCompression = m_kart_properties->getWheelDampingCompression(); wheel.m_wheelsDampingCompression = m_kart_properties->getWheelDampingCompression();
@ -1180,11 +1156,6 @@ void Kart::update(float dt)
m_kart_properties->getChassisAngularDamping()); m_kart_properties->getChassisAngularDamping());
} }
//m_wheel_rotation gives the rotation around the X-axis
m_wheel_rotation_dt = m_speed*dt / m_kart_properties->getWheelRadius();
m_wheel_rotation += m_wheel_rotation_dt;
m_wheel_rotation = fmodf(m_wheel_rotation, 2*M_PI);
if(m_kart_animation) if(m_kart_animation)
m_kart_animation->update(dt); m_kart_animation->update(dt);
@ -2601,7 +2572,9 @@ void Kart::updateGraphics(float dt, const Vec3& offset_xyz,
} }
} }
m_kart_model->update(dt, m_wheel_rotation_dt, getSteerPercent(), m_speed); // m_speed*dt is the distance the kart has moved, which determines
// how much the wheels need to rotate.
m_kart_model->update(dt, m_speed*dt, getSteerPercent(), m_speed);
// If the kart is leaning, part of the kart might end up 'in' the track. // If the kart is leaning, part of the kart might end up 'in' the track.
// To avoid this, raise the kart enough to offset the leaning. // To avoid this, raise the kart enough to offset the leaning.

View File

@ -188,12 +188,6 @@ private:
/** Handles all slipstreaming. */ /** Handles all slipstreaming. */
SlipStream *m_slipstream; SlipStream *m_slipstream;
/** Rotation compared to the start position, same for all wheels */
float m_wheel_rotation;
/** Rotation change in the last time delta, same for all wheels */
float m_wheel_rotation_dt;
/** The skidmarks object for this kart. */ /** The skidmarks object for this kart. */
SkidMarks *m_skidmarks; SkidMarks *m_skidmarks;

View File

@ -654,6 +654,15 @@ void KartModel::loadWheelInfo(const XMLNode &node,
*/ */
void KartModel::reset() void KartModel::reset()
{ {
for (unsigned int i = 0; i < 4; i++)
{
m_wheel_rotation[i] = btScalar(rand() % 360);
m_wheel_rotation_dt[i] = 0.0f;
core::vector3df wheel_rotation(0, 0, 0);
if (m_wheel_node[i])
m_wheel_node[i]->setRotation(wheel_rotation);
}
update(0.0f, 0.0f, 0.0f, 0.0f); update(0.0f, 0.0f, 0.0f, 0.0f);
// Stop any animations currently being played. // Stop any animations currently being played.
@ -784,7 +793,7 @@ void KartModel::setDefaultSuspension()
* \param speed The speed of the kart in meters/sec, used for the * \param speed The speed of the kart in meters/sec, used for the
* speed-weighted objects' animations * speed-weighted objects' animations
*/ */
void KartModel::update(float dt, float rotation_dt, float steer, float speed) void KartModel::update(float dt, float distance, float steer, float speed)
{ {
core::vector3df wheel_steer(0, steer*30.0f, 0); core::vector3df wheel_steer(0, steer*30.0f, 0);
@ -802,6 +811,10 @@ void KartModel::update(float dt, float rotation_dt, float steer, float speed)
} }
} }
#endif #endif
//m_wheel_rotation gives the rotation around the X-axis
m_wheel_rotation_dt[i] = distance / m_wheel_graphics_radius[i];
m_wheel_rotation[i] += m_wheel_rotation_dt[i];
m_wheel_rotation[i] = fmodf(m_wheel_rotation[i], 2 * M_PI);
core::vector3df pos = m_wheel_graphics_position[i].toIrrVector(); core::vector3df pos = m_wheel_graphics_position[i].toIrrVector();
@ -811,7 +824,7 @@ void KartModel::update(float dt, float rotation_dt, float steer, float speed)
// Now calculate the new rotation: (old + change) mod 360 // Now calculate the new rotation: (old + change) mod 360
float new_rotation = m_wheel_node[i]->getRotation().X float new_rotation = m_wheel_node[i]->getRotation().X
+ rotation_dt * RAD_TO_DEGREE; + m_wheel_rotation_dt[i] * RAD_TO_DEGREE;
new_rotation = fmodf(new_rotation, 360); new_rotation = fmodf(new_rotation, 360);
core::vector3df wheel_rotation(new_rotation, 0, 0); core::vector3df wheel_rotation(new_rotation, 0, 0);
// Only apply steer to first 2 wheels. // Only apply steer to first 2 wheels.

View File

@ -185,6 +185,14 @@ private:
of wheels in bullet is too large and looks strange). 1=no change, 2=half the amplitude */ of wheels in bullet is too large and looks strange). 1=no change, 2=half the amplitude */
float m_dampen_suspension_amplitude[4]; float m_dampen_suspension_amplitude[4];
/** Rotation compared to the start position, same for all wheels */
float m_wheel_rotation[4];
/** Rotation change in the last time delta, same for all wheels */
float m_wheel_rotation_dt[4];
/** Which animation is currently being played. This is used to overwrite /** Which animation is currently being played. This is used to overwrite
* the default steering animations while being in race. If this is set * the default steering animations while being in race. If this is set
* to AF_DEFAULT the default steering animation is shown. */ * to AF_DEFAULT the default steering animation is shown. */
@ -232,7 +240,7 @@ public:
void loadInfo(const XMLNode &node); void loadInfo(const XMLNode &node);
bool loadModels(const KartProperties &kart_properties); bool loadModels(const KartProperties &kart_properties);
void setDefaultSuspension(); void setDefaultSuspension();
void update(float dt, float rotation_dt, float steer, void update(float dt, float distance, float steer,
float speed); float speed);
void finishedRace(); void finishedRace();
scene::ISceneNode* scene::ISceneNode*

View File

@ -70,7 +70,7 @@ KartProperties::KartProperties(const std::string &filename)
m_nitro_max_speed_increase = m_nitro_duration = m_nitro_fade_out_time = m_nitro_max_speed_increase = m_nitro_duration = m_nitro_fade_out_time =
m_suspension_stiffness = m_wheel_damping_relaxation = m_wheel_base = m_suspension_stiffness = m_wheel_damping_relaxation = m_wheel_base =
m_wheel_damping_compression = m_friction_slip = m_roll_influence = m_wheel_damping_compression = m_friction_slip = m_roll_influence =
m_wheel_radius = m_chassis_linear_damping = m_max_suspension_force = m_chassis_linear_damping = m_max_suspension_force =
m_chassis_angular_damping = m_suspension_rest = m_chassis_angular_damping = m_suspension_rest =
m_max_speed_reverse_ratio = m_rescue_vert_offset = m_max_speed_reverse_ratio = m_rescue_vert_offset =
m_collision_terrain_impulse = m_collision_impulse = m_restitution = m_collision_terrain_impulse = m_collision_impulse = m_restitution =
@ -298,7 +298,10 @@ void KartProperties::load(const std::string &filename, const std::string &node)
// moved to be on the corner of the shape. In order to retain the same // moved to be on the corner of the shape. In order to retain the same
// steering behaviour, the wheel base (which in turn determines the // steering behaviour, the wheel base (which in turn determines the
// turn angle at certain speeds) is shortened by 2*wheel_radius // turn angle at certain speeds) is shortened by 2*wheel_radius
m_wheel_base = fabsf(m_kart_model->getLength() - 2*m_wheel_radius); // Wheel radius was always 0.25, and is now not used anymore, but in order
// to keep existing steering behaviour, the same formula is still
// used.
m_wheel_base = fabsf(m_kart_model->getLength() - 2*0.25f);
// Now convert the turn radius into turn angle: // Now convert the turn radius into turn angle:
for(unsigned int i=0; i<m_turn_angle_at_speed.size(); i++) for(unsigned int i=0; i<m_turn_angle_at_speed.size(); i++)
@ -372,7 +375,6 @@ void KartProperties::getAllData(const XMLNode * root)
{ {
wheels_node->get("damping-relaxation", &m_wheel_damping_relaxation ); wheels_node->get("damping-relaxation", &m_wheel_damping_relaxation );
wheels_node->get("damping-compression", &m_wheel_damping_compression); wheels_node->get("damping-compression", &m_wheel_damping_compression);
wheels_node->get("radius", &m_wheel_radius );
} }
if(const XMLNode *speed_weighted_objects_node = root->getNode("speed-weighted-objects")) if(const XMLNode *speed_weighted_objects_node = root->getNode("speed-weighted-objects"))
@ -687,7 +689,6 @@ void KartProperties::checkAllSet(const std::string &filename)
CHECK_NEG(m_time_reset_steer, "turn time-reset-steer" ); CHECK_NEG(m_time_reset_steer, "turn time-reset-steer" );
CHECK_NEG(m_wheel_damping_relaxation, "wheels damping-relaxation" ); CHECK_NEG(m_wheel_damping_relaxation, "wheels damping-relaxation" );
CHECK_NEG(m_wheel_damping_compression, "wheels damping-compression" ); CHECK_NEG(m_wheel_damping_compression, "wheels damping-compression" );
CHECK_NEG(m_wheel_radius, "wheels radius" );
CHECK_NEG(m_friction_slip, "friction slip" ); CHECK_NEG(m_friction_slip, "friction slip" );
CHECK_NEG(m_roll_influence, "stability roll-influence" ); CHECK_NEG(m_roll_influence, "stability roll-influence" );
CHECK_NEG(m_chassis_linear_damping, "stability chassis-linear-damping" ); CHECK_NEG(m_chassis_linear_damping, "stability chassis-linear-damping" );

View File

@ -288,7 +288,6 @@ private:
float m_max_suspension_force; float m_max_suspension_force;
float m_friction_slip; float m_friction_slip;
float m_roll_influence; float m_roll_influence;
float m_wheel_radius;
/** Parameters for the speed-weighted objects */ /** Parameters for the speed-weighted objects */
SpeedWeightedObject::Properties m_speed_weighted_object_properties; SpeedWeightedObject::Properties m_speed_weighted_object_properties;
@ -571,10 +570,6 @@ public:
/** Returns roll influence. */ /** Returns roll influence. */
float getRollInfluence () const {return m_roll_influence; } float getRollInfluence () const {return m_roll_influence; }
// ------------------------------------------------------------------------
/** Returns wheel radius. */
float getWheelRadius () const {return m_wheel_radius; }
// ------------------------------------------------------------------------ // ------------------------------------------------------------------------
/** Return the additional Y offset added to the y position of the graphical /** Return the additional Y offset added to the y position of the graphical
* chassis. Useful for karts that don't have enough space for suspension * chassis. Useful for karts that don't have enough space for suspension

View File

@ -112,7 +112,6 @@ void btKart::reset()
{ {
btWheelInfo &wheel = m_wheelInfo[i]; btWheelInfo &wheel = m_wheelInfo[i];
wheel.m_raycastInfo.m_suspensionLength = 0; wheel.m_raycastInfo.m_suspensionLength = 0;
wheel.m_rotation = 0;
updateWheelTransform(i, true); updateWheelTransform(i, true);
} }
m_visual_wheels_touch_ground = false; m_visual_wheels_touch_ground = false;
@ -159,7 +158,7 @@ void btKart::updateWheelTransform(int wheelIndex, bool interpolatedTransform)
btQuaternion steeringOrn(up,steering);//wheel.m_steering); btQuaternion steeringOrn(up,steering);//wheel.m_steering);
btMatrix3x3 steeringMat(steeringOrn); btMatrix3x3 steeringMat(steeringOrn);
btQuaternion rotatingOrn(right,-wheel.m_rotation); btQuaternion rotatingOrn(right,0);
btMatrix3x3 rotatingMat(rotatingOrn); btMatrix3x3 rotatingMat(rotatingOrn);
btMatrix3x3 basis2( btMatrix3x3 basis2(
@ -235,7 +234,7 @@ btScalar btKart::rayCast(unsigned int index)
updateWheelTransformsWS( wheel,false); updateWheelTransformsWS( wheel,false);
btScalar max_susp_len = wheel.getSuspensionRestLength()+wheel.m_wheelsRadius btScalar max_susp_len = wheel.getSuspensionRestLength()
+ wheel.m_maxSuspensionTravel; + wheel.m_maxSuspensionTravel;
// Do a slightly longer raycast to see if the kart might soon hit the // Do a slightly longer raycast to see if the kart might soon hit the
@ -266,7 +265,7 @@ btScalar btKart::rayCast(unsigned int index)
wheel.m_raycastInfo.m_triangle_index = rayResults.m_triangle_index;; wheel.m_raycastInfo.m_triangle_index = rayResults.m_triangle_index;;
wheel.m_raycastInfo.m_groundObject = &getFixedBody(); wheel.m_raycastInfo.m_groundObject = &getFixedBody();
wheel.m_raycastInfo.m_suspensionLength = depth - wheel.m_wheelsRadius; wheel.m_raycastInfo.m_suspensionLength = depth;
//clamp on max suspension travel //clamp on max suspension travel
btScalar minSuspensionLength = wheel.getSuspensionRestLength() btScalar minSuspensionLength = wheel.getSuspensionRestLength()
@ -524,15 +523,8 @@ void btKart::updateVehicle( btScalar step )
btScalar proj2 = fwd.dot(vel); btScalar proj2 = fwd.dot(vel);
wheel.m_deltaRotation = (proj2 * step) / (wheel.m_wheelsRadius);
wheel.m_rotation += wheel.m_deltaRotation;
} else
{
wheel.m_rotation += wheel.m_deltaRotation;
} }
//damping of rotation when not in contact
wheel.m_deltaRotation *= btScalar(0.99);
} }

View File

@ -2444,8 +2444,7 @@ bool Track::findGround(AbstractKart *kart)
// length of the suspension with the weight of the kart resting on // length of the suspension with the weight of the kart resting on
// it). On the other hand this initial bouncing looks nice imho // it). On the other hand this initial bouncing looks nice imho
// - so I'll leave it in for now. // - so I'll leave it in for now.
float offset = kart->getKartProperties()->getSuspensionRest() + float offset = kart->getKartProperties()->getSuspensionRest();
kart->getKartProperties()->getWheelRadius();
t.setOrigin(hit_point+Vec3(0, offset, 0) ); t.setOrigin(hit_point+Vec3(0, offset, 0) );
kart->getBody()->setCenterOfMassTransform(t); kart->getBody()->setCenterOfMassTransform(t);
kart->setTrans(t); kart->setTrans(t);