mirror of
https://github.com/qwertyuiop3/Storm.git
synced 2025-09-19 20:16:15 +08:00
Compare commits
25 Commits
06.12.2024
...
04.02.2025
Author | SHA1 | Date | |
---|---|---|---|
1136c1d430 | |||
31043114f0 | |||
1fc61ba184 | |||
359928047c | |||
631d1e1358 | |||
d5a3de9a21 | |||
0b54788d15 | |||
d12933fe27 | |||
f819000cfe | |||
a402400c01 | |||
519d56c138 | |||
f5fb3e4d30 | |||
81feda0668 | |||
61f5cad124 | |||
8496bfcbeb | |||
7b440b4004 | |||
7c6d951aee | |||
e2437349a0 | |||
0381620f7d | |||
309a0f2c27 | |||
6026914241 | |||
9efc44f17e | |||
02e94e451c | |||
5d9ab0c46b | |||
6768e29ea6 |
427
Copy_Command.hpp
427
Copy_Command.hpp
@ -13,15 +13,20 @@ struct Target_Structure
|
|||||||
|
|
||||||
std::vector<Target_Structure> Sorted_Target_List;
|
std::vector<Target_Structure> Sorted_Target_List;
|
||||||
|
|
||||||
|
void* Get_Studio_Header(void* Entity)
|
||||||
|
{
|
||||||
|
using Get_Studio_Header_Type = void*(__thiscall*)(void* Entity);
|
||||||
|
|
||||||
|
return Get_Studio_Header_Type((unsigned __int32)Client_Module + 8512)(Entity);
|
||||||
|
}
|
||||||
|
|
||||||
void* Get_Hitbox_Set(Target_Structure* Target, float(*Bones)[3][4], float Time)
|
void* Get_Hitbox_Set(Target_Structure* Target, float(*Bones)[3][4], float Time)
|
||||||
{
|
{
|
||||||
using Setup_Bones_Type = __int8(__thiscall*)(void* Entity, void* Bones, __int32 Maximum_Bones, __int32 Mask, float Current_Time);
|
using Setup_Bones_Type = __int8(__thiscall*)(void* Entity, void* Bones, __int32 Maximum_Bones, __int32 Mask, float Current_Time);
|
||||||
|
|
||||||
if (Setup_Bones_Type((unsigned __int32)Client_Module + 246656)((void*)((unsigned __int32)Target->Self + 4), Bones, 128, 524032, Time) == 1)
|
if (Setup_Bones_Type((unsigned __int32)Client_Module + 246656)((void*)((unsigned __int32)Target->Self + 4), Bones, 128, 524032, Time) == 1)
|
||||||
{
|
{
|
||||||
using Get_Studio_Header_Type = void*(__thiscall*)(void* Entity);
|
void* Studio_Header = *(void**)Get_Studio_Header(Target->Self);
|
||||||
|
|
||||||
void* Studio_Header = *(void**)Get_Studio_Header_Type((unsigned __int32)Client_Module + 8512)(Target->Self);
|
|
||||||
|
|
||||||
return (void*)((unsigned __int32)Studio_Header + *(__int32*)((unsigned __int32)Studio_Header + 176));
|
return (void*)((unsigned __int32)Studio_Header + *(__int32*)((unsigned __int32)Studio_Header + 176));
|
||||||
}
|
}
|
||||||
@ -53,7 +58,7 @@ void __thiscall Redirected_Copy_Command(void* Unknown_Parameter, Command_Structu
|
|||||||
{
|
{
|
||||||
Extended_Command->Extra_Commands = max(0, Extra_Commands = std::clamp(Interface_Extra_Commands.Integer, (__int32)(0.06f / Global_Variables->Interval_Per_Tick + 0.5f), 14));
|
Extended_Command->Extra_Commands = max(0, Extra_Commands = std::clamp(Interface_Extra_Commands.Integer, (__int32)(0.06f / Global_Variables->Interval_Per_Tick + 0.5f), 14));
|
||||||
|
|
||||||
*(float*)((unsigned __int32)Local_Player + 16) *= 1.f + Extended_Command->Extra_Commands;
|
*(float*)((unsigned __int32)Local_Player + 16) *= 1.f + Extended_Command->Extra_Commands * Interface_Interpolate_Extra_Commands.Integer;
|
||||||
}
|
}
|
||||||
|
|
||||||
__int32 Variable_Number = 0;
|
__int32 Variable_Number = 0;
|
||||||
@ -75,6 +80,8 @@ void __thiscall Redirected_Copy_Command(void* Unknown_Parameter, Command_Structu
|
|||||||
|
|
||||||
if (*(__int8*)((unsigned __int32)Local_Player + 327) == 0)
|
if (*(__int8*)((unsigned __int32)Local_Player + 327) == 0)
|
||||||
{
|
{
|
||||||
|
Command->Buttons |= 4194304 * (Command->Command_Number % 2);
|
||||||
|
|
||||||
float Move_Angles[3] =
|
float Move_Angles[3] =
|
||||||
{
|
{
|
||||||
Command->Angles[0],
|
Command->Angles[0],
|
||||||
@ -109,11 +116,11 @@ void __thiscall Redirected_Copy_Command(void* Unknown_Parameter, Command_Structu
|
|||||||
|
|
||||||
if (__builtin_signbitf(Strafe_Angle) == 0)
|
if (__builtin_signbitf(Strafe_Angle) == 0)
|
||||||
{
|
{
|
||||||
Command->Move[1] = -400.f;
|
Command->Move[1] = -450.f;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Command->Move[1] = 400.f;
|
Command->Move[1] = 450.f;
|
||||||
}
|
}
|
||||||
|
|
||||||
Move_Angles[1] -= Strafe_Angle;
|
Move_Angles[1] -= Strafe_Angle;
|
||||||
@ -122,11 +129,11 @@ void __thiscall Redirected_Copy_Command(void* Unknown_Parameter, Command_Structu
|
|||||||
{
|
{
|
||||||
if (__builtin_signbitf(Difference) == 0)
|
if (__builtin_signbitf(Difference) == 0)
|
||||||
{
|
{
|
||||||
Command->Move[1] = -400.f;
|
Command->Move[1] = -450.f;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Command->Move[1] = 400.f;
|
Command->Move[1] = 450.f;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -185,13 +192,15 @@ void __thiscall Redirected_Copy_Command(void* Unknown_Parameter, Command_Structu
|
|||||||
|
|
||||||
Correct_Movement();
|
Correct_Movement();
|
||||||
|
|
||||||
|
Extended_Command_Structure* Initial_Extended_Command = &Extended_Commands[*(__int32*)((unsigned __int32)Local_Player + 20) % 150];
|
||||||
|
|
||||||
void* Network_Channel = *(void**)(*(unsigned __int32*)((unsigned __int32)Engine_Module + 4352236) + 24);
|
void* Network_Channel = *(void**)(*(unsigned __int32*)((unsigned __int32)Engine_Module + 4352236) + 24);
|
||||||
|
|
||||||
auto Sequence_Shift = [&](__int32 Reserve) -> void
|
auto Sequence_Shift = [&](__int32 Reserve) -> void
|
||||||
{
|
{
|
||||||
if (Extended_Commands[*(__int32*)((unsigned __int32)Local_Player + 20) % 150].Sequence_Shift == 0)
|
if (Initial_Extended_Command->Sequence_Shift == 0)
|
||||||
{
|
{
|
||||||
__int32 Sequence_Shift = (*(__int32*)((unsigned __int32)Local_Player + 5324) + ~-150) / 150 * 150 + (Reserve * 150);
|
__int32 Sequence_Shift = (*(__int32*)((unsigned __int32)Local_Player + 5324) - Extended_Command->Extra_Commands + ~-150) / 150 * 150 + (Reserve * 150);
|
||||||
|
|
||||||
if (Sequence_Shift > 0)
|
if (Sequence_Shift > 0)
|
||||||
{
|
{
|
||||||
@ -216,33 +225,95 @@ void __thiscall Redirected_Copy_Command(void* Unknown_Parameter, Command_Structu
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static __int32 Accumulative_Correction;
|
||||||
|
|
||||||
|
auto Disable_Clock_Correction = [&](__int32 Queue) -> void
|
||||||
|
{
|
||||||
|
if (Queue > 0)
|
||||||
|
{
|
||||||
|
if (Extended_Command == Initial_Extended_Command)
|
||||||
|
{
|
||||||
|
Extended_Command->Extra_Commands = 0;
|
||||||
|
|
||||||
|
Extra_Commands = max((__int32)(0.06f / Global_Variables->Interval_Per_Tick + 0.5f), Queue);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Accumulative_Correction += 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Initial_Extended_Command->Extra_Commands == 0)
|
||||||
|
{
|
||||||
|
*(__int32*)((unsigned __int32)Network_Channel + 16) = -1;
|
||||||
|
|
||||||
|
*(__int32*)((unsigned __int32)Network_Channel + 28) = 255;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
auto Correct_Extended_Command = [&]() -> void
|
||||||
|
{
|
||||||
|
if (*(__int32*)((unsigned __int32)Network_Channel + 16) != -1)
|
||||||
|
{
|
||||||
|
Extended_Command->Extra_Commands += Accumulative_Correction;
|
||||||
|
|
||||||
|
Accumulative_Correction = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
Extended_Command->Sequence_Shift = Initial_Extended_Command->Sequence_Shift;
|
||||||
|
};
|
||||||
|
|
||||||
if (*(__int32*)((unsigned __int32)Local_Player + 228) == 3)
|
if (*(__int32*)((unsigned __int32)Local_Player + 228) == 3)
|
||||||
{
|
{
|
||||||
if (*(__int8*)((unsigned __int32)Local_Player + 7322) == 1)
|
if (*(__int8*)((unsigned __int32)Local_Player + 7322) == 0)
|
||||||
|
{
|
||||||
|
if (*(void**)((unsigned __int32)Local_Player + 10008) == INVALID_HANDLE_VALUE)
|
||||||
|
{
|
||||||
|
__int8 Is_Jockey_Victim = *(void**)((unsigned __int32)Local_Player + 10056) != INVALID_HANDLE_VALUE;
|
||||||
|
|
||||||
|
if ((*(void**)((unsigned __int32)Local_Player + 10012) != INVALID_HANDLE_VALUE) + (*(void**)((unsigned __int32)Local_Player + 10024) != INVALID_HANDLE_VALUE) + Is_Jockey_Victim != 0)
|
||||||
|
{
|
||||||
|
Command->Buttons |= Is_Jockey_Victim * 2;
|
||||||
|
|
||||||
|
Disable_Clock_Correction(Interface_Extra_Commands_Action.Integer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Sequence_Shift(2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
if (*(__int32*)((unsigned __int32)Local_Player + 7324) == 0)
|
if (*(__int32*)((unsigned __int32)Local_Player + 7324) == 0)
|
||||||
{
|
{
|
||||||
Sequence_Shift(-2);
|
Sequence_Shift(-2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
if (*(void**)((unsigned __int32)Local_Player + 10008) != INVALID_HANDLE_VALUE)
|
|
||||||
{
|
|
||||||
Sequence_Shift(2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Extended_Command->Sequence_Shift = Extended_Commands[*(__int32*)((unsigned __int32)Local_Player + 20) % 150].Sequence_Shift;
|
Correct_Extended_Command();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
__int8 Action = *(void**)((unsigned __int32)Local_Player + 7076) == *(void**)((unsigned __int32)Local_Player + 376);
|
||||||
|
|
||||||
|
__int8 Reviving = *(void**)((unsigned __int32)Local_Player + 8076) != INVALID_HANDLE_VALUE;
|
||||||
|
|
||||||
if ((*(float*)((unsigned __int32)Local_Player + 4604) + 800.f * Global_Variables->Interval_Per_Tick >= 560.f) + *(__int8*)((unsigned __int32)Local_Player + 8068) + *(__int8*)((unsigned __int32)Local_Player + 9708) != 0)
|
if ((*(float*)((unsigned __int32)Local_Player + 4604) + 800.f * Global_Variables->Interval_Per_Tick >= 560.f) + *(__int8*)((unsigned __int32)Local_Player + 8068) + *(__int8*)((unsigned __int32)Local_Player + 9708) != 0)
|
||||||
{
|
{
|
||||||
Sequence_Shift(2);
|
Sequence_Shift(2);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (Action + Reviving != 0)
|
||||||
|
{
|
||||||
|
Disable_Clock_Correction(Interface_Extra_Commands_Action.Integer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Extended_Command->Sequence_Shift = Extended_Commands[*(__int32*)((unsigned __int32)Local_Player + 20) % 150].Sequence_Shift;
|
Correct_Extended_Command();
|
||||||
|
|
||||||
|
*(__int32*)((unsigned __int32)Local_Player + 5620) = Command->Command_Number;
|
||||||
|
|
||||||
void* Prediction = (void*)((unsigned __int32)Client_Module + 8072728);
|
void* Prediction = (void*)((unsigned __int32)Client_Module + 8072728);
|
||||||
|
|
||||||
@ -264,7 +335,7 @@ void __thiscall Redirected_Copy_Command(void* Unknown_Parameter, Command_Structu
|
|||||||
|
|
||||||
if ((*(__int32*)((unsigned __int32)Local_Player + 324) & 9) == 0)
|
if ((*(__int32*)((unsigned __int32)Local_Player + 324) & 9) == 0)
|
||||||
{
|
{
|
||||||
if ((*(__int32*)((unsigned __int32)Local_Player + 5020) & 32) == 0)
|
if ((*(__int32*)((unsigned __int32)Local_Player + 5020) & 32) * (Action ^ 1) == 0)
|
||||||
{
|
{
|
||||||
using Can_Attack_Type = __int8(__thiscall*)(void* Player);
|
using Can_Attack_Type = __int8(__thiscall*)(void* Player);
|
||||||
|
|
||||||
@ -278,6 +349,59 @@ void __thiscall Redirected_Copy_Command(void* Unknown_Parameter, Command_Structu
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
__int8 Cancelable_Shove = 1 + (*(float*)((unsigned __int32)Local_Player + 7336) < Global_Variables->Current_Time) * (*(float*)((unsigned __int32)Weapon + 2404) <= Global_Variables->Current_Time);
|
||||||
|
|
||||||
|
__int32 Weapon_Identifier = Get_Identifier(Weapon, 1, 0);
|
||||||
|
|
||||||
|
if ((Weapon_Identifier == 105) + (Weapon_Identifier == 121) == 0)
|
||||||
|
{
|
||||||
|
static std::unordered_set<__int32> Grenades = { 106, 118, 129 };
|
||||||
|
|
||||||
|
if (Grenades.contains(Weapon_Identifier) == 1)
|
||||||
|
{
|
||||||
|
Cancelable_Shove = min((*(__int16*)((unsigned __int32)Weapon + 3304) == 0) + (*(float*)((unsigned __int32)Weapon + 3308) == 0.f), Cancelable_Shove);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Cancelable_Shove = min(1 + (*(float*)((unsigned __int32)Weapon + 3312) == -1.f), Cancelable_Shove);
|
||||||
|
}
|
||||||
|
|
||||||
|
__int8 In_Shove = Global_Variables->Current_Time >= *(float*)((unsigned __int32)Local_Player + 7904);
|
||||||
|
|
||||||
|
if (Global_Variables->Current_Time >= *(float*)((unsigned __int32)Weapon + 2704))
|
||||||
|
{
|
||||||
|
In_Shove = *(__int8*)((unsigned __int32)Weapon + 2720);
|
||||||
|
}
|
||||||
|
|
||||||
|
__int32 Ammo = *(__int32*)((unsigned __int32)Weapon + 2436);
|
||||||
|
|
||||||
|
static void* Predicted_Shot;
|
||||||
|
|
||||||
|
using Get_Weapon_Data_Type = void*(__thiscall*)(void* Weapon);
|
||||||
|
|
||||||
|
void* Weapon_Data = Get_Weapon_Data_Type((unsigned __int32)Client_Module + 86432)(Weapon);
|
||||||
|
|
||||||
|
__int8 Is_Melee = *(__int32*)((unsigned __int32)Weapon_Data + 352) * (*(__int32*)((unsigned __int32)Weapon_Data + 348) ^ 1) <= 1;
|
||||||
|
|
||||||
|
__int8 Reloading = *(__int8*)((unsigned __int32)Weapon + 2493);
|
||||||
|
|
||||||
|
__int8 Can_Attack = 0;
|
||||||
|
|
||||||
|
if (Weapon_Identifier == 39)
|
||||||
|
{
|
||||||
|
Can_Attack = (min(Chainsaw_Cycles * 0.46153846f * Global_Variables->Interval_Per_Tick, 1.f) > 0.95f) * (In_Shove ^ 1);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Can_Attack = (*(float*)((unsigned __int32)Weapon + 2400) <= Global_Variables->Current_Time) * (Ammo > 0 - Is_Melee * 2) * (Reloading ^ 1);
|
||||||
|
|
||||||
|
if ((*(double*)((unsigned __int32)Weapon + 3392) == 0.) * Weapon_Identifier == 153)
|
||||||
|
{
|
||||||
|
Can_Attack *= *(float*)((unsigned __int32)Weapon + 3400) <= Global_Variables->Current_Time;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
__int32 Entity_Number = 1;
|
__int32 Entity_Number = 1;
|
||||||
|
|
||||||
using Get_Interpolation_Time_Type = float(__cdecl*)();
|
using Get_Interpolation_Time_Type = float(__cdecl*)();
|
||||||
@ -377,146 +501,168 @@ void __thiscall Redirected_Copy_Command(void* Unknown_Parameter, Command_Structu
|
|||||||
|
|
||||||
size_t Target_Number = 0;
|
size_t Target_Number = 0;
|
||||||
|
|
||||||
using Get_Weapon_Data_Type = void*(__thiscall*)(void* Weapon);
|
|
||||||
|
|
||||||
void* Weapon_Data = Get_Weapon_Data_Type((unsigned __int32)Client_Module + 86432)(Weapon);
|
|
||||||
|
|
||||||
__int8 Is_Melee = *(__int32*)((unsigned __int32)Weapon_Data + 352) * (*(__int32*)((unsigned __int32)Weapon_Data + 348) ^ 1) <= 1;
|
|
||||||
|
|
||||||
__int8 Action = *(__int32*)((unsigned __int32)Local_Player + 7080) != 0;
|
|
||||||
|
|
||||||
__int8 Reviving = *(void**)((unsigned __int32)Local_Player + 8076) != INVALID_HANDLE_VALUE;
|
|
||||||
|
|
||||||
__int32 Weapon_Identifier = Get_Identifier(Weapon, 1, 0);
|
|
||||||
|
|
||||||
__int8 Is_Cold_Melee = Weapon_Identifier == 231;
|
|
||||||
|
|
||||||
using Get_Eye_Position_Type = void(__thiscall*)(void* Entity, float* Eye_Position);
|
using Get_Eye_Position_Type = void(__thiscall*)(void* Entity, float* Eye_Position);
|
||||||
|
|
||||||
float Eye_Position[3];
|
float Eye_Position[3];
|
||||||
|
|
||||||
Get_Eye_Position_Type((unsigned __int32)Client_Module + 108512)(Local_Player, Eye_Position);
|
Get_Eye_Position_Type((unsigned __int32)Client_Module + 108512)(Local_Player, Eye_Position);
|
||||||
|
|
||||||
__int8 Cancelable_Shove = 1 + (*(float*)((unsigned __int32)Local_Player + 7336) < Global_Variables->Current_Time);
|
|
||||||
|
|
||||||
Target_Structure* Shove_Target = nullptr;
|
Target_Structure* Shove_Target = nullptr;
|
||||||
|
|
||||||
Shove_Traverse_Sorted_Target_List_Label:
|
if (Cancelable_Shove + In_Shove > 1)
|
||||||
{
|
{
|
||||||
if (Target_Number != Sorted_Target_List.size())
|
if (*(__int8*)((unsigned __int32)Local_Player + 8070) * (Weapon_Identifier == 231) == 0)
|
||||||
{
|
{
|
||||||
Target_Structure* Target = &Sorted_Target_List.at(Target_Number);
|
if (Interface_Shotgun_Shove.Integer == 1)
|
||||||
|
|
||||||
__int8 Forced = 0;
|
|
||||||
|
|
||||||
if ((*(__int8*)((unsigned __int32)Weapon + 2493) + Is_Melee) * (Action + Reviving ^ 1) != 0)
|
|
||||||
{
|
{
|
||||||
if ((Target->Identifier ^ 72) % 348 >= 72)
|
if ((Weapon_Identifier - 148) % 14 == 0)
|
||||||
{
|
{
|
||||||
Forced = 1;
|
if ((void*)((unsigned __int32)Weapon + Ammo) == Predicted_Shot)
|
||||||
|
|
||||||
goto Shove_Label;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (((270 - Is_Cold_Melee - (*(__int8*)((unsigned __int32)Local_Player + 8070) ^ 1) - Target->Identifier) ^ Target->Identifier - 263) > 0)
|
|
||||||
{
|
|
||||||
Shove_Label:
|
|
||||||
{
|
|
||||||
__int8 Infected = (Target->Identifier == 264) * (Forced ^ 1);
|
|
||||||
|
|
||||||
__int32 Gender = *(__int32*)((unsigned __int32)Target->Self + 52);
|
|
||||||
|
|
||||||
if ((Infected ^ 1) + (Gender == 15) != 0)
|
|
||||||
{
|
{
|
||||||
using Get_Sequence_Name_Type = char*(__thiscall*)(void* Entity, __int32 Sequence);
|
Predicted_Shot = nullptr;
|
||||||
|
|
||||||
if (__builtin_strstr(Get_Sequence_Name_Type((unsigned __int32)Client_Module + 203392)(Target->Self, *(__int32*)((unsigned __int32)Target->Self + 2212)), "hove") == nullptr)
|
Command->Buttons |= 2048;
|
||||||
{
|
|
||||||
using Perform_Shove_Trace = __int8(__thiscall*)(void* Weapon, float* Direction);
|
|
||||||
|
|
||||||
float* Target_Origin = Get_Center(Target->Self);
|
Block_Buttons = 1;
|
||||||
|
|
||||||
float Direction[3] =
|
|
||||||
{
|
|
||||||
Target_Origin[0] - Eye_Position[0],
|
|
||||||
|
|
||||||
Target_Origin[1] - Eye_Position[1],
|
|
||||||
|
|
||||||
Target_Origin[2] - Eye_Position[2]
|
|
||||||
};
|
|
||||||
|
|
||||||
Vector_Normalize(Direction);
|
|
||||||
|
|
||||||
*(float*)((unsigned __int32)Weapon + 2724) = 75.f;
|
|
||||||
|
|
||||||
*(__int32*)((unsigned __int32)Weapon + 3248) = 0;
|
|
||||||
|
|
||||||
Perform_Trace_Target = Target->Self;
|
|
||||||
|
|
||||||
Perform_Trace_Damage = 0;
|
|
||||||
|
|
||||||
Perform_Shove_Trace((unsigned __int32)Client_Module + 3220512)(Weapon, Direction);
|
|
||||||
|
|
||||||
Perform_Trace_Target = nullptr;
|
|
||||||
|
|
||||||
if (Perform_Trace_Damage == 1)
|
|
||||||
{
|
|
||||||
if (Action == 0)
|
|
||||||
{
|
|
||||||
Command->Tick_Number = Target->Tick_Number;
|
|
||||||
|
|
||||||
Command->Angles[0] = __builtin_atan2f(-Direction[2], __builtin_hypotf(Direction[0], Direction[1])) * 180.f / 3.1415927f;
|
|
||||||
|
|
||||||
Command->Angles[1] = __builtin_atan2f(Direction[1], Direction[0]) * 180.f / 3.1415927f;
|
|
||||||
|
|
||||||
if (Cancelable_Shove == 1)
|
|
||||||
{
|
|
||||||
float Shove_Multiplier = min((Global_Variables->Current_Time - *(float*)((unsigned __int32)Weapon + 2704) + *(float*)((unsigned __int32)Weapon + 2700)) / *(float*)((unsigned __int32)Weapon + 2700), 1.f);
|
|
||||||
|
|
||||||
Command->Angles[1] += -45.f * Shove_Multiplier + 45.f * (1.f - Shove_Multiplier);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
Command->Angles[1] += 45.f;
|
|
||||||
}
|
|
||||||
|
|
||||||
Command->Buttons |= 2048;
|
|
||||||
|
|
||||||
Block_Buttons = 1;
|
|
||||||
|
|
||||||
Cancelable_Shove = (Gender * Interface_Riot_Deprioritize.Integer * (Forced ^ 1)) == 15;
|
|
||||||
|
|
||||||
*(float*)((unsigned __int32)Target->Self + 16) = Get_Target_Time(Target);
|
|
||||||
|
|
||||||
goto Shove_Found_Target_Label;
|
|
||||||
}
|
|
||||||
|
|
||||||
Cancelable_Shove = 0;
|
|
||||||
|
|
||||||
goto Shove_Found_Target_Label;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Target_Number += 1;
|
__int8 Is_Chainsaw = Weapon_Identifier == 39;
|
||||||
|
|
||||||
goto Shove_Traverse_Sorted_Target_List_Label;
|
__int8 Holstering = 0;
|
||||||
|
|
||||||
Shove_Found_Target_Label:
|
if (Is_Chainsaw == 0)
|
||||||
{
|
{
|
||||||
Shove_Target = Target;
|
using Get_Sequence_Duration_Type = float(__thiscall*)(void* Entity, void* Studio_Header, __int32 Sequence);
|
||||||
|
|
||||||
|
using Select_Sequence_Type = __int32(__thiscall*)(void* Entity, __int32 Activity);
|
||||||
|
|
||||||
|
using Get_Deploy_Activity_Type = __int32(__thiscall**)(void* Weapon);
|
||||||
|
|
||||||
|
using Translate_Activity_Type = __int32(__thiscall**)(void* Weapon, __int32 Activity);
|
||||||
|
|
||||||
|
Holstering = (min(*(float*)((unsigned __int32)Local_Player + 3872), *(float*)((unsigned __int32)Weapon + 2412)) + Get_Sequence_Duration_Type((unsigned __int32)Client_Module + 180400)(Weapon, Get_Studio_Header(Weapon), Select_Sequence_Type((unsigned __int32)Client_Module + 202896)(Weapon, (*Translate_Activity_Type(*(unsigned __int32*)Weapon + 1692))(Weapon, (*Get_Deploy_Activity_Type(*(unsigned __int32*)Weapon + 1600))(Weapon)))) > Global_Variables->Current_Time) * (Can_Attack ^ 1);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Is_Chainsaw = Can_Attack * (Command->Buttons & 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
Shove_Traverse_Sorted_Target_List_Label:
|
||||||
|
{
|
||||||
|
if (Target_Number != Sorted_Target_List.size())
|
||||||
|
{
|
||||||
|
Target_Structure* Target = &Sorted_Target_List.at(Target_Number);
|
||||||
|
|
||||||
|
__int8 Forced = 0;
|
||||||
|
|
||||||
|
if (((Command->Buttons & 2048) + Reloading + Holstering + Is_Melee * (Is_Chainsaw ^ 1)) * (Action + Reviving ^ 1) != 0)
|
||||||
|
{
|
||||||
|
if ((Target->Identifier ^ 72) % 348 >= 72)
|
||||||
|
{
|
||||||
|
Forced = 1;
|
||||||
|
|
||||||
|
goto Shove_Label;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((270 - Target->Identifier ^ Target->Identifier - 263) >= 0)
|
||||||
|
{
|
||||||
|
Shove_Label:
|
||||||
|
{
|
||||||
|
__int8 Infected = (Target->Identifier == 264) * (Forced ^ 1);
|
||||||
|
|
||||||
|
__int32 Gender = *(__int32*)((unsigned __int32)Target->Self + 52);
|
||||||
|
|
||||||
|
if ((Infected ^ 1) + (Gender == 15) != 0)
|
||||||
|
{
|
||||||
|
if (__builtin_strstr(Get_Sequence_Name(Target->Self), "hove") == nullptr)
|
||||||
|
{
|
||||||
|
using Perform_Shove_Trace = __int8(__thiscall*)(void* Weapon, float* Direction);
|
||||||
|
|
||||||
|
float* Target_Origin = Get_Center(Target->Self);
|
||||||
|
|
||||||
|
float Direction[3] =
|
||||||
|
{
|
||||||
|
Target_Origin[0] - Eye_Position[0],
|
||||||
|
|
||||||
|
Target_Origin[1] - Eye_Position[1],
|
||||||
|
|
||||||
|
Target_Origin[2] - Eye_Position[2]
|
||||||
|
};
|
||||||
|
|
||||||
|
Vector_Normalize(Direction);
|
||||||
|
|
||||||
|
*(float*)((unsigned __int32)Weapon + 2724) = 75.f;
|
||||||
|
|
||||||
|
*(__int32*)((unsigned __int32)Weapon + 3248) = 0;
|
||||||
|
|
||||||
|
Perform_Trace_Target = Target->Self;
|
||||||
|
|
||||||
|
Perform_Trace_Damage = 0.f;
|
||||||
|
|
||||||
|
Perform_Shove_Trace((unsigned __int32)Client_Module + 3220512)(Weapon, Direction);
|
||||||
|
|
||||||
|
Perform_Trace_Target = nullptr;
|
||||||
|
|
||||||
|
if (Perform_Trace_Damage == 1.f)
|
||||||
|
{
|
||||||
|
if (Action == 0)
|
||||||
|
{
|
||||||
|
Command->Tick_Number = Target->Tick_Number;
|
||||||
|
|
||||||
|
Command->Angles[0] = __builtin_atan2f(-Direction[2], __builtin_hypotf(Direction[0], Direction[1])) * 180.f / 3.1415927f;
|
||||||
|
|
||||||
|
Command->Angles[1] = __builtin_atan2f(Direction[1], Direction[0]) * 180.f / 3.1415927f;
|
||||||
|
|
||||||
|
if (Cancelable_Shove == 1)
|
||||||
|
{
|
||||||
|
float Shove_Multiplier = min((Global_Variables->Current_Time - *(float*)((unsigned __int32)Weapon + 2704) + *(float*)((unsigned __int32)Weapon + 2700)) / *(float*)((unsigned __int32)Weapon + 2700), 1.f);
|
||||||
|
|
||||||
|
Command->Angles[1] += -45.f * Shove_Multiplier + 45.f * (1.f - Shove_Multiplier);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Command->Angles[1] += 45.f;
|
||||||
|
}
|
||||||
|
|
||||||
|
Command->Buttons |= 2048;
|
||||||
|
|
||||||
|
Block_Buttons = 1;
|
||||||
|
|
||||||
|
Cancelable_Shove = (Gender * Interface_Riot_Deprioritize.Integer * (Forced ^ 1)) == 15;
|
||||||
|
|
||||||
|
*(float*)((unsigned __int32)Target->Self + 16) = Get_Target_Time(Target);
|
||||||
|
|
||||||
|
goto Shove_Found_Target_Label;
|
||||||
|
}
|
||||||
|
|
||||||
|
Cancelable_Shove = 0;
|
||||||
|
|
||||||
|
goto Shove_Found_Target_Label;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Target_Number += 1;
|
||||||
|
|
||||||
|
goto Shove_Traverse_Sorted_Target_List_Label;
|
||||||
|
|
||||||
|
Shove_Found_Target_Label:
|
||||||
|
{
|
||||||
|
Shove_Target = Target;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Cancelable_Shove != 0)
|
if (Cancelable_Shove != 0)
|
||||||
{
|
{
|
||||||
__int8 Can_Attack = (*(float*)((unsigned __int32)Weapon + 2400) <= Global_Variables->Current_Time) * (*(__int32*)((unsigned __int32)Weapon + 2436) > 0 - Is_Melee * 2) * (*(float*)((unsigned __int32)Local_Player + 3872) <= Global_Variables->Current_Time);
|
if (Reviving + (Can_Attack ^ 1) == 0)
|
||||||
|
|
||||||
if (Reviving + (Weapon_Identifier == 96) + (Can_Attack ^ 1) == 0)
|
|
||||||
{
|
{
|
||||||
Target_Structure* Aim_Target = nullptr;
|
Target_Structure* Aim_Target = nullptr;
|
||||||
|
|
||||||
@ -542,12 +688,9 @@ void __thiscall Redirected_Copy_Command(void* Unknown_Parameter, Command_Structu
|
|||||||
{
|
{
|
||||||
if (Weapon_Identifier == 153)
|
if (Weapon_Identifier == 153)
|
||||||
{
|
{
|
||||||
if (*(double*)((unsigned __int32)Weapon + 3392) != 0.)
|
Compensate_Burst = *(double*)((unsigned __int32)Weapon + 3392) != 0.;
|
||||||
{
|
|
||||||
Compensate_Burst = 1;
|
|
||||||
|
|
||||||
Command->Buttons |= 1;
|
Command->Buttons |= Compensate_Burst;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -595,7 +738,7 @@ void __thiscall Redirected_Copy_Command(void* Unknown_Parameter, Command_Structu
|
|||||||
|
|
||||||
Perform_Trace_Target = Target->Self;
|
Perform_Trace_Target = Target->Self;
|
||||||
|
|
||||||
Perform_Trace_Damage = 0;
|
Perform_Trace_Damage = 0.f;
|
||||||
|
|
||||||
void* Previous_Audio_Device = *(void**)((unsigned __int32)Engine_Module + 5050008);
|
void* Previous_Audio_Device = *(void**)((unsigned __int32)Engine_Module + 5050008);
|
||||||
|
|
||||||
@ -629,7 +772,7 @@ void __thiscall Redirected_Copy_Command(void* Unknown_Parameter, Command_Structu
|
|||||||
|
|
||||||
*(__int32*)((unsigned __int32)Weapon_Data + 2520) = Bullets;
|
*(__int32*)((unsigned __int32)Weapon_Data + 2520) = Bullets;
|
||||||
|
|
||||||
return (Perform_Trace_Damage >= Interface_Penetration_Damage.Floating_Point) * (Perform_Trace_Damage != 0);
|
return (Perform_Trace_Damage >= Interface_Penetration_Damage.Floating_Point) * (Perform_Trace_Damage != 0.f);
|
||||||
};
|
};
|
||||||
|
|
||||||
static std::unordered_map<__int32, __int32> Hitboxes =
|
static std::unordered_map<__int32, __int32> Hitboxes =
|
||||||
@ -752,6 +895,8 @@ void __thiscall Redirected_Copy_Command(void* Unknown_Parameter, Command_Structu
|
|||||||
Command->Angles[2] -= Recoil[2];
|
Command->Angles[2] -= Recoil[2];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Predicted_Shot = (void*)((unsigned __int32)Weapon + Ammo - 1);
|
||||||
|
|
||||||
Block_Buttons = 2048;
|
Block_Buttons = 2048;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -772,7 +917,7 @@ void __thiscall Redirected_Copy_Command(void* Unknown_Parameter, Command_Structu
|
|||||||
|
|
||||||
Correct_Movement();
|
Correct_Movement();
|
||||||
|
|
||||||
*(__int8*)((unsigned __int32)__builtin_frame_address(0) + 235) = Extra_Commands <= 0;
|
*(__int8*)((unsigned __int32)__builtin_frame_address(0) + 235) = max(Extra_Commands <= 0, *(__int32*)((unsigned __int32)Network_Channel + 16) == -1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -64,4 +64,8 @@ void Redirected_Draw_Crosshair()
|
|||||||
}
|
}
|
||||||
|
|
||||||
Rotation_Angle = __builtin_remainderf(Rotation_Angle + (*(Global_Variables_Structure**)((unsigned __int32)Client_Module + 7096744))->Frame_Time * Interface_Storm_Speed.Integer, 360.f);
|
Rotation_Angle = __builtin_remainderf(Rotation_Angle + (*(Global_Variables_Structure**)((unsigned __int32)Client_Module + 7096744))->Frame_Time * Interface_Storm_Speed.Integer, 360.f);
|
||||||
|
|
||||||
|
using Get_Display_Type = void*(__cdecl*)();
|
||||||
|
|
||||||
|
*(__int32*)((unsigned __int32)Get_Display_Type((unsigned __int32)Client_Module + 2930128)() + 400) = 0;
|
||||||
}
|
}
|
@ -196,7 +196,7 @@ __int32 __stdcall DllMain(HMODULE This_Module, unsigned __int32 Call_Reason, voi
|
|||||||
|
|
||||||
_putws(L"[ + ] Animations");
|
_putws(L"[ + ] Animations");
|
||||||
{
|
{
|
||||||
Redirection_Manager::Redirect_Function(1, (void*)((unsigned __int32)Client_Module + 205296), (void*)Redirected_Update_Animations);
|
Redirection_Manager::Redirect_Function((void*)((unsigned __int32)Client_Module + 205296), (void*)Redirected_Update_Animations);
|
||||||
|
|
||||||
Original_Estimate_Velocity_Caller = Redirection_Manager::Redirect_Function(0, (void*)((unsigned __int32)Client_Module + 311856), (void*)Redirected_Estimate_Velocity);
|
Original_Estimate_Velocity_Caller = Redirection_Manager::Redirect_Function(0, (void*)((unsigned __int32)Client_Module + 311856), (void*)Redirected_Estimate_Velocity);
|
||||||
|
|
||||||
@ -247,7 +247,7 @@ __int32 __stdcall DllMain(HMODULE This_Module, unsigned __int32 Call_Reason, voi
|
|||||||
|
|
||||||
Original_Perform_Shove_Trace_Caller = (void*)((unsigned __int32)Client_Module + 3221111);
|
Original_Perform_Shove_Trace_Caller = (void*)((unsigned __int32)Client_Module + 3221111);
|
||||||
|
|
||||||
Redirection_Manager::Redirect_Function(1, (void*)((unsigned __int32)Client_Module + 3221102), (void*)Redirected_Perform_Shove_Trace);
|
Redirection_Manager::Redirect_Function((void*)((unsigned __int32)Client_Module + 3221102), (void*)Redirected_Perform_Shove_Trace);
|
||||||
}
|
}
|
||||||
|
|
||||||
_putws(L"[ + ] Network");
|
_putws(L"[ + ] Network");
|
||||||
@ -256,7 +256,7 @@ __int32 __stdcall DllMain(HMODULE This_Module, unsigned __int32 Call_Reason, voi
|
|||||||
|
|
||||||
Original_Move_Caller = Redirection_Manager::Redirect_Function(3, (void*)((unsigned __int32)Engine_Module + 512288), (void*)Redirected_Move);
|
Original_Move_Caller = Redirection_Manager::Redirect_Function(3, (void*)((unsigned __int32)Engine_Module + 512288), (void*)Redirected_Move);
|
||||||
|
|
||||||
Redirection_Manager::Redirect_Function(1, (void*)((unsigned __int32)Engine_Module + 511680), (void*)Redirected_Send_Move);
|
Redirection_Manager::Redirect_Function((void*)((unsigned __int32)Engine_Module + 511680), (void*)Redirected_Send_Move);
|
||||||
}
|
}
|
||||||
|
|
||||||
_putws(L"[ + ] Input");
|
_putws(L"[ + ] Input");
|
||||||
@ -270,6 +270,8 @@ __int32 __stdcall DllMain(HMODULE This_Module, unsigned __int32 Call_Reason, voi
|
|||||||
|
|
||||||
_putws(L"[ + ] Effects");
|
_putws(L"[ + ] Effects");
|
||||||
{
|
{
|
||||||
|
Byte_Manager::Set_Bytes(0, (void*)((unsigned __int32)Client_Module + 407384), 1, 133);
|
||||||
|
|
||||||
Original_Calculate_View_Caller = Redirection_Manager::Redirect_Function(0, (void*)((unsigned __int32)Client_Module + 132944), (void*)Redirected_Calculate_View);
|
Original_Calculate_View_Caller = Redirection_Manager::Redirect_Function(0, (void*)((unsigned __int32)Client_Module + 132944), (void*)Redirected_Calculate_View);
|
||||||
|
|
||||||
Byte_Manager::Set_Bytes(0, (void*)((unsigned __int32)Client_Module + 133424), 1, 235);
|
Byte_Manager::Set_Bytes(0, (void*)((unsigned __int32)Client_Module + 133424), 1, 235);
|
||||||
@ -289,17 +291,17 @@ __int32 __stdcall DllMain(HMODULE This_Module, unsigned __int32 Call_Reason, voi
|
|||||||
{
|
{
|
||||||
Original_Write_Texture_Caller = Redirection_Manager::Redirect_Function(0, (void*)((unsigned __int32)GetModuleHandleW(L"vguimatsurface.dll") + 100592), (void*)Redirected_Write_Texture);
|
Original_Write_Texture_Caller = Redirection_Manager::Redirect_Function(0, (void*)((unsigned __int32)GetModuleHandleW(L"vguimatsurface.dll") + 100592), (void*)Redirected_Write_Texture);
|
||||||
|
|
||||||
Redirection_Manager::Redirect_Function(1, (void*)((unsigned __int32)Client_Module + 2913504), (void*)Redirected_Paint);
|
Redirection_Manager::Redirect_Function((void*)((unsigned __int32)Client_Module + 2913504), (void*)Redirected_Paint);
|
||||||
|
|
||||||
Original_Get_Glow_Color_Caller = Redirection_Manager::Redirect_Function(1, (void*)((unsigned __int32)Client_Module + 2455600), (void*)Redirected_Get_Glow_Color);
|
Original_Get_Glow_Color_Caller = Redirection_Manager::Redirect_Function(1, (void*)((unsigned __int32)Client_Module + 2455600), (void*)Redirected_Get_Glow_Color);
|
||||||
|
|
||||||
Byte_Manager::Set_Bytes(0, (void*)((unsigned __int32)Client_Module + 3244715), 1, 49);
|
Byte_Manager::Set_Bytes(0, (void*)((unsigned __int32)Client_Module + 3244715), 1, 49);
|
||||||
|
|
||||||
Redirection_Manager::Redirect_Function(1, (void*)((unsigned __int32)Client_Module + 2301184), (void*)Redirected_Draw_Crosshair);
|
Redirection_Manager::Redirect_Function((void*)((unsigned __int32)Client_Module + 2301184), (void*)Redirected_Draw_Crosshair);
|
||||||
|
|
||||||
Byte_Manager::Set_Bytes(0, (void*)((unsigned __int32)Client_Module + 2930985), 1, 235);
|
Byte_Manager::Set_Bytes(0, (void*)((unsigned __int32)Client_Module + 2930985), 1, 235);
|
||||||
|
|
||||||
Redirection_Manager::Redirect_Function(1, (void*)((unsigned __int32)Client_Module + 3118720), (void*)Redirected_Draw_Crosshair);
|
Redirection_Manager::Redirect_Function((void*)((unsigned __int32)Client_Module + 3118720), (void*)Redirected_Draw_Crosshair);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,3 +1,10 @@
|
|||||||
|
char* Get_Sequence_Name(void* Entity)
|
||||||
|
{
|
||||||
|
using Get_Sequence_Name_Type = char*(__thiscall*)(void* Entity, __int32 Sequence);
|
||||||
|
|
||||||
|
return Get_Sequence_Name_Type((unsigned __int32)Client_Module + 203392)(Entity, *(__int32*)((unsigned __int32)Entity + 2212));
|
||||||
|
}
|
||||||
|
|
||||||
__int32 Get_Identifier(void* Entity, __int8 Raw, __int8 Equipment)
|
__int32 Get_Identifier(void* Entity, __int8 Raw, __int8 Equipment)
|
||||||
{
|
{
|
||||||
using Get_Identifier_Type = void*(__cdecl**)();
|
using Get_Identifier_Type = void*(__cdecl**)();
|
||||||
@ -9,32 +16,7 @@ __int32 Get_Identifier(void* Entity, __int8 Raw, __int8 Equipment)
|
|||||||
return Identifier;
|
return Identifier;
|
||||||
}
|
}
|
||||||
|
|
||||||
static std::unordered_set<__int32> Targets =
|
static std::unordered_set<__int32> Targets = { 0, 13, 99, 232, 263, 264, 265, 270, 272, 275, 276, 277 };
|
||||||
{
|
|
||||||
0,
|
|
||||||
|
|
||||||
13,
|
|
||||||
|
|
||||||
99,
|
|
||||||
|
|
||||||
232,
|
|
||||||
|
|
||||||
263,
|
|
||||||
|
|
||||||
264,
|
|
||||||
|
|
||||||
265,
|
|
||||||
|
|
||||||
270,
|
|
||||||
|
|
||||||
272,
|
|
||||||
|
|
||||||
275,
|
|
||||||
|
|
||||||
276,
|
|
||||||
|
|
||||||
277
|
|
||||||
};
|
|
||||||
|
|
||||||
if (Targets.contains(Identifier) == 1)
|
if (Targets.contains(Identifier) == 1)
|
||||||
{
|
{
|
||||||
@ -52,11 +34,9 @@ __int32 Get_Identifier(void* Entity, __int8 Raw, __int8 Equipment)
|
|||||||
{
|
{
|
||||||
if ((*(__int32*)((unsigned __int32)Entity + 572) - 131088 & 255) == 0)
|
if ((*(__int32*)((unsigned __int32)Entity + 572) - 131088 & 255) == 0)
|
||||||
{
|
{
|
||||||
using Get_Sequence_Name_Type = char*(__thiscall*)(void* Entity, __int32 Sequence);
|
if (__builtin_strstr(Get_Sequence_Name(Entity), "eath") == nullptr)
|
||||||
|
|
||||||
if (__builtin_strstr(Get_Sequence_Name_Type((unsigned __int32)Client_Module + 203392)(Entity, *(__int32*)((unsigned __int32)Entity + 2212)), "eath") == nullptr)
|
|
||||||
{
|
{
|
||||||
Valid = 1;
|
Valid = Identifier == 264 ? *(__int8*)((unsigned __int32)Entity + 4493) ^ 1 : 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -93,20 +73,7 @@ __int32 Get_Identifier(void* Entity, __int8 Raw, __int8 Equipment)
|
|||||||
{
|
{
|
||||||
if (Equipment == 1)
|
if (Equipment == 1)
|
||||||
{
|
{
|
||||||
static std::unordered_set<__int32> Equipment_List =
|
static std::unordered_set<__int32> Equipment_List = { 73, 105, 109, 121, 256, 260 };
|
||||||
{
|
|
||||||
73,
|
|
||||||
|
|
||||||
105,
|
|
||||||
|
|
||||||
109,
|
|
||||||
|
|
||||||
121,
|
|
||||||
|
|
||||||
256,
|
|
||||||
|
|
||||||
260
|
|
||||||
};
|
|
||||||
|
|
||||||
if (Equipment_List.contains(Identifier) == 1)
|
if (Equipment_List.contains(Identifier) == 1)
|
||||||
{
|
{
|
||||||
@ -144,12 +111,7 @@ void* Original_Estimate_Velocity_Caller;
|
|||||||
|
|
||||||
void __thiscall Redirected_Estimate_Velocity(void* Entity, float* Velocity)
|
void __thiscall Redirected_Estimate_Velocity(void* Entity, float* Velocity)
|
||||||
{
|
{
|
||||||
static std::unordered_set<__int32> Invalids =
|
static std::unordered_set<__int32> Invalids = { 264, 277 };
|
||||||
{
|
|
||||||
264,
|
|
||||||
|
|
||||||
277
|
|
||||||
};
|
|
||||||
|
|
||||||
if (Invalids.contains(Get_Identifier(Entity, 1, 0)) == 1)
|
if (Invalids.contains(Get_Identifier(Entity, 1, 0)) == 1)
|
||||||
{
|
{
|
||||||
@ -161,10 +123,6 @@ void __thiscall Redirected_Estimate_Velocity(void* Entity, float* Velocity)
|
|||||||
|
|
||||||
Calculate_Velocity_Type((unsigned __int32)Client_Module + 290704)(Entity);
|
Calculate_Velocity_Type((unsigned __int32)Client_Module + 290704)(Entity);
|
||||||
|
|
||||||
Velocity[0] = *(float*)((unsigned __int32)Entity + 136);
|
Byte_Manager::Copy_Bytes(1, Velocity, sizeof(float[3]), (float*)((unsigned __int32)Entity + 136));
|
||||||
|
|
||||||
Velocity[1] = *(float*)((unsigned __int32)Entity + 140);
|
|
||||||
|
|
||||||
Velocity[2] = *(float*)((unsigned __int32)Entity + 144);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -11,10 +11,14 @@ struct Interface_Structure
|
|||||||
|
|
||||||
Interface_Structure Interface_Extra_Commands;
|
Interface_Structure Interface_Extra_Commands;
|
||||||
|
|
||||||
|
Interface_Structure Interface_Extra_Commands_Action;
|
||||||
|
|
||||||
Interface_Structure Interface_Interpolate_Extra_Commands;
|
Interface_Structure Interface_Interpolate_Extra_Commands;
|
||||||
|
|
||||||
Interface_Structure Interface_Target_On_Simulation;
|
Interface_Structure Interface_Target_On_Simulation;
|
||||||
|
|
||||||
|
Interface_Structure Interface_Shotgun_Shove;
|
||||||
|
|
||||||
Interface_Structure Interface_Riot_Deprioritize;
|
Interface_Structure Interface_Riot_Deprioritize;
|
||||||
|
|
||||||
Interface_Structure Interface_Penetrate_Teammates;
|
Interface_Structure Interface_Penetrate_Teammates;
|
||||||
@ -52,10 +56,14 @@ void Implement_Extended_Interface()
|
|||||||
|
|
||||||
Create_Interface(Pointer_Name(Interface_Extra_Commands), (char*)"5", nullptr);
|
Create_Interface(Pointer_Name(Interface_Extra_Commands), (char*)"5", nullptr);
|
||||||
|
|
||||||
|
Create_Interface(Pointer_Name(Interface_Extra_Commands_Action), (char*)"10", nullptr);
|
||||||
|
|
||||||
Create_Interface(Pointer_Name(Interface_Interpolate_Extra_Commands), (char*)"1", nullptr);
|
Create_Interface(Pointer_Name(Interface_Interpolate_Extra_Commands), (char*)"1", nullptr);
|
||||||
|
|
||||||
Create_Interface(Pointer_Name(Interface_Target_On_Simulation), (char*)"0", nullptr);
|
Create_Interface(Pointer_Name(Interface_Target_On_Simulation), (char*)"0", nullptr);
|
||||||
|
|
||||||
|
Create_Interface(Pointer_Name(Interface_Shotgun_Shove), (char*)"1", nullptr);
|
||||||
|
|
||||||
Create_Interface(Pointer_Name(Interface_Riot_Deprioritize), (char*)"0", nullptr);
|
Create_Interface(Pointer_Name(Interface_Riot_Deprioritize), (char*)"0", nullptr);
|
||||||
|
|
||||||
Create_Interface(Pointer_Name(Interface_Penetrate_Teammates), (char*)"0", nullptr);
|
Create_Interface(Pointer_Name(Interface_Penetrate_Teammates), (char*)"0", nullptr);
|
||||||
|
25
Move.hpp
25
Move.hpp
@ -1,20 +1,24 @@
|
|||||||
__int32 Extra_Commands;
|
__int32 Extra_Commands;
|
||||||
|
|
||||||
|
__int32 Chainsaw_Cycles;
|
||||||
|
|
||||||
void* Original_Move_Caller;
|
void* Original_Move_Caller;
|
||||||
|
|
||||||
void Redirected_Move(float Unknown_Parameter, __int8 Final)
|
void Redirected_Move(float Unknown_Parameter, __int8 Final)
|
||||||
{
|
{
|
||||||
|
void* Local_Player = *(void**)((unsigned __int32)Client_Module + 7498712);
|
||||||
|
|
||||||
using Run_Prediction_Type = void(__cdecl*)();
|
using Run_Prediction_Type = void(__cdecl*)();
|
||||||
|
|
||||||
if (*(void**)((unsigned __int32)Client_Module + 7498712) != nullptr)
|
if (Local_Player != nullptr)
|
||||||
{
|
{
|
||||||
Redirected_Read_Packets(Final);
|
Redirected_Read_Packets(Final);
|
||||||
|
|
||||||
|
Local_Player = *(void**)((unsigned __int32)Client_Module + 7498712);
|
||||||
|
|
||||||
Run_Prediction_Type((unsigned __int32)Engine_Module + 527776)();
|
Run_Prediction_Type((unsigned __int32)Engine_Module + 527776)();
|
||||||
|
|
||||||
using Update_Animations_Type = void(__cdecl*)();
|
Redirected_Update_Animations();
|
||||||
|
|
||||||
Update_Animations_Type((unsigned __int32)Client_Module + 205296)();
|
|
||||||
|
|
||||||
using Fire_Events_Type = void(__cdecl*)();
|
using Fire_Events_Type = void(__cdecl*)();
|
||||||
|
|
||||||
@ -24,7 +28,7 @@ void Redirected_Move(float Unknown_Parameter, __int8 Final)
|
|||||||
|
|
||||||
Update_Animation_Type = 1;
|
Update_Animation_Type = 1;
|
||||||
|
|
||||||
Update_Animations_Type((unsigned __int32)Client_Module + 205296)();
|
Redirected_Update_Animations();
|
||||||
|
|
||||||
Update_Animation_Type = 0;
|
Update_Animation_Type = 0;
|
||||||
}
|
}
|
||||||
@ -37,6 +41,17 @@ void Redirected_Move(float Unknown_Parameter, __int8 Final)
|
|||||||
|
|
||||||
Run_Prediction_Type((unsigned __int32)Engine_Module + 527776)();
|
Run_Prediction_Type((unsigned __int32)Engine_Module + 527776)();
|
||||||
|
|
||||||
|
if (Local_Player != nullptr)
|
||||||
|
{
|
||||||
|
Chainsaw_Cycles += 1 + (Chainsaw_Cycles == 0);
|
||||||
|
|
||||||
|
static float Deploy_Time;
|
||||||
|
|
||||||
|
Chainsaw_Cycles *= *(float*)((unsigned __int32)Local_Player + 3872) == Deploy_Time;
|
||||||
|
|
||||||
|
Deploy_Time = *(float*)((unsigned __int32)Local_Player + 3872);
|
||||||
|
}
|
||||||
|
|
||||||
if (Extra_Commands > 0)
|
if (Extra_Commands > 0)
|
||||||
{
|
{
|
||||||
Extra_Commands -= 1;
|
Extra_Commands -= 1;
|
||||||
|
57
Paint.hpp
57
Paint.hpp
@ -77,7 +77,7 @@ void __thiscall Redirected_Paint(void* Panel)
|
|||||||
{
|
{
|
||||||
Target_Structure* Target = &Sorted_Target_List.at(Target_Number);
|
Target_Structure* Target = &Sorted_Target_List.at(Target_Number);
|
||||||
|
|
||||||
float Bounds[4] = { __builtin_inff(), -__builtin_inff(), __builtin_inff(), -__builtin_inff()};
|
float Bounds[4] = { __builtin_inff(), -__builtin_inff(), __builtin_inff(), -__builtin_inff()};
|
||||||
|
|
||||||
auto Get_Bounds = [&]() -> __int8
|
auto Get_Bounds = [&]() -> __int8
|
||||||
{
|
{
|
||||||
@ -121,10 +121,10 @@ void __thiscall Redirected_Paint(void* Panel)
|
|||||||
|
|
||||||
Hitbox_Vertices[7][Axis_Number] = Bones[*(__int32*)Hitbox][Axis_Number][0] * Hitbox_Maximum[0] + Bones[*(__int32*)Hitbox][Axis_Number][1] * Hitbox_Maximum[1] + Bones[*(__int32*)Hitbox][Axis_Number][2] * Hitbox_Maximum[2] + Bones[*(__int32*)Hitbox][Axis_Number][3];
|
Hitbox_Vertices[7][Axis_Number] = Bones[*(__int32*)Hitbox][Axis_Number][0] * Hitbox_Maximum[0] + Bones[*(__int32*)Hitbox][Axis_Number][1] * Hitbox_Maximum[1] + Bones[*(__int32*)Hitbox][Axis_Number][2] * Hitbox_Maximum[2] + Bones[*(__int32*)Hitbox][Axis_Number][3];
|
||||||
|
|
||||||
if (Axis_Number != 2)
|
Axis_Number += 1;
|
||||||
{
|
|
||||||
Axis_Number += 1;
|
|
||||||
|
|
||||||
|
if (Axis_Number != sizeof(Hitbox_Vertices[0]) / sizeof(float))
|
||||||
|
{
|
||||||
goto Initialize_Vertices_Label;
|
goto Initialize_Vertices_Label;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -162,10 +162,10 @@ void __thiscall Redirected_Paint(void* Panel)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Vertex_Number != 7)
|
Vertex_Number += 1;
|
||||||
{
|
|
||||||
Vertex_Number += 1;
|
|
||||||
|
|
||||||
|
if (Vertex_Number != sizeof(Hitbox_Vertices) / sizeof(Hitbox_Vertices[0]))
|
||||||
|
{
|
||||||
goto Transform_Vertices_Label;
|
goto Transform_Vertices_Label;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -217,7 +217,7 @@ void __thiscall Redirected_Paint(void* Panel)
|
|||||||
|
|
||||||
{ 121, { { 255, 255, 255 }, (wchar_t*)L"Pain" } },
|
{ 121, { { 255, 255, 255 }, (wchar_t*)L"Pain" } },
|
||||||
|
|
||||||
{ 232, { { 0, 255, 0 }, (wchar_t*)L"Survivor" } },
|
{ 232, { { 0, 255, 0 } } },
|
||||||
|
|
||||||
{ 256, { { 255, 255, 255 }, (wchar_t*)L"Ammo" } },
|
{ 256, { { 255, 255, 255 }, (wchar_t*)L"Ammo" } },
|
||||||
|
|
||||||
@ -238,6 +238,13 @@ void __thiscall Redirected_Paint(void* Panel)
|
|||||||
|
|
||||||
Paint_Data_Structure* Paint_Data = &Paint_Data_List[Target->Identifier];
|
Paint_Data_Structure* Paint_Data = &Paint_Data_List[Target->Identifier];
|
||||||
|
|
||||||
|
if (Target->Identifier == 232)
|
||||||
|
{
|
||||||
|
static wchar_t* Survivors[8] = { (wchar_t*)L"Nick", (wchar_t*)L"Rochelle", (wchar_t*)L"Coach", (wchar_t*)L"Ellis", (wchar_t*)L"Bill", (wchar_t*)L"Zoey", (wchar_t*)L"Louis", (wchar_t*)L"Francis" };
|
||||||
|
|
||||||
|
Paint_Data->Name = Survivors[*(__int32*)((unsigned __int32)Target->Self + 7308) + 4 * (*(__int32*)((unsigned __int32)Client_Module + 8144624) == 1)];
|
||||||
|
}
|
||||||
|
|
||||||
__int8 Ghost = 0;
|
__int8 Ghost = 0;
|
||||||
|
|
||||||
if (*(__int32*)((unsigned __int32)Target->Self + 236) != 0)
|
if (*(__int32*)((unsigned __int32)Target->Self + 236) != 0)
|
||||||
@ -245,10 +252,23 @@ void __thiscall Redirected_Paint(void* Panel)
|
|||||||
Ghost = *(__int8*)((unsigned __int32)Target->Self + 7322);
|
Ghost = *(__int8*)((unsigned __int32)Target->Self + 7322);
|
||||||
}
|
}
|
||||||
|
|
||||||
auto Draw_Box = [&](__int32 From_X, __int32 From_Y, __int32 To_X, __int32 To_Y)
|
auto Draw_Box = [&](__int32 From_X, __int32 From_Y, __int32 To_X, __int32 To_Y) -> void
|
||||||
{
|
{
|
||||||
using Set_Color_Type = void(__thiscall**)(void* Surface, unsigned __int8 Red, unsigned __int8 Green, unsigned __int8 Blue, unsigned __int8 Alpha);
|
using Set_Color_Type = void(__thiscall**)(void* Surface, unsigned __int8 Red, unsigned __int8 Green, unsigned __int8 Blue, unsigned __int8 Alpha);
|
||||||
|
|
||||||
|
if (Ghost == 0)
|
||||||
|
{
|
||||||
|
(*Set_Color_Type(*(unsigned __int32*)Surface + 44))(Surface, (__int32)(Paint_Data->Color[0] / 2.f + 0.5f), (__int32)(Paint_Data->Color[1] / 2.f + 0.5f), (__int32)(Paint_Data->Color[2] / 2.f + 0.5f), 128);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
(*Set_Color_Type(*(unsigned __int32*)Surface + 44))(Surface, 64, 64, 64, 128);
|
||||||
|
}
|
||||||
|
|
||||||
|
using Draw_Filled_Rect_Type = void(__thiscall**)(void* Surface, __int32 From_X, __int32 From_Y, __int32 To_X, __int32 To_Y);
|
||||||
|
|
||||||
|
(*Draw_Filled_Rect_Type(*(unsigned __int32*)Surface + 48))(Surface, From_X + 2, From_Y + 2, To_X - 2, To_Y - 2);
|
||||||
|
|
||||||
(*Set_Color_Type(*(unsigned __int32*)Surface + 44))(Surface, 0, 0, 0, 255);
|
(*Set_Color_Type(*(unsigned __int32*)Surface + 44))(Surface, 0, 0, 0, 255);
|
||||||
|
|
||||||
using Draw_Rect_Type = void(__thiscall**)(void* Surface, __int32 From_X, __int32 From_Y, __int32 To_X, __int32 To_Y);
|
using Draw_Rect_Type = void(__thiscall**)(void* Surface, __int32 From_X, __int32 From_Y, __int32 To_X, __int32 To_Y);
|
||||||
@ -267,19 +287,6 @@ void __thiscall Redirected_Paint(void* Panel)
|
|||||||
}
|
}
|
||||||
|
|
||||||
(*Draw_Rect_Type(*(unsigned __int32*)Surface + 56))(Surface, From_X, From_Y, To_X, To_Y);
|
(*Draw_Rect_Type(*(unsigned __int32*)Surface + 56))(Surface, From_X, From_Y, To_X, To_Y);
|
||||||
|
|
||||||
if (Ghost == 0)
|
|
||||||
{
|
|
||||||
(*Set_Color_Type(*(unsigned __int32*)Surface + 44))(Surface, (__int32)(Paint_Data->Color[0] / 2.f + 0.5f), (__int32)(Paint_Data->Color[1] / 2.f + 0.5f), (__int32)(Paint_Data->Color[2] / 2.f + 0.5f), 128);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
(*Set_Color_Type(*(unsigned __int32*)Surface + 44))(Surface, 64, 64, 64, 128);
|
|
||||||
}
|
|
||||||
|
|
||||||
using Draw_Filled_Rect_Type = void(__thiscall**)(void* Surface, __int32 From_X, __int32 From_Y, __int32 To_X, __int32 To_Y);
|
|
||||||
|
|
||||||
(*Draw_Filled_Rect_Type(*(unsigned __int32*)Surface + 48))(Surface, From_X + 2, From_Y + 2, To_X - 2, To_Y - 2);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
Draw_Box(Bounds[0], Bounds[2], Bounds[1], Bounds[3]);
|
Draw_Box(Bounds[0], Bounds[2], Bounds[1], Bounds[3]);
|
||||||
@ -306,6 +313,8 @@ void __thiscall Redirected_Paint(void* Panel)
|
|||||||
|
|
||||||
Draw_Text_Type((unsigned __int32)Engine_Module + 2218736)(Font, 0, 0, 0, 0, 0, 0, Text);
|
Draw_Text_Type((unsigned __int32)Engine_Module + 2218736)(Font, 0, 0, 0, 0, 0, 0, Text);
|
||||||
|
|
||||||
|
Write_Character = 0;
|
||||||
|
|
||||||
if (Character != L'~')
|
if (Character != L'~')
|
||||||
{
|
{
|
||||||
Character += L'\1';
|
Character += L'\1';
|
||||||
@ -358,8 +367,6 @@ void __thiscall Redirected_Paint(void* Panel)
|
|||||||
|
|
||||||
wchar_t Text[2] = { Paint_Data->Name[Character_Number] };
|
wchar_t Text[2] = { Paint_Data->Name[Character_Number] };
|
||||||
|
|
||||||
Write_Character = Text[0];
|
|
||||||
|
|
||||||
if (Ghost == 0)
|
if (Ghost == 0)
|
||||||
{
|
{
|
||||||
Draw_Text_Type((unsigned __int32)Engine_Module + 2218736)(Font, Bounds[1] + 7 + Offset_X - Character_Bounds[0], Bounds[2] + Offset_Y, Paint_Data->Color[0], Paint_Data->Color[1], Paint_Data->Color[2], 255, Text);
|
Draw_Text_Type((unsigned __int32)Engine_Module + 2218736)(Font, Bounds[1] + 7 + Offset_X - Character_Bounds[0], Bounds[2] + Offset_Y, Paint_Data->Color[0], Paint_Data->Color[1], Paint_Data->Color[2], 255, Text);
|
||||||
@ -369,8 +376,6 @@ void __thiscall Redirected_Paint(void* Panel)
|
|||||||
Draw_Text_Type((unsigned __int32)Engine_Module + 2218736)(Font, Bounds[1] + 7 + Offset_X - Character_Bounds[0], Bounds[2] + Offset_Y, 128, 128, 128, 255, Text);
|
Draw_Text_Type((unsigned __int32)Engine_Module + 2218736)(Font, Bounds[1] + 7 + Offset_X - Character_Bounds[0], Bounds[2] + Offset_Y, 128, 128, 128, 255, Text);
|
||||||
}
|
}
|
||||||
|
|
||||||
Write_Character = 0;
|
|
||||||
|
|
||||||
Offset_X += Character_Bounds[1] + 1;
|
Offset_X += Character_Bounds[1] + 1;
|
||||||
|
|
||||||
Character_Number += 1;
|
Character_Number += 1;
|
||||||
|
@ -37,6 +37,10 @@ void __thiscall Perform_Trace(void* Stack)
|
|||||||
|
|
||||||
if (*(__int32*)((unsigned __int32)Entity + 228) == *(__int32*)((unsigned __int32)Local_Player + 228))
|
if (*(__int32*)((unsigned __int32)Entity + 228) == *(__int32*)((unsigned __int32)Local_Player + 228))
|
||||||
{
|
{
|
||||||
|
Perform_Trace_Target = nullptr;
|
||||||
|
|
||||||
|
Perform_Trace_Damage = 0.f;
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -68,7 +72,7 @@ void __thiscall Perform_Trace(void* Stack)
|
|||||||
{
|
{
|
||||||
if (Interface_Penetration_Damage.Integer == 0)
|
if (Interface_Penetration_Damage.Integer == 0)
|
||||||
{
|
{
|
||||||
Perform_Trace_Damage = 1;
|
Perform_Trace_Damage = 1.f;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -281,6 +285,14 @@ void __thiscall Perform_Trace(void* Stack)
|
|||||||
{
|
{
|
||||||
Damage = (__int32)(Damage + 1.f * (Damage < 1));
|
Damage = (__int32)(Damage + 1.f * (Damage < 1));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (Identifier == 276)
|
||||||
|
{
|
||||||
|
if (__builtin_strstr(Get_Sequence_Name(Entity), "limb") != nullptr)
|
||||||
|
{
|
||||||
|
Damage = min(Damage, *(__int32*)((unsigned __int32)Entity + 236) - 1.f);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -289,7 +301,7 @@ void __thiscall Perform_Trace(void* Stack)
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
if (Upgrade_Type + Gender == 17)
|
if ((Upgrade_Type == 2) + (Gender == 15) == 2)
|
||||||
{
|
{
|
||||||
float Inflictor_Direction[3];
|
float Inflictor_Direction[3];
|
||||||
|
|
||||||
|
@ -87,8 +87,6 @@ void __thiscall Redirected_Post_Network_Data_Received(void* Unknown_Parameter, _
|
|||||||
{
|
{
|
||||||
Predicton_Copy.Construct(Local_Player, Prediction_Frame, (void*)Predicton_Copy_Compare);
|
Predicton_Copy.Construct(Local_Player, Prediction_Frame, (void*)Predicton_Copy_Compare);
|
||||||
|
|
||||||
Consistent_Time = Commands_Acknowledged > 150;
|
|
||||||
|
|
||||||
using Transfer_Data_Type = __int32(__thiscall*)(Prediction_Copy_Structure* Prediction_Copy, void* Unknown_Parameter, __int32 Entity_Number, Prediction_Descriptor_Structure* Descriptor);
|
using Transfer_Data_Type = __int32(__thiscall*)(Prediction_Copy_Structure* Prediction_Copy, void* Unknown_Parameter, __int32 Entity_Number, Prediction_Descriptor_Structure* Descriptor);
|
||||||
|
|
||||||
Transfer_Data_Type((unsigned __int32)Client_Module + 1573744)(&Predicton_Copy, nullptr, -1, (Prediction_Descriptor_Structure*)((unsigned __int32)Client_Module + 7236480));
|
Transfer_Data_Type((unsigned __int32)Client_Module + 1573744)(&Predicton_Copy, nullptr, -1, (Prediction_Descriptor_Structure*)((unsigned __int32)Client_Module + 7236480));
|
||||||
|
@ -13,10 +13,13 @@ void __thiscall Redirected_Process_Movement(void* Unknown_Parameter, void* Playe
|
|||||||
|
|
||||||
(decltype(&Redirected_Process_Movement)(Original_Process_Movement_Caller))(Unknown_Parameter, Player, Move_Data);
|
(decltype(&Redirected_Process_Movement)(Original_Process_Movement_Caller))(Unknown_Parameter, Player, Move_Data);
|
||||||
|
|
||||||
void* Ability = *(void**)((unsigned __int32)Client_Module + 7644532 + (((*(unsigned __int32*)((unsigned __int32)Player + 7892) & 4095) - 4097) << 4));
|
if (Get_Identifier(Player, 0, 0) == 272)
|
||||||
|
|
||||||
if (Ability != nullptr)
|
|
||||||
{
|
{
|
||||||
*(float*)((unsigned __int32)Ability + 1636) = 0.f;
|
void* Ability = *(void**)((unsigned __int32)Client_Module + 7644532 + (((*(unsigned __int32*)((unsigned __int32)Player + 7892) & 4095) - 4097) << 4));
|
||||||
|
|
||||||
|
if (Ability != nullptr)
|
||||||
|
{
|
||||||
|
*(float*)((unsigned __int32)Ability + 1636) = 0.f;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -1,4 +1,4 @@
|
|||||||
to achieve least interpolation time: `cl_updaterate 100;cl_interp_ratio 0;cl_interp 0`\
|
to achieve least (aligned) interpolation time: `cl_updaterate 30;cl_interp_ratio 0;cl_interp 0`\
|
||||||
to queue extra commands: `bind key +zoom`
|
to queue extra commands: `bind key +zoom`
|
||||||
```
|
```
|
||||||
code: https://github.com/qwertyuiop3/Storm
|
code: https://github.com/qwertyuiop3/Storm
|
||||||
|
@ -62,7 +62,10 @@ void Redirected_Send_Move()
|
|||||||
|
|
||||||
void* Network_Channel = *(void**)(*(unsigned __int32*)((unsigned __int32)Engine_Module + 4352236) + 24);
|
void* Network_Channel = *(void**)(*(unsigned __int32*)((unsigned __int32)Engine_Module + 4352236) + 24);
|
||||||
|
|
||||||
*(__int32*)((unsigned __int32)Network_Channel + 28) -= Extra_Commands_Queue;
|
if (*(__int32*)((unsigned __int32)Network_Channel + 16) != -1)
|
||||||
|
{
|
||||||
|
*(__int32*)((unsigned __int32)Network_Channel + 28) -= Extra_Commands_Queue;
|
||||||
|
}
|
||||||
|
|
||||||
using Send_Message_Type = void(__thiscall**)(void* Network_Channel, void* Message, void* Unknown_Parameter_1, void* Unknown_Parameter_2);
|
using Send_Message_Type = void(__thiscall**)(void* Network_Channel, void* Message, void* Unknown_Parameter_1, void* Unknown_Parameter_2);
|
||||||
|
|
||||||
|
@ -2,5 +2,7 @@ void* Original_Update_Caller;
|
|||||||
|
|
||||||
void __thiscall Redirected_Update(void* Unknown_Parameter_1, void* Unknown_Parameter_2, void* Unknown_Parameter_3, __int32 Incoming_Sequence_Number, int Outgoing_Sequence_Number)
|
void __thiscall Redirected_Update(void* Unknown_Parameter_1, void* Unknown_Parameter_2, void* Unknown_Parameter_3, __int32 Incoming_Sequence_Number, int Outgoing_Sequence_Number)
|
||||||
{
|
{
|
||||||
|
Consistent_Time = Outgoing_Sequence_Number - Incoming_Sequence_Number > 150;
|
||||||
|
|
||||||
(decltype(&Redirected_Update)(Original_Update_Caller))(Unknown_Parameter_1, Unknown_Parameter_2, Unknown_Parameter_3, Incoming_Sequence_Number, Incoming_Sequence_Number + (Outgoing_Sequence_Number - Incoming_Sequence_Number) % 150);
|
(decltype(&Redirected_Update)(Original_Update_Caller))(Unknown_Parameter_1, Unknown_Parameter_2, Unknown_Parameter_3, Incoming_Sequence_Number, Incoming_Sequence_Number + (Outgoing_Sequence_Number - Incoming_Sequence_Number) % 150);
|
||||||
}
|
}
|
@ -1,14 +1,14 @@
|
|||||||
struct Global_Variables_Structure
|
struct Global_Variables_Structure
|
||||||
{
|
{
|
||||||
__int8 Additional_Bytes_1[12];
|
__int8 Additional_Bytes_1[12];
|
||||||
|
|
||||||
float Current_Time;
|
float Current_Time;
|
||||||
|
|
||||||
float Frame_Time;
|
float Frame_Time;
|
||||||
|
|
||||||
__int8 Additional_Bytes_2[8];
|
__int8 Additional_Bytes_2[8];
|
||||||
|
|
||||||
float Interval_Per_Tick;
|
float Interval_Per_Tick;
|
||||||
};
|
};
|
||||||
|
|
||||||
float Update_Animation_Time;
|
float Update_Animation_Time;
|
||||||
@ -17,42 +17,42 @@ __int8 Update_Animation_Type;
|
|||||||
|
|
||||||
void Redirected_Update_Animations()
|
void Redirected_Update_Animations()
|
||||||
{
|
{
|
||||||
Global_Variables_Structure* Global_Variables = *(Global_Variables_Structure**)((unsigned __int32)Client_Module + 7096744);
|
Global_Variables_Structure* Global_Variables = *(Global_Variables_Structure**)((unsigned __int32)Client_Module + 7096744);
|
||||||
|
|
||||||
float Previous_Current_Time = Global_Variables->Current_Time;
|
float Previous_Current_Time = Global_Variables->Current_Time;
|
||||||
|
|
||||||
Global_Variables->Current_Time = Update_Animation_Time;
|
Global_Variables->Current_Time = Update_Animation_Time;
|
||||||
|
|
||||||
float Previous_Frame_Time = Global_Variables->Frame_Time;
|
float Previous_Frame_Time = Global_Variables->Frame_Time;
|
||||||
|
|
||||||
Global_Variables->Frame_Time = Global_Variables->Interval_Per_Tick * Update_Animation_Type;
|
Global_Variables->Frame_Time = Global_Variables->Interval_Per_Tick * Update_Animation_Type;
|
||||||
|
|
||||||
__int32 Entity_Number = 0;
|
__int32 Entity_Number = 0;
|
||||||
|
|
||||||
Traverse_Animation_List_Label:
|
Traverse_Animation_List_Label:
|
||||||
{
|
{
|
||||||
if (Entity_Number != *(__int32*)((unsigned __int32)Client_Module + 7479624))
|
if (Entity_Number != *(__int32*)((unsigned __int32)Client_Module + 7479624))
|
||||||
{
|
{
|
||||||
void* Animation_List = *(void**)((unsigned __int32)Client_Module + 7479612);
|
void* Animation_List = *(void**)((unsigned __int32)Client_Module + 7479612);
|
||||||
|
|
||||||
if ((*(__int8*)((unsigned __int32)Animation_List + 8 * Entity_Number + 4) & 1) != 0)
|
if ((*(__int8*)((unsigned __int32)Animation_List + 8 * Entity_Number + 4) & 1) != 0)
|
||||||
{
|
{
|
||||||
using Update_Animation_Type = void(__thiscall**)(void* Entity);
|
using Update_Animation_Type = void(__thiscall**)(void* Entity);
|
||||||
|
|
||||||
void* Entity = *(void**)((unsigned __int32)Animation_List + 8 * Entity_Number);
|
void* Entity = *(void**)((unsigned __int32)Animation_List + 8 * Entity_Number);
|
||||||
|
|
||||||
*(float*)((unsigned __int32)Entity + 328) = Update_Animation_Time - Global_Variables->Frame_Time;
|
*(float*)((unsigned __int32)Entity + 328) = Update_Animation_Time - Global_Variables->Frame_Time;
|
||||||
|
|
||||||
(*Update_Animation_Type(*(unsigned __int32*)Entity + 808))(Entity);
|
(*Update_Animation_Type(*(unsigned __int32*)Entity + 808))(Entity);
|
||||||
}
|
}
|
||||||
|
|
||||||
Entity_Number += 1;
|
Entity_Number += 1;
|
||||||
|
|
||||||
goto Traverse_Animation_List_Label;
|
goto Traverse_Animation_List_Label;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Global_Variables->Frame_Time = Previous_Frame_Time;
|
Global_Variables->Frame_Time = Previous_Frame_Time;
|
||||||
|
|
||||||
Global_Variables->Current_Time = Previous_Current_Time;
|
Global_Variables->Current_Time = Previous_Current_Time;
|
||||||
}
|
}
|
@ -14,10 +14,10 @@ void __thiscall Redirected_Write_Texture(void* Unknown_Parameter_1, void* Unknow
|
|||||||
|
|
||||||
unsigned __int32 Offset_X = Width;
|
unsigned __int32 Offset_X = Width;
|
||||||
|
|
||||||
unsigned __int32 Offset_Y = Height;
|
|
||||||
|
|
||||||
unsigned __int32 Character_Width = 0;
|
unsigned __int32 Character_Width = 0;
|
||||||
|
|
||||||
|
unsigned __int32 Offset_Y = Height;
|
||||||
|
|
||||||
unsigned __int32 Character_Height = 0;
|
unsigned __int32 Character_Height = 0;
|
||||||
|
|
||||||
Traverse_Horizontal_Label:
|
Traverse_Horizontal_Label:
|
||||||
@ -28,11 +28,11 @@ void __thiscall Redirected_Write_Texture(void* Unknown_Parameter_1, void* Unknow
|
|||||||
{
|
{
|
||||||
if (*(unsigned __int32*)((unsigned __int32)Texture + X * 4 + Y * 4 * Width) != 0)
|
if (*(unsigned __int32*)((unsigned __int32)Texture + X * 4 + Y * 4 * Width) != 0)
|
||||||
{
|
{
|
||||||
Offset_X = min(Offset_X, X);
|
Offset_X = min(X, Offset_X);
|
||||||
|
|
||||||
Character_Width = max(Character_Width, X + 1);
|
Character_Width = max(Character_Width, X + 1);
|
||||||
|
|
||||||
Offset_Y = min(Offset_Y, Y);
|
Offset_Y = min(Y, Offset_Y);
|
||||||
|
|
||||||
Character_Height = max(Character_Height, Y + 1);
|
Character_Height = max(Character_Height, Y + 1);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user