From 0449bdda117faae26509ac8b3606441c9b223f80 Mon Sep 17 00:00:00 2001 From: Trsdy <914137150@qq.com> Date: Mon, 28 Oct 2024 17:06:35 +0800 Subject: [PATCH] Attempt on curing kirov's Parkinson --- src/Ext/Unit/Hooks.Jumpjet.cpp | 23 ++++++++++++++--------- 1 file changed, 14 insertions(+), 9 deletions(-) diff --git a/src/Ext/Unit/Hooks.Jumpjet.cpp b/src/Ext/Unit/Hooks.Jumpjet.cpp index 9c375e5a40..bd59a0dcfc 100644 --- a/src/Ext/Unit/Hooks.Jumpjet.cpp +++ b/src/Ext/Unit/Hooks.Jumpjet.cpp @@ -8,6 +8,7 @@ // Jumpjets stuck at FireError::FACING because Jumpjet has its own facing just for JumpjetTurnRate // We should not touch the linked unit's PrimaryFacing when it's moving and just let the loco sync this shit in 54D692 // The body facing never actually turns, it just syncs +// Whatever, now let's totally forget PrimaryFacing and only use that loco facing DEFINE_HOOK(0x736F78, UnitClass_UpdateFiring_FireErrorIsFACING, 0x6) { GET(UnitClass* const, pThis, ESI); @@ -176,7 +177,7 @@ DEFINE_HOOK(0x70B649, TechnoClass_RigidBodyDynamics_NoTiltCrashBlyat, 0x6) } // Just rewrite this completely to avoid headache -Matrix3D* __stdcall JumpjetLocomotionClass_Draw_Matrix(ILocomotion* iloco, Matrix3D* ret, VoxelIndexKey* pIndex) +Matrix3D* __stdcall JumpjetLocomotionClass_Draw_Matrix(ILocomotion* iloco, Matrix3D* ret, int* pIndex) { __assume(iloco != nullptr); auto const pThis = static_cast(iloco); @@ -185,19 +186,15 @@ Matrix3D* __stdcall JumpjetLocomotionClass_Draw_Matrix(ILocomotion* iloco, Matri bool const onGround = pThis->State == JumpjetLocomotionClass::State::Grounded; // Man, what can I say, you don't want to stick your rotor into the ground auto slope_idx = MapClass::Instance->GetCellAt(linked->Location)->SlopeIndex; - - if (onGround && pIndex && pIndex->Is_Valid_Key()) - *(int*)(pIndex) = slope_idx + (*(int*)(pIndex) << 6); - - *ret = Matrix3D::VoxelRampMatrix[onGround ? slope_idx : 0] * pThis->LocomotionClass::Draw_Matrix(pIndex); - + *ret = Matrix3D::VoxelRampMatrix[onGround ? slope_idx : 0]; + auto curf = pThis->LocomotionFacing.Current(); + ret->RotateZ((float)curf.GetRadian<32>()); float arf = linked->AngleRotatedForwards; float ars = linked->AngleRotatedSideways; if (std::abs(ars) >= 0.005 || std::abs(arf) >= 0.005) { - if (pIndex) - pIndex->Invalidate(); + if (pIndex) *pIndex = -1; if (onGround) { @@ -218,6 +215,14 @@ Matrix3D* __stdcall JumpjetLocomotionClass_Draw_Matrix(ILocomotion* iloco, Matri ret->RotateY(arf); } } + + if (pIndex && *pIndex != -1) + { + if (onGround) *pIndex = slope_idx + (*pIndex << 6); + *pIndex *= 32; + *pIndex |= curf.GetFacing<32>(); + } + return ret; }