physics: fix a lot of problems

This commit is contained in:
nillerusr 2021-10-23 14:41:59 +03:00
parent b44df09ae1
commit 92c0c3aeb9
31 changed files with 104 additions and 54 deletions

View file

@ -2788,7 +2788,7 @@ int CFastPointLeafNum::GetLeaf( const Vector &vPos )
m_vCachedPos = vPos; m_vCachedPos = vPos;
CCollisionBSPData *pBSPData = GetCollisionBSPData(); CCollisionBSPData *pBSPData = GetCollisionBSPData();
m_flDistToExitLeafSqr = 1e16; m_flDistToExitLeafSqr = 1e24;
m_iCachedLeaf = CM_PointLeafnumMinDistSqr_r( pBSPData, vPos, 0, m_flDistToExitLeafSqr ); m_iCachedLeaf = CM_PointLeafnumMinDistSqr_r( pBSPData, vPos, 0, m_flDistToExitLeafSqr );
} }

View file

@ -102,8 +102,8 @@ inline CVertIndex CDispInfo::IndexToVert( int index ) const
void CDispInfo::UpdateBoundingBox() void CDispInfo::UpdateBoundingBox()
{ {
m_BBoxMin.Init( 1e16, 1e16, 1e16 ); m_BBoxMin.Init( 1e24, 1e24, 1e24 );
m_BBoxMax.Init( -1e16, -1e16, -1e16 ); m_BBoxMax.Init( -1e24, -1e24, -1e24 );
for( int i=0; i < NumVerts(); i++ ) for( int i=0; i < NumVerts(); i++ )
{ {

View file

@ -793,7 +793,7 @@ CDispInfo::CDispInfo()
m_pPowerInfo = NULL; m_pPowerInfo = NULL;
m_ViewerSphereCenter.Init( 1e16, 1e16, 1e16 ); m_ViewerSphereCenter.Init( 1e24, 1e24, 1e24 );
m_bInUse = false; m_bInUse = false;
@ -995,7 +995,7 @@ int FindNeighborCornerVert( CCoreDispInfo *pDisp, const Vector &vecPoint )
CDispUtilsHelper *pDispHelper = pDisp; CDispUtilsHelper *pDispHelper = pDisp;
int iClosest = 0; int iClosest = 0;
float flClosest = 1e16; float flClosest = 1e24;
for ( int iCorner = 0; iCorner < 4; ++iCorner ) for ( int iCorner = 0; iCorner < 4; ++iCorner )
{ {

View file

@ -122,8 +122,8 @@ struct portalclip_t
static inline bool GetPortalScreenExtents( dareaportal_t *pPortal, static inline bool GetPortalScreenExtents( dareaportal_t *pPortal,
portalclip_t * RESTRICT clip, CPortalRect &portalRect , float *pReflectionWaterHeight ) portalclip_t * RESTRICT clip, CPortalRect &portalRect , float *pReflectionWaterHeight )
{ {
portalRect.left = portalRect.bottom = 1e16; portalRect.left = portalRect.bottom = 1e24;
portalRect.right = portalRect.top = -1e16; portalRect.right = portalRect.top = -1e24;
bool bValidExtents = false; bool bValidExtents = false;
worldbrushdata_t *pBrushData = host_state.worldbrush; worldbrushdata_t *pBrushData = host_state.worldbrush;

View file

@ -150,8 +150,8 @@ C_SteamJet::C_SteamJet()
m_bFaceLeft = false; m_bFaceLeft = false;
m_ParticleEffect.SetAlwaysSimulate( false ); // Don't simulate outside the PVS or frustum. m_ParticleEffect.SetAlwaysSimulate( false ); // Don't simulate outside the PVS or frustum.
m_vLastRampUpdatePos.Init( 1e16, 1e16, 1e16 ); m_vLastRampUpdatePos.Init( 1e24, 1e24, 1e24 );
m_vLastRampUpdateAngles.Init( 1e16, 1e16, 1e16 ); m_vLastRampUpdateAngles.Init( 1e24, 1e24, 1e24 );
} }

View file

@ -283,7 +283,7 @@ struct CInterpolatedVarEntryBase<Type, false>
{ {
Assert(maxCount==1); Assert(maxCount==1);
} }
Type *NewEntry( const Type *pValue, int maxCount, float time ) Type *NewEntry( Type *pValue, int maxCount, float time )
{ {
Assert(maxCount==1); Assert(maxCount==1);
changetime = time; changetime = time;

View file

@ -125,8 +125,8 @@ inline CParticleRenderIterator::CParticleRenderIterator()
m_bGotFirst = false; m_bGotFirst = false;
m_flPrevZ = 0; m_flPrevZ = 0;
m_nParticlesInCurrentBatch = 0; m_nParticlesInCurrentBatch = 0;
m_MinZ = 1e16; m_MinZ = 1e24;
m_MaxZ = -1e16; m_MaxZ = -1e24;
m_nZCoords = 0; m_nZCoords = 0;
} }

View file

@ -173,7 +173,7 @@ void CMCVMinimapPanel::OnMousePressed( vgui::MouseCode code )
// Find the closest MCV to their mouse press. // Find the closest MCV to their mouse press.
int iClosest = -1; int iClosest = -1;
float flClosest = 1e16; float flClosest = 1e24;
Vector2D curMousePos( m_LastX, m_LastY ); Vector2D curMousePos( m_LastX, m_LastY );
for ( int i=0; i < pPanel->m_DeployedTeleportStations.Count(); i++ ) for ( int i=0; i < pPanel->m_DeployedTeleportStations.Count(); i++ )

View file

@ -79,7 +79,7 @@ IPhysicsObject *PhysModelCreateCustom( C_BaseEntity *pEntity, const CPhysCollide
solid_t solid; solid_t solid;
solid.params = g_PhysDefaultObjectParams; solid.params = g_PhysDefaultObjectParams;
solid.params.mass = 85.0f; solid.params.mass = 85.0f;
solid.params.inertia = 1e16f; solid.params.inertia = 1e24f;
int surfaceProp = -1; int surfaceProp = -1;
if ( props && props[0] ) if ( props && props[0] )
{ {

View file

@ -74,7 +74,7 @@ static float g_PhysAverageSimTime;
CCallQueue g_PostSimulationQueue; CCallQueue g_PostSimulationQueue;
// local routines // local roeutines
static IPhysicsObject *PhysCreateWorld( CBaseEntity *pWorld ); static IPhysicsObject *PhysCreateWorld( CBaseEntity *pWorld );
static void PhysFrame( float deltaTime ); static void PhysFrame( float deltaTime );
static bool IsDebris( int collisionGroup ); static bool IsDebris( int collisionGroup );
@ -1689,6 +1689,7 @@ void PhysFrame( float deltaTime )
float simRealTime = 0; float simRealTime = 0;
deltaTime *= phys_timescale.GetFloat(); deltaTime *= phys_timescale.GetFloat();
// !!!HACKHACK -- hard limit scaled time to avoid spending too much time in here // !!!HACKHACK -- hard limit scaled time to avoid spending too much time in here
// Limit to 100 ms // Limit to 100 ms
if ( deltaTime > 0.100f ) if ( deltaTime > 0.100f )
@ -1709,10 +1710,9 @@ void PhysFrame( float deltaTime )
g_Collisions.BufferTouchEvents( true ); g_Collisions.BufferTouchEvents( true );
#endif #endif
physenv->Simulate( deltaTime );
int activeCount = physenv->GetActiveObjectCount(); int activeCount = physenv->GetActiveObjectCount();
IPhysicsObject **pActiveList = NULL; IPhysicsObject **pActiveList = NULL;
#if 0
if ( activeCount ) if ( activeCount )
{ {
pActiveList = (IPhysicsObject **)stackalloc( sizeof(IPhysicsObject *)*activeCount ); pActiveList = (IPhysicsObject **)stackalloc( sizeof(IPhysicsObject *)*activeCount );
@ -1721,6 +1721,26 @@ void PhysFrame( float deltaTime )
for ( int i = 0; i < activeCount; i++ ) for ( int i = 0; i < activeCount; i++ )
{ {
CBaseEntity *pEntity = reinterpret_cast<CBaseEntity *>(pActiveList[i]->GetGameData()); CBaseEntity *pEntity = reinterpret_cast<CBaseEntity *>(pActiveList[i]->GetGameData());
OutputVPhysicsDebugInfo(pEntity);
}
stackfree( pActiveList );
}
#endif
physenv->Simulate( deltaTime );
activeCount = physenv->GetActiveObjectCount();
pActiveList = NULL;
if ( activeCount )
{
pActiveList = (IPhysicsObject **)stackalloc( sizeof(IPhysicsObject *)*activeCount );
physenv->GetActiveObjects( pActiveList );
for ( int i = 0; i < activeCount; i++ )
{
CBaseEntity *pEntity = reinterpret_cast<CBaseEntity *>(pActiveList[i]->GetGameData());
// OutputVPhysicsDebugInfo(pEntity);
if ( pEntity ) if ( pEntity )
{ {
if ( pEntity->CollisionProp()->DoesVPhysicsInvalidateSurroundingBox() ) if ( pEntity->CollisionProp()->DoesVPhysicsInvalidateSurroundingBox() )
@ -1948,7 +1968,7 @@ void CCollisionEvent::Friction( IPhysicsObject *pObject, float energy, int surfa
if ( pEntity ) if ( pEntity )
{ {
friction_t *pFriction = g_Collisions.FindFriction( pEntity ); friction_t *pFriction = g_Collisions.FindFriction( pEntity );
if ( pFriction && pFriction->pObject) if ( pFriction && pFriction->pObject)
{ {
// in MP mode play sound and effects once every 500 msecs, // in MP mode play sound and effects once every 500 msecs,

View file

@ -8014,7 +8014,7 @@ void CBasePlayer::SetupVPhysicsShadow( const Vector &vecAbsOrigin, const Vector
Q_strncpy( solid.surfaceprop, "player", sizeof(solid.surfaceprop) ); Q_strncpy( solid.surfaceprop, "player", sizeof(solid.surfaceprop) );
solid.params = g_PhysDefaultObjectParams; solid.params = g_PhysDefaultObjectParams;
solid.params.mass = 85.0f; solid.params.mass = 85.0f;
solid.params.inertia = 1e16f; solid.params.inertia = 1e24f;
solid.params.enableCollisions = false; solid.params.enableCollisions = false;
//disable drag //disable drag
solid.params.dragCoefficient = 0; solid.params.dragCoefficient = 0;

View file

@ -74,7 +74,7 @@ bool COrderHeal::CreateOrder( CPlayerClass *pClass )
ORDER_HEAL, ORDER_HEAL,
pTeam->GetPlayer( sorted[0] ), pTeam->GetPlayer( sorted[0] ),
pClass->GetPlayer(), pClass->GetPlayer(),
1e16, 1e24,
60, 60,
pOrder ); pOrder );

View file

@ -157,7 +157,7 @@ bool OrderCreator_ResourceZoneObject(
ORDER_BUILD, ORDER_BUILD,
pClosest, pClosest,
pPlayer, pPlayer,
1e16, 1e24,
60, 60,
pOrder pOrder
); );

View file

@ -95,7 +95,7 @@ bool COrderKillMortarGuy::CreateOrder( CPlayerClass *pClass )
ORDER_KILL, ORDER_KILL,
pBrian, pBrian,
pClass->GetPlayer(), pClass->GetPlayer(),
1e16, 1e24,
60, 60,
pOrder pOrder
); );

View file

@ -61,7 +61,7 @@ bool COrderMortarAttack::CreateOrder( CPlayerClass *pClass )
ORDER_MORTAR_ATTACK, ORDER_MORTAR_ATTACK,
pEnt, pEnt,
pPlayer, pPlayer,
1e16, 1e24,
40, 40,
pOrder pOrder
); );

View file

@ -91,7 +91,7 @@ bool COrderRepair::CreateOrder_RepairFriendlyObjects( CPlayerClassDefender *pCla
ORDER_REPAIR, ORDER_REPAIR,
pObjToHeal, pObjToHeal,
pPlayer, pPlayer,
1e16, 1e24,
60, 60,
pOrder pOrder
); );
@ -130,7 +130,7 @@ bool COrderRepair::CreateOrder_RepairOwnObjects( CPlayerClass *pClass )
ORDER_REPAIR, ORDER_REPAIR,
pObj, pObj,
info.m_pPlayer, info.m_pPlayer,
1e16, 1e24,
60, 60,
pOrder pOrder
); );

View file

@ -177,7 +177,7 @@ void CObjectBarbedWire::StartPlacement( CBaseTFPlayer *pPlayer )
if ( pPlayer && !m_hConnectedTo ) if ( pPlayer && !m_hConnectedTo )
{ {
// Automatically connect to the nearest barbed wire on our team. // Automatically connect to the nearest barbed wire on our team.
float flClosest = 1e16; float flClosest = 1e24;
CObjectBarbedWire *pClosest = NULL; CObjectBarbedWire *pClosest = NULL;
CBaseEntity *pCur = gEntList.FirstEnt(); CBaseEntity *pCur = gEntList.FirstEnt();

View file

@ -1041,7 +1041,7 @@ void CPlayerClass::InitVCollision( void )
solid_t solid; solid_t solid;
solid.params = g_PhysDefaultObjectParams; solid.params = g_PhysDefaultObjectParams;
solid.params.mass = 85.0f; solid.params.mass = 85.0f;
solid.params.inertia = 1e16f; solid.params.inertia = 1e24f;
solid.params.enableCollisions = false; solid.params.enableCollisions = false;
//disable drag //disable drag
solid.params.dragCoefficient = 0; solid.params.dragCoefficient = 0;

View file

@ -145,7 +145,7 @@ public:
int iOrderType, int iOrderType,
CBaseEntity *pTarget, CBaseEntity *pTarget,
CBaseTFPlayer *pPlayer = NULL, CBaseTFPlayer *pPlayer = NULL,
float flDistanceToRemove = 1e16, float flDistanceToRemove = 1e24,
float flLifetime = 60, float flLifetime = 60,
COrder *pDefaultOrder = NULL // If this is specified, then it is used instead of COrder *pDefaultOrder = NULL // If this is specified, then it is used instead of
// asking COrder to allocate an order. // asking COrder to allocate an order.

View file

@ -478,7 +478,7 @@ void PhysGetDefaultAABBSolid( solid_t &solid )
{ {
solid.params = g_PhysDefaultObjectParams; solid.params = g_PhysDefaultObjectParams;
solid.params.mass = 85.0f; solid.params.mass = 85.0f;
solid.params.inertia = 1e16f; solid.params.inertia = 1e24f;
Q_strncpy( solid.surfaceprop, "default", sizeof( solid.surfaceprop ) ); Q_strncpy( solid.surfaceprop, "default", sizeof( solid.surfaceprop ) );
} }

View file

@ -374,7 +374,7 @@ public:
m_bSkipControllerInitialization = bSkip; m_bSkipControllerInitialization = bSkip;
} }
void StartTextInput(); virtual void StartTextInput();
#if defined( USE_SDL ) #if defined( USE_SDL )
void PollInputState_Platform(); void PollInputState_Platform();

View file

@ -794,7 +794,10 @@ struct dfaceid_t
#if defined( _X360 ) #if defined( _X360 )
#pragma bitfield_order( push, lsb_to_msb ) #pragma bitfield_order( push, lsb_to_msb )
#endif #endif
#ifdef WIN32
#pragma warning( disable:4201 ) // C4201: nonstandard extension used: nameless struct/union #pragma warning( disable:4201 ) // C4201: nonstandard extension used: nameless struct/union
#endif
struct dleaf_version_0_t struct dleaf_version_0_t
{ {
DECLARE_BYTESWAP_DATADESC(); DECLARE_BYTESWAP_DATADESC();

View file

@ -770,8 +770,8 @@ void ClearNeighborData( CCoreDispInfo *pDisp )
void GetDispBox( CCoreDispInfo *pDisp, CDispBox &box ) void GetDispBox( CCoreDispInfo *pDisp, CDispBox &box )
{ {
// Calculate the bbox for this displacement. // Calculate the bbox for this displacement.
Vector vMin( 1e16, 1e16, 1e16 ); Vector vMin( 1e24, 1e24, 1e24 );
Vector vMax( -1e16, -1e16, -1e16 ); Vector vMax( -1e24, -1e24, -1e24 );
for ( int iVert = 0; iVert < 4; ++iVert ) for ( int iVert = 0; iVert < 4; ++iVert )
{ {

View file

@ -156,6 +156,8 @@ public:
void ActivateSteamControllerActionSet( GameActionSet_t eActionSet ) { void ActivateSteamControllerActionSet( GameActionSet_t eActionSet ) {
ActivateSteamControllerActionSetForSlot( 0xffffffffffffffff, eActionSet ); ActivateSteamControllerActionSetForSlot( 0xffffffffffffffff, eActionSet );
} }
virtual void StartTextInput() = 0;
}; };

View file

@ -311,7 +311,7 @@ CPositionInterpolator_Rope::CPositionInterpolator_Rope()
m_nSegments = 5; m_nSegments = 5;
for( int i=0; i < 2; i++ ) for( int i=0; i < 2; i++ )
m_Delegate.m_CurEndPoints[i] = Vector( 1e16, 1e16, 1e16 ); m_Delegate.m_CurEndPoints[i] = Vector( 1e24, 1e24, 1e24 );
} }
void CPositionInterpolator_Rope::Release() void CPositionInterpolator_Rope::Release()

View file

@ -1236,12 +1236,13 @@ public:
#if !defined( _X360 ) #if !defined( _X360 )
Assert( dstVertex.m_vecUserData.w == -1.0f || dstVertex.m_vecUserData.w == 1.0f ); Assert( dstVertex.m_vecUserData.w == -1.0f || dstVertex.m_vecUserData.w == 1.0f );
// TODO(nillerusr): uncomment when i remove -mfpmath=387 from compiler options #if 0 // FIXME(nillerusr): causing a crash, reason: misalign?
//if ( nHasSIMD ) if ( nHasSIMD )
//{ {
// meshBuilder.FastVertexSSE( dstVertex ); meshBuilder.FastVertexSSE( dstVertex );
//} }
//else else
#endif
{ {
meshBuilder.FastVertex( dstVertex ); meshBuilder.FastVertex( dstVertex );
} }
@ -1251,11 +1252,13 @@ public:
} }
else else
{ {
#if 0 // FIXME(nillerusr): causing a crash, reason: misalign?
if ( nHasSIMD ) if ( nHasSIMD )
{ {
meshBuilder.FastVertexSSE( *(ModelVertexDX7_t*)&dstVertex ); meshBuilder.FastVertexSSE( *(ModelVertexDX7_t*)&dstVertex );
} }
else else
#endif
{ {
meshBuilder.FastVertex( *(ModelVertexDX7_t*)&dstVertex ); meshBuilder.FastVertex( *(ModelVertexDX7_t*)&dstVertex );
} }

View file

@ -1484,7 +1484,8 @@ void TextEntry::OnMousePressed(MouseCode code)
return; return;
} }
g_pInputSystem->StartTextInput(); if( IsEnabled() )
g_pInputSystem->StartTextInput();
// move the cursor to where the mouse was pressed // move the cursor to where the mouse was pressed
int x, y; int x, y;

View file

@ -652,6 +652,9 @@ void CConsolePanel::OnTextChanged(Panel *panel)
// see if they've hit the tilde key (which opens & closes the console) // see if they've hit the tilde key (which opens & closes the console)
int len = Q_strlen(m_szPartialText); int len = Q_strlen(m_szPartialText);
if( !len )
return;
bool hitTilde = ( m_szPartialText[len - 1] == '~' || m_szPartialText[len - 1] == '`' ) ? true : false; bool hitTilde = ( m_szPartialText[len - 1] == '~' || m_szPartialText[len - 1] == '`' ) ? true : false;
bool altKeyDown = ( vgui::input()->IsKeyDown( KEY_LALT ) || vgui::input()->IsKeyDown( KEY_RALT ) ) ? true : false; bool altKeyDown = ( vgui::input()->IsKeyDown( KEY_LALT ) || vgui::input()->IsKeyDown( KEY_RALT ) ) ? true : false;
@ -1253,4 +1256,4 @@ void CConsoleDialog::OnKeyCodePressed( vgui::KeyCode code )
{ {
BaseClass::OnKeyCodePressed(code); BaseClass::OnKeyCodePressed(code);
} }
} }

View file

@ -592,7 +592,8 @@ void CPhysicsObject::SetMass( float mass )
} }
Assert( mass > 0 ); Assert( mass > 0 );
mass = clamp( mass, 0, VPHYSICS_MAX_MASS ); // NOTE: Allow zero procedurally, but not by initialization
mass = clamp( mass, 1.f, VPHYSICS_MAX_MASS );
m_pObject->change_mass( mass ); m_pObject->change_mass( mass );
SetVolume( m_volume ); SetVolume( m_volume );
RecomputeDragBases(); RecomputeDragBases();
@ -633,13 +634,17 @@ Vector CPhysicsObject::GetInvInertia( void ) const
} }
void CPhysicsObject::SetInertia( const Vector &inertia ) void CPhysicsObject::SetInertia( const Vector &inertia )
{ {
IVP_U_Float_Point ri; IVP_U_Float_Point ri; ConvertDirectionToIVP( inertia, ri );
ConvertDirectionToIVP( inertia, ri );
ri.k[0] = IVP_Inline_Math::fabsd(ri.k[0]); ri.k[0] = IVP_Inline_Math::fabsd(ri.k[0]);
ri.k[1] = IVP_Inline_Math::fabsd(ri.k[1]); ri.k[1] = IVP_Inline_Math::fabsd(ri.k[1]);
ri.k[2] = IVP_Inline_Math::fabsd(ri.k[2]); ri.k[2] = IVP_Inline_Math::fabsd(ri.k[2]);
if( ri.k[0] > 1e14f ) ri.k[0] = 1e14f; if( ri.k[1] > 1e14f ) ri.k[1] = 1e14f; if( ri.k[2] > 1e14f ) ri.k[2] = 1e14f;
if( ri.k[0] <= 0 ) ri.k[0] = 1.f; if( ri.k[1] <= 0 ) ri.k[1] = 1.f; if( ri.k[2] <= 0 ) ri.k[2] = 1.f;
m_pObject->get_core()->set_rotation_inertia( &ri ); m_pObject->get_core()->set_rotation_inertia( &ri );
} }
@ -1358,6 +1363,7 @@ bool CPhysicsObject::IsFluid() const
// sets the object to be hinged. Fixed it place, but able to rotate around one axis. // sets the object to be hinged. Fixed it place, but able to rotate around one axis.
void CPhysicsObject::BecomeHinged( int localAxis ) void CPhysicsObject::BecomeHinged( int localAxis )
{ {
if ( IsMoveable() ) if ( IsMoveable() )
{ {
float savedMass = GetMass(); float savedMass = GetMass();
@ -1370,6 +1376,7 @@ void CPhysicsObject::BecomeHinged( int localAxis )
SetMass( VPHYSICS_MAX_MASS ); SetMass( VPHYSICS_MAX_MASS );
IVP_U_Float_Hesse tmp = *iri; IVP_U_Float_Hesse tmp = *iri;
#if 0 #if 0
for ( i = 0; i < 3; i++ ) for ( i = 0; i < 3; i++ )
tmp.k[i] = savedRI[i]; tmp.k[i] = savedRI[i];
@ -1394,10 +1401,10 @@ void CPhysicsObject::RemoveHinged()
void CPhysicsObject::OutputDebugInfo() const void CPhysicsObject::OutputDebugInfo() const
{ {
Msg("-----------------\nObject: %s\n", m_pObject->get_name()); Msg("-----------------\nObject: %s\n", m_pObject->get_name());
Msg("Mass: %.1f (inv %.3f)\n", GetMass(), GetInvMass() ); Msg("Mass: %.3e (inv %.3e)\n", GetMass(), GetInvMass() );
Vector inertia = GetInertia(); Vector inertia = GetInertia();
Vector invInertia = GetInvInertia(); Vector invInertia = GetInvInertia();
Msg("Inertia: %.2f, %.2f, %.2f (inv %.3f, %.3f, %.3f)\n", inertia.x, inertia.y, inertia.z, invInertia.x, invInertia.y, invInertia.z ); Msg("Inertia: %.3e, %.3e, %.3e (inv %.3e, %.3e, %.3e)\n", inertia.x, inertia.y, inertia.z, invInertia.x, invInertia.y, invInertia.z );
Vector speed, angSpeed; Vector speed, angSpeed;
GetVelocity( &speed, &angSpeed ); GetVelocity( &speed, &angSpeed );
@ -1406,7 +1413,7 @@ void CPhysicsObject::OutputDebugInfo() const
float damp, angDamp; float damp, angDamp;
GetDamping( &damp, &angDamp ); GetDamping( &damp, &angDamp );
Msg("Damping %.2f linear, %.2f angular\n", damp, angDamp ); Msg("Damping %.3e linear, %.3e angular\n", damp, angDamp );
Msg("Linear Drag: %.2f, %.2f, %.2f (factor %.2f)\n", m_dragBasis.x, m_dragBasis.y, m_dragBasis.z, m_dragCoefficient ); Msg("Linear Drag: %.2f, %.2f, %.2f (factor %.2f)\n", m_dragBasis.x, m_dragBasis.y, m_dragBasis.z, m_dragCoefficient );
Msg("Angular Drag: %.2f, %.2f, %.2f (factor %.2f)\n", m_angDragBasis.x, m_angDragBasis.y, m_angDragBasis.z, m_angDragCoefficient ); Msg("Angular Drag: %.2f, %.2f, %.2f (factor %.2f)\n", m_angDragBasis.x, m_angDragBasis.y, m_angDragBasis.z, m_angDragCoefficient );
@ -1462,8 +1469,7 @@ bool CPhysicsObject::IsAttachedToConstraint( bool bExternalOnly ) const
static void InitObjectTemplate( IVP_Template_Real_Object &objectTemplate, int materialIndex, objectparams_t *pParams, bool isStatic ) static void InitObjectTemplate( IVP_Template_Real_Object &objectTemplate, int materialIndex, objectparams_t *pParams, bool isStatic )
{ {
objectTemplate.mass = pParams->mass; objectTemplate.mass = clamp( pParams->mass, VPHYSICS_MIN_MASS, VPHYSICS_MAX_MASS );
objectTemplate.mass = clamp( objectTemplate.mass, VPHYSICS_MIN_MASS, VPHYSICS_MAX_MASS );
if ( materialIndex >= 0 ) if ( materialIndex >= 0 )
{ {
@ -1495,8 +1501,8 @@ static void InitObjectTemplate( IVP_Template_Real_Object &objectTemplate, int ma
if ( inertia <= 0 ) if ( inertia <= 0 )
inertia = 1.0; inertia = 1.0;
if ( inertia > 1e18f ) if ( inertia > 1e14f )
inertia = 1e18f; inertia = 1e14f;
objectTemplate.rot_inertia.set(inertia, inertia, inertia); objectTemplate.rot_inertia.set(inertia, inertia, inertia);
objectTemplate.rot_speed_damp_factor.set(pParams->rotdamping, pParams->rotdamping, pParams->rotdamping); objectTemplate.rot_speed_damp_factor.set(pParams->rotdamping, pParams->rotdamping, pParams->rotdamping);

View file

@ -1052,7 +1052,7 @@ void CShadowController::AttachObject( void )
if ( !m_allowsRotation ) if ( !m_allowsRotation )
{ {
IVP_U_Float_Point ri( 1e15f, 1e15f, 1e15f ); IVP_U_Float_Point ri( 1e14f, 1e14f, 1e14f );
pCore->set_rotation_inertia( &ri ); pCore->set_rotation_inertia( &ri );
} }
if ( !m_allowsTranslation ) if ( !m_allowsTranslation )

View file

@ -174,7 +174,13 @@ void CVPhysicsParse::ParseSolid( solid_t *pSolid, IVPhysicsKeyHandler *unknownKe
} }
else if ( !Q_stricmp( key, "inertia" ) ) else if ( !Q_stricmp( key, "inertia" ) )
{ {
pSolid->params.inertia = atof(value); float inertia = atof(value);
if( inertia > 1e14f )
pSolid->params.inertia = 1e14f;
else if( inertia <= 0 )
pSolid->params.inertia = 1.f;
else
pSolid->params.inertia = inertia;
} }
else if ( !Q_stricmp( key, "damping" ) ) else if ( !Q_stricmp( key, "damping" ) )
{ {
@ -468,7 +474,13 @@ void CVPhysicsParse::ParseVehicleWheel( vehicle_wheelparams_t &wheel )
} }
else if ( !Q_stricmp( key, "inertia" ) ) else if ( !Q_stricmp( key, "inertia" ) )
{ {
wheel.inertia = atof( value ); float inertia = atof(value);
if( inertia > 1e14f )
wheel.inertia = 1e14f;
else if( inertia <= 0 )
wheel.inertia = 1.f;
else
wheel.inertia = inertia;
} }
else if ( !Q_stricmp( key, "damping" ) ) else if ( !Q_stricmp( key, "damping" ) )
{ {