Refactor code & add more language keys
This commit is contained in:
parent
7b0fa7c7f6
commit
425137e82e
@ -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",
|
||||||
|
@ -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,8 +163,10 @@ 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();
|
||||||
ImGui::Dummy(ImVec2(0, 10));
|
ImGui::Dummy(ImVec2(0, 10));
|
||||||
@ -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()
|
||||||
|
@ -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();
|
||||||
};
|
};
|
||||||
|
@ -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;
|
||||||
|
@ -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();
|
||||||
|
@ -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();
|
||||||
}
|
}
|
@ -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();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -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();
|
||||||
|
170
src/hotkeys.cpp
170
src/hotkeys.cpp
@ -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)
|
||||||
{
|
{
|
||||||
|
@ -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.
|
||||||
|
@ -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;
|
||||||
|
15
src/neon.h
15
src/neon.h
@ -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);
|
||||||
};
|
};
|
||||||
|
@ -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"};
|
||||||
|
@ -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;
|
||||||
|
@ -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);
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
22
src/rpc.cpp
22
src/rpc.cpp
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
@ -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,11 +792,15 @@ 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);
|
||||||
|
|
||||||
ImGui::Spacing();
|
ImGui::Spacing();
|
||||||
|
@ -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();
|
||||||
};
|
};
|
||||||
|
@ -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
|
||||||
{
|
{
|
||||||
|
@ -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
|
||||||
|
210
src/vkeys.h
210
src/vkeys.h
@ -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"
|
|
||||||
};
|
|
@ -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"
|
||||||
|
Loading…
Reference in New Issue
Block a user