Refactor code & add more language keys

This commit is contained in:
Grinch_ 2022-06-13 00:01:43 +06:00
parent 7b0fa7c7f6
commit 425137e82e
24 changed files with 343 additions and 279 deletions

View File

@ -112,6 +112,7 @@
"Author": "Author", "Author": "Author",
"BugDisclaimer": "If you find bugs or have suggestions, let me know on discord.", "BugDisclaimer": "If you find bugs or have suggestions, let me know on discord.",
"Build": "Build", "Build": "Build",
"CheatMenuNoDir" : "Failed to find CheatMenu directory!",
"CheckUpdate": "Check update", "CheckUpdate": "Check update",
"Commands": "Commands", "Commands": "Commands",
"Config": "Config", "Config": "Config",
@ -124,6 +125,8 @@
"DiscordServer": "Discord server", "DiscordServer": "Discord server",
"DownloadPage" : "Download page", "DownloadPage" : "Download page",
"EnsureLatest" : "Please ensure you have the latest version from GitHub.", "EnsureLatest" : "Please ensure you have the latest version from GitHub.",
"DiscordRPCInitFailed": "Failed to init discord rpc",
"DiscordRPCNoDll" : "Failed to find discord-rpc.dll",
"FixVehKey": "Fix current vehicle", "FixVehKey": "Fix current vehicle",
"FlipVehKey": "Flip current vehicle", "FlipVehKey": "Flip current vehicle",
"Frames": "Frames: %d", "Frames": "Frames: %d",

View File

@ -79,7 +79,7 @@ void CheatMenu::ProcessPages()
ImGuiStyle &style = ImGui::GetStyle(); ImGuiStyle &style = ImGui::GetStyle();
ImGui::PushStyleVar(ImGuiStyleVar_ItemSpacing, ImVec2(0, 0)); ImGui::PushStyleVar(ImGuiStyleVar_ItemSpacing, ImVec2(0, 0));
ImGui::PushFont(FontMgr::GetFont("header")); ImGui::PushFont(FontMgr::Get("header"));
m_nMenuPage = Updater::IsUpdateAvailable() ? eMenuPages::UPDATE : m_nMenuPage; m_nMenuPage = Updater::IsUpdateAvailable() ? eMenuPages::UPDATE : m_nMenuPage;
// Check once if it's anniversary day // Check once if it's anniversary day
@ -93,7 +93,7 @@ void CheatMenu::ProcessPages()
{ {
/* /*
* We don't want to be annoying and * We don't want to be annoying and
* show anniversary screen on game start * show anniversary screen on every game start
*/ */
bool flag = gConfig.GetValue("window.anniversaryShown", false); bool flag = gConfig.GetValue("window.anniversaryShown", false);
@ -116,7 +116,9 @@ void CheatMenu::ProcessPages()
if (m_headerList[i].skipHeader) if (m_headerList[i].skipHeader)
{ {
if (m_nMenuPage == m_headerList[i].page) if (m_nMenuPage == m_headerList[i].page)
{
pCallback = m_headerList[i].pFunc; pCallback = m_headerList[i].pFunc;
}
continue; continue;
} }
@ -161,7 +163,9 @@ void CheatMenu::ProcessPages()
ImGui::RenderTextClipped(min + style.FramePadding, max - style.FramePadding, text, NULL, &size, style.ButtonTextAlign); ImGui::RenderTextClipped(min + style.FramePadding, max - style.FramePadding, text, NULL, &size, style.ButtonTextAlign);
if (i % 3 != 2) if (i % 3 != 2)
{
ImGui::SameLine(); ImGui::SameLine();
}
} }
ImGui::PopFont(); ImGui::PopFont();
ImGui::PopStyleVar(); ImGui::PopStyleVar();
@ -195,6 +199,12 @@ void CheatMenu::GenHeaderList()
void CheatMenu::Init() void CheatMenu::Init()
{ {
if (!std::filesystem::exists(PLUGIN_PATH((char*)"CheatMenu")))
{
gLog << TEXT("Menu.CheatMenuNoDir") << std::endl;
return;
}
if (!D3dHook::InjectHook(DrawWindow)) if (!D3dHook::InjectHook(DrawWindow))
{ {
return; return;
@ -255,7 +265,7 @@ void CheatMenu::Init()
} }
/* /*
* YIKES YOU AREN"T SUPPOSED TO FIND THIS YOU KNOW!!! * YIKES YOU AREN"T SUPPOSED TO FIND THIS!!!
* Probably a good easter egg for the upcoming anniversary ;) * Probably a good easter egg for the upcoming anniversary ;)
*/ */
void CheatMenu::ShowAnniversaryPage() void CheatMenu::ShowAnniversaryPage()

View File

@ -1,16 +1,10 @@
/*
Author: Grinch_
Copyright Grinch_ 2019-2022. All rights reserved.
Required:
DirectX 9 SDK
Plugin SDK
Build Tools 2022 (v143)
Windows SDK
*/
#pragma once #pragma once
#include "pch.h" #include "pch.h"
/*
* Main CheatMenu Class
* Handles rendering, resizing, page handling etc.
*/
class CheatMenu class CheatMenu
{ {
private: private:
@ -26,17 +20,24 @@ private:
bool skipHeader = false; bool skipHeader = false;
}; };
static inline eMenuPages m_nMenuPage = eMenuPages::WELCOME; static inline eMenuPages m_nMenuPage = eMenuPages::WELCOME; // current visible menu page
static inline bool m_bShowMenu = false; static inline bool m_bShowMenu = false;
static inline ImVec2 m_fMenuSize = ImVec2(screen::GetScreenWidth() / 4, screen::GetScreenHeight() / 1.2); static inline ImVec2 m_fMenuSize = ImVec2(screen::GetScreenWidth() / 4, screen::GetScreenHeight() / 1.2);
static inline bool m_bSizeChangedExternal = false; static inline bool m_bSizeChangedExternal = false; // Was menu size change requested
static inline std::vector<HeaderData> m_headerList; static inline std::vector<HeaderData> m_headerList;
// Applies imgui theme to the menu
static void ApplyStyle(); static void ApplyStyle();
// Draws the window ui each frame
// Also handles drawing overlay & command window
static void DrawWindow(); static void DrawWindow();
static void ShowAnniversaryPage(); static void ShowAnniversaryPage();
static void ShowUpdatePage(); static void ShowUpdatePage();
static void ShowWelcomePage(); static void ShowWelcomePage();
// Does all the processing required to handle menu pages
static void ProcessPages(); static void ProcessPages();
public: public:
@ -46,5 +47,8 @@ public:
static void Init(); static void Init();
static bool IsMenuShown(); static bool IsMenuShown();
static void ResetMenuSize(); static void ResetMenuSize();
// Generates menu headers
// Needs to be called after language change or adding new headers
static void GenHeaderList(); static void GenHeaderList();
}; };

View File

@ -60,7 +60,7 @@ void D3dHook::ProcessFrame(void* ptr)
ImVec2 size(screen::GetScreenWidth(), screen::GetScreenHeight()); ImVec2 size(screen::GetScreenWidth(), screen::GetScreenHeight());
if (fScreenSize.x != size.x && fScreenSize.y != size.y) if (fScreenSize.x != size.x && fScreenSize.y != size.y)
{ {
FontMgr::ReloadFonts(); FontMgr::ReloadAll();
if (gRenderer == Render_DirectX9) if (gRenderer == Render_DirectX9)
{ {
@ -139,9 +139,9 @@ void D3dHook::ProcessFrame(void* ptr)
ImGui_ImplWin32_EnableDpiAwareness(); ImGui_ImplWin32_EnableDpiAwareness();
// Loading fonts // Loading fonts
io.FontDefault = FontMgr::LoadFont("text", 1.0f); io.FontDefault = FontMgr::Load("text", 1.0f);
FontMgr::LoadFont("title", 2.0f); FontMgr::Load("title", 2.0f);
FontMgr::LoadFont("header", 1.25f); FontMgr::Load("header", 1.25f);
io.IniFilename = nullptr; io.IniFilename = nullptr;
io.LogFilename = nullptr; io.LogFilename = nullptr;

View File

@ -1,6 +1,10 @@
#pragma once #pragma once
#include "pch.h" #include "pch.h"
/*
* DirectX Hooking Class
* Supports DX9 & DX11
*/
class D3dHook class D3dHook
{ {
private: private:
@ -15,7 +19,6 @@ private:
static inline bool mouseShown; static inline bool mouseShown;
static inline void* pCallbackFunc = nullptr; static inline void* pCallbackFunc = nullptr;
static void CALLBACK ProcessFrame(void* ptr); static void CALLBACK ProcessFrame(void* ptr);
static LRESULT CALLBACK hkWndProc(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam); static LRESULT CALLBACK hkWndProc(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam);
static void ProcessMouse(); static void ProcessMouse();

View File

@ -1,11 +1,11 @@
#include "fontmgr.h" #include "fontmgr.h"
#include "pch.h" #include "pch.h"
ImFont* FontMgr::GetFont(const char* fontName) ImFont* FontMgr::Get(const char* fontName)
{ {
for (auto &data : m_vecFonts) for (auto &data : m_vecFonts)
{ {
if (data.m_path == std::string(fontName)) if (!strcmp(data.m_path.c_str(), fontName))
{ {
return data.m_pFont; return data.m_pFont;
} }
@ -14,27 +14,27 @@ ImFont* FontMgr::GetFont(const char* fontName)
return nullptr; return nullptr;
} }
ImFont* FontMgr::LoadFont(const char* fontName, float fontMul) ImFont* FontMgr::Load(const char* fontName, float fontMul)
{ {
ImGuiIO& io = ImGui::GetIO(); ImGuiIO& io = ImGui::GetIO();
size_t fontSize = static_cast<int>(screen::GetScreenHeight() / 54.85f) * fontMul; size_t fontSize = static_cast<int>(screen::GetScreenHeight() / 54.85f) * fontMul;
std::string fullPath = std::format("{}{}.ttf", PLUGIN_PATH((char*)"CheatMenu/fonts/"), fontName);
ImFont *pFont = io.Fonts->AddFontFromFileTTF(fullPath.c_str(), fontSize);
std::string fullPath = std::string(PLUGIN_PATH((char*)"CheatMenu/fonts/")) + fontName + ".ttf"; m_vecFonts.push_back({pFont, fontSize, fontMul, std::string(fontName)});
m_vecFonts.push_back({io.Fonts->AddFontFromFileTTF(fullPath.c_str(), fontSize), fontSize, fontMul,
std::string(fontName)});
io.Fonts->Build(); io.Fonts->Build();
return m_vecFonts.back().m_pFont; return pFont;
} }
void FontMgr::UnloadFonts() void FontMgr::UnloadAll()
{ {
ImGui::GetIO().Fonts->Clear(); ImGui::GetIO().Fonts->Clear();
} }
void FontMgr::ReloadFonts() void FontMgr::ReloadAll()
{ {
UnloadFonts(); UnloadAll();
ImGuiIO& io = ImGui::GetIO(); ImGuiIO& io = ImGui::GetIO();
for (auto &data : m_vecFonts) for (auto &data : m_vecFonts)
@ -43,6 +43,6 @@ void FontMgr::ReloadFonts()
std::string fullPath = PLUGIN_PATH((char*)"CheatMenu/fonts/") + data.m_path + ".ttf"; std::string fullPath = PLUGIN_PATH((char*)"CheatMenu/fonts/") + data.m_path + ".ttf";
data.m_pFont = io.Fonts->AddFontFromFileTTF(fullPath.c_str(), data.m_nSize); data.m_pFont = io.Fonts->AddFontFromFileTTF(fullPath.c_str(), data.m_nSize);
} }
io.FontDefault = GetFont("text"); io.FontDefault = Get("text");
io.Fonts->Build(); io.Fonts->Build();
} }

View File

@ -1,7 +1,7 @@
#pragma once #pragma once
/* /*
Font Manager class Font Manager Class
Handles loading, fetching, freeing & reloading fonts Handles loading, fetching, freeing & reloading fonts
*/ */
class FontMgr class FontMgr
@ -20,12 +20,18 @@ public:
FontMgr() = delete; FontMgr() = delete;
FontMgr(FontMgr&) = delete; FontMgr(FontMgr&) = delete;
static ImFont* GetFont(const char* fontName); // Returns font pointer from name
static ImFont* LoadFont(const char* fontName, float fontMul = 1.0f); static ImFont* Get(const char* fontName);
// Loads a font into memory
static ImFont* Load(const char* fontName, float fontMul = 1.0f);
// Unloads all the loaded fonts from fontmgr
// ImGui::GetIO().Default font must be loaded after unloading all fonts // ImGui::GetIO().Default font must be loaded after unloading all fonts
static void UnloadFonts(); static void UnloadAll();
static void ReloadFonts();
// Reloads all the fonts
static void ReloadAll();
}; };

View File

@ -290,7 +290,7 @@ void Game::FreeCam()
m_Freecam::m_fTotalMouse.y = -150; m_Freecam::m_fTotalMouse.y = -150;
} }
if (KeyPressed(VK_RETURN)) if (freeCamTeleport.Pressed())
{ {
CPlayerPed* player = FindPlayerPed(); CPlayerPed* player = FindPlayerPed();
CVector pos = m_Freecam::m_pPed->GetPosition(); CVector pos = m_Freecam::m_pPed->GetPosition();

View File

@ -4,6 +4,176 @@
const size_t HOTKEY_START = 3; const size_t HOTKEY_START = 3;
const size_t HOTKEY_END = 135; const size_t HOTKEY_END = 135;
static std::string key_names[]
{
"LMB",
"RMB",
"Cancel",
"MMB",
"X1MB",
"X2MB",
"Unknown1",
"Back",
"Tab",
"Reserved1",
"Reserved2",
"Clear",
"Enter",
"Unknown2",
"Unknown3",
"Shift",
"Ctrl",
"Alt",
"Pause",
"Capslock",
"IME",
"IME2",
"IME3",
"Unknown4",
"IME4",
"Unknown5",
"Esc",
"IME5"
"IME6",
"IME7",
"IME8",
"IME9",
"Space",
"Pup",
"Pdown",
"End",
"Home",
"Left",
"Up",
"Right",
"Down",
"Select",
"Print",
"Execute",
"Print Screen",
"INS",
"Del",
"Help",
"0",
"1",
"2",
"3",
"4",
"5",
"6",
"7",
"8",
"9",
"Unknown6",
"Unknown7",
"Unknown8",
"Unknown9",
"Unknown10",
"Unknown11",
"Unknown12",
"A",
"B",
"C",
"D",
"E",
"F",
"G",
"H",
"I",
"J",
"K",
"L",
"M",
"N",
"O",
"P",
"Q",
"R",
"S",
"T",
"U",
"V",
"W",
"X",
"Y",
"Z",
"LWin",
"RWin",
"Apps",
"Unknown11",
"Sleep",
"Numpad 0",
"Numpad 1",
"Numpad 2",
"Numpad 3",
"Numpad 4",
"Numpad 5",
"Numpad 6",
"Numpad 7",
"Numpad 8",
"Numpad 9",
"Multiply",
"Add",
"Separator",
"Substract",
"Decimal",
"Divide",
"F1",
"F2",
"F3",
"F4",
"F5",
"F6",
"F7",
"F8",
"F9",
"F10",
"F11",
"F12",
"F13",
"F14",
"F15",
"F16",
"F17",
"F18",
"F19",
"F20",
"F21",
"F22",
"F23",
"F24",
"Unknown12",
"Unknown13",
"Unknown14",
"Unknown15",
"Unknown16",
"Unknown17",
"Unknown18",
"Numlock",
"Scroll",
"Unknown19",
"Unknown20",
"Unknown21",
"Unknown22",
"Unknown23",
"Unknown24",
"Unknown25",
"Unknown26",
"Unknown27",
"Unknown28",
"Unknown29",
"Unknown30",
"Unknown31",
"Unknown32",
"Unknown33",
"LShift",
"RShift",
"LCtrl",
"RCtrl",
"LMenu",
"RMenu"
};
Hotkey::Hotkey(int key1, int key2, const std::string& configPath) Hotkey::Hotkey(int key1, int key2, const std::string& configPath)
: m_key1(key1), m_key2(key2), m_ConfigPath("Hotkeys." + configPath) : m_key1(key1), m_key2(key2), m_ConfigPath("Hotkeys." + configPath)
{ {

View File

@ -1,6 +1,44 @@
#pragma once #pragma once
#include <string> #include <string>
const int VK_NONE = -1;
const size_t VK_KEY_0 = 0x30;
const size_t VK_KEY_1 = 0x31;
const size_t VK_KEY_2 = 0x32;
const size_t VK_KEY_3 = 0x33;
const size_t VK_KEY_4 = 0x34;
const size_t VK_KEY_5 = 0x35;
const size_t VK_KEY_6 = 0x36;
const size_t VK_KEY_7 = 0x37;
const size_t VK_KEY_8 = 0x38;
const size_t VK_KEY_9 = 0x39;
const size_t VK_KEY_A = 0x41;
const size_t VK_KEY_B = 0x42;
const size_t VK_KEY_C = 0x43;
const size_t VK_KEY_D = 0x44;
const size_t VK_KEY_E = 0x45;
const size_t VK_KEY_F = 0x46;
const size_t VK_KEY_G = 0x47;
const size_t VK_KEY_H = 0x48;
const size_t VK_KEY_I = 0x49;
const size_t VK_KEY_J = 0x4A;
const size_t VK_KEY_K = 0x4B;
const size_t VK_KEY_L = 0x4C;
const size_t VK_KEY_M = 0x4D;
const size_t VK_KEY_N = 0x4E;
const size_t VK_KEY_O = 0x4F;
const size_t VK_KEY_P = 0x50;
const size_t VK_KEY_Q = 0x51;
const size_t VK_KEY_R = 0x52;
const size_t VK_KEY_S = 0x53;
const size_t VK_KEY_T = 0x54;
const size_t VK_KEY_U = 0x55;
const size_t VK_KEY_V = 0x56;
const size_t VK_KEY_W = 0x57;
const size_t VK_KEY_X = 0x58;
const size_t VK_KEY_Y = 0x59;
const size_t VK_KEY_Z = 0x5A;
/* /*
HotKey Implementation Class HotKey Implementation Class
Handles events, save-load, name-fetch, ui etc. Handles events, save-load, name-fetch, ui etc.

View File

@ -259,13 +259,13 @@ void Neon::SetPulsing(CVehicle* pVeh, bool state)
m_VehNeon.Get(pVeh).m_bPulsing = state; m_VehNeon.Get(pVeh).m_bPulsing = state;
} }
void Neon::Install(CVehicle* pVeh, int red, int green, int blue) void Neon::Install(CVehicle* pVeh, int r, int g, int b)
{ {
CRGBA& color = m_VehNeon.Get(pVeh).m_Color; CRGBA& color = m_VehNeon.Get(pVeh).m_Color;
color.r = red; color.r = r;
color.g = green; color.g = g;
color.b = blue; color.b = b;
color.a = 255; color.a = 255;
m_VehNeon.Get(pVeh).m_bNeonInstalled = true; m_VehNeon.Get(pVeh).m_bNeonInstalled = true;

View File

@ -35,11 +35,24 @@ public:
Neon() = delete; Neon() = delete;
Neon(Neon&) = delete; Neon(Neon&) = delete;
// Injects necessary hooks into the game
static void InjectHooks(); static void InjectHooks();
static void Install(CVehicle* veh, int red, int green, int blue);
// Installs neons with color
static void Install(CVehicle* veh, int r, int g, int b);
// Is neon installer for particular vehicle
static bool IsInstalled(CVehicle* veh); static bool IsInstalled(CVehicle* veh);
// Is neon pulsing enabled for vehicle
static bool IsPulsingEnabled(CVehicle* veh); static bool IsPulsingEnabled(CVehicle* veh);
// Set neon pulsing state
static void SetPulsing(CVehicle* veh, bool state); static void SetPulsing(CVehicle* veh, bool state);
// Removes the neon game hooks
static void RemoveHooks(); static void RemoveHooks();
// Removes neon from vehicle
static void Remove(CVehicle* veh); static void Remove(CVehicle* veh);
}; };

View File

@ -8,7 +8,8 @@ Hotkey freeCam {VK_F6, VK_F6, "Freecam.Toggle"};
Hotkey freeCamForward {VK_KEY_I, VK_KEY_I, "Freecam.Forward"};; Hotkey freeCamForward {VK_KEY_I, VK_KEY_I, "Freecam.Forward"};;
Hotkey freeCamBackward {VK_KEY_K, VK_KEY_K, "Freecam.Backward"};; Hotkey freeCamBackward {VK_KEY_K, VK_KEY_K, "Freecam.Backward"};;
Hotkey freeCamLeft {VK_KEY_J, VK_KEY_J, "Freecam.Left"};; Hotkey freeCamLeft {VK_KEY_J, VK_KEY_J, "Freecam.Left"};;
Hotkey freeCamRight {VK_KEY_L, VK_KEY_L, "Freecam.Right"};; Hotkey freeCamRight {VK_KEY_L, VK_KEY_L, "Freecam.Right"};
Hotkey freeCamTeleport {VK_RETURN, VK_RETURN, "Freecam.Teleport"};
Hotkey commandWindow {VK_LCONTROL, VK_KEY_C, "CommandWindowToggle"};; Hotkey commandWindow {VK_LCONTROL, VK_KEY_C, "CommandWindowToggle"};;
Hotkey fixVeh {VK_NONE, VK_NONE, "Vehicle.Fix"}; Hotkey fixVeh {VK_NONE, VK_NONE, "Vehicle.Fix"};
Hotkey flipVeh {VK_NONE, VK_NONE, "Vehicle.Flip"}; Hotkey flipVeh {VK_NONE, VK_NONE, "Vehicle.Flip"};

View File

@ -71,7 +71,6 @@
#include "json.h" #include "json.h"
#include "hotkeys.h" #include "hotkeys.h"
#include "vkeys.h"
#include "resourcestore.h" #include "resourcestore.h"
#include "fontmgr.h" #include "fontmgr.h"
#include "locale.h" #include "locale.h"
@ -114,6 +113,7 @@ extern Hotkey freeCamForward;
extern Hotkey freeCamBackward; extern Hotkey freeCamBackward;
extern Hotkey freeCamLeft; extern Hotkey freeCamLeft;
extern Hotkey freeCamRight; extern Hotkey freeCamRight;
extern Hotkey freeCamTeleport;
extern Hotkey commandWindow; extern Hotkey commandWindow;
extern Hotkey fixVeh; extern Hotkey fixVeh;
extern Hotkey flipVeh; extern Hotkey flipVeh;

View File

@ -5,8 +5,7 @@
ResourceStore::ResourceStore(const char* text, eResourceType type, ImVec2 imageSize) ResourceStore::ResourceStore(const char* text, eResourceType type, ImVec2 imageSize)
: m_ImageSize(imageSize) : m_ImageSize(imageSize)
{ {
if (type == eResourceType::TYPE_TEXT if (type == eResourceType::TYPE_TEXT || type == eResourceType::TYPE_BOTH)
|| type == eResourceType::TYPE_BOTH)
{ {
m_pJson = std::make_unique<CJson>(text); m_pJson = std::make_unique<CJson>(text);
@ -20,12 +19,14 @@ ResourceStore::ResourceStore(const char* text, eResourceType type, ImVec2 imageS
} }
} }
if (type == eResourceType::TYPE_IMAGE if (type == eResourceType::TYPE_IMAGE || type == eResourceType::TYPE_BOTH)
|| type == eResourceType::TYPE_BOTH)
{ {
/* /*
Textures need to be loaded from main thread Textures need to be loaded from main thread
Loading it directly here doesn't work Loading it directly here doesn't work
TODO:
Maybe enabling a dx9 flag fixes this?
Switch to initScriptsEvent
*/ */
Events::processScriptsEvent += [text, this]() Events::processScriptsEvent += [text, this]()
{ {
@ -38,7 +39,8 @@ ResourceStore::ResourceStore(const char* text, eResourceType type, ImVec2 imageS
} }
} }
static void* GetTextureFromRaster(RwTexture* pTexture) // Get dx9 texture object from RwTexture*
static IDirect3DTexture9** GetTextureFromRaster(RwTexture* pTexture)
{ {
RwRasterEx* raster = (RwRasterEx*)(&pTexture->raster->parent); RwRasterEx* raster = (RwRasterEx*)(&pTexture->raster->parent);

View File

@ -4,10 +4,6 @@
#include "../depend/imgui/imgui.h" #include "../depend/imgui/imgui.h"
#include "d3d9.h" #include "d3d9.h"
/*
Global resource handler class
Handles both image and json resources
*/
struct RwD3D9Raster struct RwD3D9Raster
{ {
union union
@ -47,10 +43,14 @@ enum eResourceType
TYPE_BOTH, TYPE_BOTH,
}; };
using TextureResourceList = std::vector<std::unique_ptr<TextureResource>>; /*
Global Resource Handler Class
Handles loading & unloading both text (json) & image files
*/
class ResourceStore class ResourceStore
{ {
private: private:
// Loads a image texture from it's path
void LoadTextureResource(std::string&& path); void LoadTextureResource(std::string&& path);
public: public:
@ -58,7 +58,7 @@ public:
std::vector<std::string> m_Categories = {"All"}; std::vector<std::string> m_Categories = {"All"};
std::string m_Selected = "All"; std::string m_Selected = "All";
std::unique_ptr<CJson> m_pJson; std::unique_ptr<CJson> m_pJson;
TextureResourceList m_ImagesList; std::vector<std::unique_ptr<TextureResource>> m_ImagesList;
ImVec2 m_ImageSize; ImVec2 m_ImageSize;
bool m_bTexturesLoaded = false; bool m_bTexturesLoaded = false;

View File

@ -5,7 +5,10 @@
#include "vehicle.h" #include "vehicle.h"
#include "cheatmenu.h" #include "cheatmenu.h"
char asciitolower(char in) // discord server ids
const char* id = BY_GAME("951199292981403669", "951448264195059712", "951457540573655080");
static char asciitolower(char in)
{ {
if (in <= 'Z' && in >= 'A') if (in <= 'Z' && in >= 'A')
{ {
@ -19,13 +22,20 @@ void RPC::Shutdown()
{ {
if (f_ShutDown) if (f_ShutDown)
{ {
CallDyn<>(int(f_ShutDown)); CallDyn<>(reinterpret_cast<int>(f_ShutDown));
} }
} }
void RPC::Init() void RPC::Init()
{ {
std::string Id = BY_GAME("951199292981403669", "951448264195059712", "951457540573655080"); const char* dllPath = PLUGIN_PATH((char*)"CheatMenu/dlls/discord-rpc.dll");
// check if the dll exits
if (!std::filesystem::exists(dllPath))
{
gLog << TEXT("Menu.DiscordRPCNoDll") << std::endl;
return;
}
if (!hDll) if (!hDll)
{ {
@ -34,7 +44,7 @@ void RPC::Init()
f_Update = NULL; f_Update = NULL;
f_ShutDown = NULL; f_ShutDown = NULL;
hDll = LoadLibrary(PLUGIN_PATH((char*)"CheatMenu/dlls/discord-rpc.dll")); hDll = LoadLibrary(dllPath);
if (hDll) if (hDll)
{ {
@ -46,13 +56,13 @@ void RPC::Init()
if (f_Init) if (f_Init)
{ {
CallDyn<const char*, int, int, int>((int)f_Init, Id.c_str(), NULL, NULL, NULL); CallDyn<const char*, int, int, int>((int)f_Init, id, NULL, NULL, NULL);
drpc.startTimestamp = time(0); drpc.startTimestamp = time(0);
bInit = true; bInit = true;
} }
else else
{ {
gLog << "Failed to init discord rpc" << std::endl; gLog << TEXT("Menu.DiscordRPCInitFailed") << std::endl;
} }
} }

View File

@ -1,9 +1,13 @@
#pragma once #pragma once
/*
* Discord Rich Presence Class
* Handles connection with discord
*/
class RPC class RPC
{ {
private: private:
typedef struct struct DiscordRichPresence
{ {
const char* state; const char* state;
const char* details; const char* details;
@ -20,7 +24,7 @@ private:
const char* joinSecret; const char* joinSecret;
const char* spectateSecret; const char* spectateSecret;
char instance; char instance;
} DiscordRichPresence; };
static inline FARPROC f_Init, f_ShutDown, f_Update; static inline FARPROC f_Init, f_ShutDown, f_Update;
static inline DiscordRichPresence drpc; static inline DiscordRichPresence drpc;

View File

@ -11,7 +11,7 @@ bool Ui::DrawTitleBar()
ImGuiWindow* window = g.CurrentWindow; ImGuiWindow* window = g.CurrentWindow;
ImGuiID id = window->GetID("#CLOSE"); ImGuiID id = window->GetID("#CLOSE");
ImGui::PushFont(FontMgr::GetFont("title")); ImGui::PushFont(FontMgr::Get("title"));
CenterdText(MENU_TITLE); CenterdText(MENU_TITLE);
if (!ImGui::IsWindowHovered(ImGuiHoveredFlags_RootWindow | ImGuiHoveredFlags_ChildWindows if (!ImGui::IsWindowHovered(ImGuiHoveredFlags_RootWindow | ImGuiHoveredFlags_ChildWindows
@ -792,10 +792,14 @@ void Ui::EditBits(const char* label, const int address, const std::vector<std::s
bool state = *mem_val & mask; bool state = *mem_val & mask;
if (ImGui::Checkbox(names[i].c_str(), &state)) if (ImGui::Checkbox(names[i].c_str(), &state))
{
*mem_val ^= mask; *mem_val ^= mask;
}
if (i + 1 == 32 / 2) if (i + 1 == 32 / 2)
{
ImGui::NextColumn(); ImGui::NextColumn();
}
} }
ImGui::Columns(1); ImGui::Columns(1);

View File

@ -21,8 +21,14 @@ public:
Updater() = delete; Updater() = delete;
Updater(const Updater&) = delete; Updater(const Updater&) = delete;
/*
Checks for update on GitHub
This might freeze the current thread!
*/
static void CheckUpdate(); static void CheckUpdate();
static std::string GetUpdateVersion(); static std::string GetUpdateVersion();
// Is updated version available from GitHub
static bool IsUpdateAvailable(); static bool IsUpdateAvailable();
/* /*
@ -36,5 +42,7 @@ public:
// Needs to run in it's own thread to prevent the game from freezing // Needs to run in it's own thread to prevent the game from freezing
static void Process(); static void Process();
// Resets updater state to IDLE
static void ResetUpdaterState(); static void ResetUpdaterState();
}; };

View File

@ -2,10 +2,8 @@
#include "tchar.h" #include "tchar.h"
#include "pdh.h" #include "pdh.h"
/* /*
* Contains utility functions * Contains utility functions
* for all 3 games
*/ */
class Util class Util
{ {

View File

@ -2,5 +2,5 @@
#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 "20220523" #define BUILD_NUMBER "20220612"
#define MENU_TITLE MENU_NAME " v" MENU_VERSION #define MENU_TITLE MENU_NAME " v" MENU_VERSION

View File

@ -1,210 +0,0 @@
#pragma once
#define VK_NONE -1
#define VK_KEY_0 0x30
#define VK_KEY_1 0x31
#define VK_KEY_2 0x32
#define VK_KEY_3 0x33
#define VK_KEY_4 0x34
#define VK_KEY_5 0x35
#define VK_KEY_6 0x36
#define VK_KEY_7 0x37
#define VK_KEY_8 0x38
#define VK_KEY_9 0x39
#define VK_KEY_A 0x41
#define VK_KEY_B 0x42
#define VK_KEY_C 0x43
#define VK_KEY_D 0x44
#define VK_KEY_E 0x45
#define VK_KEY_F 0x46
#define VK_KEY_G 0x47
#define VK_KEY_H 0x48
#define VK_KEY_I 0x49
#define VK_KEY_J 0x4A
#define VK_KEY_K 0x4B
#define VK_KEY_L 0x4C
#define VK_KEY_M 0x4D
#define VK_KEY_N 0x4E
#define VK_KEY_O 0x4F
#define VK_KEY_P 0x50
#define VK_KEY_Q 0x51
#define VK_KEY_R 0x52
#define VK_KEY_S 0x53
#define VK_KEY_T 0x54
#define VK_KEY_U 0x55
#define VK_KEY_V 0x56
#define VK_KEY_W 0x57
#define VK_KEY_X 0x58
#define VK_KEY_Y 0x59
#define VK_KEY_Z 0x5A
static std::string key_names[]
{
"LMB",
"RMB",
"Cancel",
"MMB",
"X1MB",
"X2MB",
"Unknown1",
"Back",
"Tab",
"Reserved1",
"Reserved2",
"Clear",
"Enter",
"Unknown2",
"Unknown3",
"Shift",
"Ctrl",
"Alt",
"Pause",
"Capslock",
"IME",
"IME2",
"IME3",
"Unknown4",
"IME4",
"Unknown5",
"Esc",
"IME5"
"IME6",
"IME7",
"IME8",
"IME9",
"Space",
"Pup",
"Pdown",
"End",
"Home",
"Left",
"Up",
"Right",
"Down",
"Select",
"Print",
"Execute",
"Print Screen",
"INS",
"Del",
"Help",
"0",
"1",
"2",
"3",
"4",
"5",
"6",
"7",
"8",
"9",
"Unknown6",
"Unknown7",
"Unknown8",
"Unknown9",
"Unknown10",
"Unknown11",
"Unknown12",
"A",
"B",
"C",
"D",
"E",
"F",
"G",
"H",
"I",
"J",
"K",
"L",
"M",
"N",
"O",
"P",
"Q",
"R",
"S",
"T",
"U",
"V",
"W",
"X",
"Y",
"Z",
"LWin",
"RWin",
"Apps",
"Unknown11",
"Sleep",
"Numpad 0",
"Numpad 1",
"Numpad 2",
"Numpad 3",
"Numpad 4",
"Numpad 5",
"Numpad 6",
"Numpad 7",
"Numpad 8",
"Numpad 9",
"Multiply",
"Add",
"Separator",
"Substract",
"Decimal",
"Divide",
"F1",
"F2",
"F3",
"F4",
"F5",
"F6",
"F7",
"F8",
"F9",
"F10",
"F11",
"F12",
"F13",
"F14",
"F15",
"F16",
"F17",
"F18",
"F19",
"F20",
"F21",
"F22",
"F23",
"F24",
"Unknown12",
"Unknown13",
"Unknown14",
"Unknown15",
"Unknown16",
"Unknown17",
"Unknown18",
"Numlock",
"Scroll",
"Unknown19",
"Unknown20",
"Unknown21",
"Unknown22",
"Unknown23",
"Unknown24",
"Unknown25",
"Unknown26",
"Unknown27",
"Unknown28",
"Unknown29",
"Unknown30",
"Unknown31",
"Unknown32",
"Unknown33",
"LShift",
"RShift",
"LCtrl",
"RCtrl",
"LMenu",
"RMenu"
};

View File

@ -9,4 +9,4 @@ set "III_DIR="F:\GTA3""
cd tools cd tools
premake5.exe vs2022 premake5.exe vs2022
cd ../build cd ../build
call "C:\Program Files (x86)\Microsoft Visual Studio\2022\BuildTools\Common7\Tools\VsDevCmd.bat" call "C:\Program Files\Microsoft Visual Studio\2022\Community\Common7\Tools\VsDevCmd.bat"