Add no radar rot (jeremii), player regen, armour cmd

This commit is contained in:
Grinch_ 2022-07-25 00:36:52 +06:00
parent 91cf68ab03
commit 366b42de61
8 changed files with 87 additions and 23 deletions

View File

@ -202,6 +202,10 @@ RAMUsage = "RAM usage: %.2f%%"
ResetConfig = "Reset config" ResetConfig = "Reset config"
ResetConfigMSG = "Config has been reset. Restart the game for it to take effect." ResetConfigMSG = "Config has been reset. Restart the game for it to take effect."
ResetSize = "Reset size" ResetSize = "Reset size"
SetArmourCMD = "Set armour"
SetArmourCMDText = """
Set player armour.
Example: armour (armour value)."""
SetHealthCMD = "Set health" SetHealthCMD = "Set health"
SetHealthCMDText = """ SetHealthCMDText = """
Set player health. Set player health.
@ -335,8 +339,6 @@ GodDisabled = "God mode disabled"
GodEnabled = "God mode enabled" GodEnabled = "God mode enabled"
GodMode = "God mode" GodMode = "God mode"
Health = "Health" Health = "Health"
HealthRegen = "Health regeneration"
HealthRegenTip = "Player heals if not taken damage for 5 seconds"
InfO2 = "Infinite oxygen" InfO2 = "Infinite oxygen"
InfSprint = "Infinite sprint" InfSprint = "Infinite sprint"
InvisPlayer = "Invisible player" InvisPlayer = "Invisible player"
@ -356,6 +358,8 @@ NeverWanted = "Never wanted"
NoFee = "No arrest fee" NoFee = "No arrest fee"
PedSkinsTab = "Ped skins" PedSkinsTab = "Ped skins"
PlayerFlags = "Player flags," PlayerFlags = "Player flags,"
PlayerRegen = "Player regeneration"
PlayerRegenTip = "Player heals if not taken damage for 5 seconds"
RemoveAll = "Remove all" RemoveAll = "Remove all"
RemoveClothesTab = "Remove clothes" RemoveClothesTab = "Remove clothes"
RespawnDieLoc = "Respawn die location" RespawnDieLoc = "Respawn die location"
@ -428,7 +432,7 @@ AutoDriveNoVeh = "You need to be inside a vehicle!"
AutoDriveCoord = "Drive to coordinates" AutoDriveCoord = "Drive to coordinates"
AutoDriveMarker = "Drive to marker" AutoDriveMarker = "Drive to marker"
AutoDriveStop = "Stop driving" AutoDriveStop = "Stop driving"
AutoDriveInfo = """Automatically drives you to selected location. This doesn't work very well and AI might get stuck!""" AutoDriveInfo = """Automatically drives you to selected location. This doesn't work very well and vehicle might get stuck!"""
AutoUnflip = "Auto unflip" AutoUnflip = "Auto unflip"
Big = "Big" Big = "Big"
BikeFly = "Bikes fly" BikeFly = "Bikes fly"
@ -683,6 +687,7 @@ NoMoneyZeros = "No money zeros"
NoOutline = "No outline" NoOutline = "No outline"
NoParticles = "No particle effects" NoParticles = "No particle effects"
NoPostFX = "No postfx" NoPostFX = "No postfx"
NoRadarRot = "No radar rotation"
NoWater = "No water" NoWater = "No water"
PoleShadowStrength = "Pole shadow strength" PoleShadowStrength = "Pole shadow strength"
PostFX1 = "PostFX 1" PostFX1 = "PostFX 1"

View File

@ -15,7 +15,7 @@ private:
static inline const char* fileExt = ".toml"; static inline const char* fileExt = ".toml";
std::unique_ptr<toml::table> pTable; std::unique_ptr<toml::table> pTable;
std::string path; std::string path;
public: public:
typedef toml::table Table; typedef toml::table Table;

View File

@ -9,7 +9,7 @@
#define MENU_NAME "Cheat Menu" #define MENU_NAME "Cheat Menu"
#define MENU_VERSION_NUMBER "3.3" #define MENU_VERSION_NUMBER "3.3"
#define MENU_VERSION MENU_VERSION_NUMBER"-beta" #define MENU_VERSION MENU_VERSION_NUMBER"-beta"
#define BUILD_NUMBER "20220708" #define BUILD_NUMBER "20220721"
#define MENU_TITLE MENU_NAME " v" MENU_VERSION #define MENU_TITLE MENU_NAME " v" MENU_VERSION
#ifdef GTASA #ifdef GTASA

View File

@ -216,6 +216,20 @@ void Menu::ProcessCommands()
std::string command; std::string command;
ss >> command; ss >> command;
if (command == "armour")
{
try
{
std::string temp;
ss >> temp;
FindPlayerPed()->m_fArmour = std::stof(temp);
}
catch (...)
{
SetHelpMessage(TEXT("Menu.InvalidValue"));
}
}
if (command == "hp") if (command == "hp")
{ {
try try
@ -491,6 +505,13 @@ void Menu::ShowPage()
{ {
ImGui::TextWrapped(TEXT("Menu.OpenCMDUsing"), commandWindow.GetNameString().c_str()); ImGui::TextWrapped(TEXT("Menu.OpenCMDUsing"), commandWindow.GetNameString().c_str());
ImGui::Spacing(); ImGui::Spacing();
if (ImGui::CollapsingHeader(TEXT("Menu.SeArmourCMD")))
{
ImGui::Spacing();
ImGui::TextWrapped(TEXT("Menu.SetArmourCMDText"));
ImGui::Spacing();
ImGui::Separator();
}
if (ImGui::CollapsingHeader(TEXT("Menu.SetHealthCMD"))) if (ImGui::CollapsingHeader(TEXT("Menu.SetHealthCMD")))
{ {
ImGui::Spacing(); ImGui::Spacing();

View File

@ -137,29 +137,41 @@ void Player::Init()
{ {
uint timer = CTimer::m_snTimeInMilliseconds; uint timer = CTimer::m_snTimeInMilliseconds;
CPlayerPed* player = FindPlayerPed(); CPlayerPed* player = FindPlayerPed();
CPlayerInfo *pInfo = &CWorld::Players[CWorld::PlayerInFocus];
int hplayer = CPools::GetPedRef(player); int hplayer = CPools::GetPedRef(player);
if (m_bHealthRegen) if (m_bPlayerRegen)
{ {
static uint lastDmgTimer = 0; static uint lastDmg = 0;
static uint lastHealTimer = 0; static uint lastTimer = 0;
static float health = 0;
float maxHealth = BY_GAME(player->m_fMaxHealth, 100, 100); float maxHealth = BY_GAME(player->m_fMaxHealth, 100, 100);
float maxArmour = BY_GAME(pInfo->m_nMaxArmour, pInfo->m_nMaxArmour, 100);
if (player->m_fHealth != health) static float prevVal = 0;
float curVal = (player->m_fHealth == player->m_fMaxHealth) ? player->m_fHealth : player->m_fArmour;
if (curVal != prevVal)
{ {
health = player->m_fHealth; lastDmg = timer;
lastDmgTimer = timer; curVal = prevVal;
} }
if (player->m_fHealth != maxHealth if (timer - lastDmg > 5000 && timer - lastTimer > 1000)
&& timer - lastDmgTimer > 5000
&& timer - lastHealTimer > 1000
)
{ {
player->m_fHealth += 0.2f; if (player->m_fHealth != maxHealth || player->m_fArmour != maxArmour)
lastHealTimer = timer; {
health = player->m_fHealth; if (player->m_fHealth != maxHealth)
{
player->m_fHealth += 0.2f;
prevVal = player->m_fHealth;
}
else
{
player->m_fArmour += 0.2f;
prevVal = player->m_fArmour;
}
lastTimer = timer;
}
} }
} }
@ -493,7 +505,6 @@ void Player::ShowPage()
pPlayer->m_nFlags.bMeleeProof = m_bGodMode; pPlayer->m_nFlags.bMeleeProof = m_bGodMode;
#endif #endif
} }
Widget::Checkbox(TEXT("Player.HealthRegen"), &m_bHealthRegen, TEXT("Player.HealthRegenTip"));
#ifdef GTASA #ifdef GTASA
Widget::CheckboxAddr(TEXT("Player.CycleJump"), 0x969161); Widget::CheckboxAddr(TEXT("Player.CycleJump"), 0x969161);
Widget::CheckboxAddr(TEXT("Player.InfO2"), 0x96916E); Widget::CheckboxAddr(TEXT("Player.InfO2"), 0x96916E);
@ -555,7 +566,7 @@ void Player::ShowPage()
#endif #endif
Widget::CheckboxAddr(TEXT("Player.NoFee"), (int)&pInfo->m_bGetOutOfJailFree); Widget::CheckboxAddr(TEXT("Player.NoFee"), (int)&pInfo->m_bGetOutOfJailFree);
Widget::Checkbox(TEXT("Player.RespawnDieLoc"), &KeepPosition::m_bEnabled, TEXT("Player.RespawnDieLocTip")); Widget::Checkbox(TEXT("Player.RespawnDieLoc"), &KeepPosition::m_bEnabled, TEXT("Player.RespawnDieLocTip"));
Widget::Checkbox(TEXT("Player.PlayerRegen"), &m_bPlayerRegen, TEXT("Player.PlayerRegenTip"));
#ifdef GTASA #ifdef GTASA
static bool sprintInt = false; static bool sprintInt = false;
if (Widget::Checkbox(TEXT("Player.SprintEverywhere"), &sprintInt, TEXT("Player.SprintEverywhereTip"))) if (Widget::Checkbox(TEXT("Player.SprintEverywhere"), &sprintInt, TEXT("Player.SprintEverywhereTip")))

View File

@ -4,7 +4,7 @@
class Player class Player
{ {
private: private:
static inline bool m_bHealthRegen; static inline bool m_bPlayerRegen;
static inline bool m_bGodMode; static inline bool m_bGodMode;
static inline bool m_bModloaderInstalled; static inline bool m_bModloaderInstalled;
struct KeepPosition struct KeepPosition

View File

@ -755,7 +755,33 @@ void Visual::ShowPage()
} }
} }
Widget::CheckboxAddr(TEXT("Visual.NoPostFX"), 0xC402CF); Widget::CheckboxAddr(TEXT("Visual.NoPostFX"), 0xC402CF);
if (Widget::Checkbox(TEXT("Visual.NoRadarRot"), &m_bNoRadarRot))
{
// Credits: jeremii (bjeremii.blogspot.com)
if (m_bNoRadarRot)
{
patch::Set<float>(0xBA8310, 0.0);
patch::Set<float>(0xBA830C, 0.0);
patch::Set<float>(0xBA8308, 1.0);
// stop map rotaiton
patch::Nop(0x5837FB, 6);
patch::Nop(0x583805, 6);
patch::Nop(0x58380D, 6);
patch::Nop(0x5837D6, 6);
patch::Nop(0x5837D0, 6);
patch::Nop(0x5837C6, 8);
}
else
{
patch::SetRaw(0x5837FB, (void*)"\xD9\x15\x10\x83\xBA\x00", 6);
patch::SetRaw(0x583805, (void*)"\xD9\x1D\x0C\x83\xBA\x00", 6);
patch::SetRaw(0x58380D, (void*)"\xD9\x1D\x08\x83\xBA\x00", 6);
patch::SetRaw(0x5837D6, (void*)"\xD9\x1D\x10\x83\xBA\x00", 6);
patch::SetRaw(0x5837D0, (void*)"\xD9\x1D\x08\x83\xBA\x00", 6);
patch::SetRaw(0x5837C6, (void*)"\xD9\x1D\x0C\x83\xBA\x00\xD9\xC0", 8);
}
}
if (Widget::Checkbox(TEXT("Visual.NoWater"), &m_bNoWater)) if (Widget::Checkbox(TEXT("Visual.NoWater"), &m_bNoWater))
{ {
if (m_bNoWater) if (m_bNoWater)

View File

@ -30,6 +30,7 @@ private:
static inline bool m_bNoTextures; static inline bool m_bNoTextures;
static inline bool m_bFullScreenMap; static inline bool m_bFullScreenMap;
static inline bool m_bSquareRadar; static inline bool m_bSquareRadar;
static inline bool m_bNoRadarRot;
#endif #endif
template<typename T> template<typename T>