From e5a2d4ff42ab571aaca1d0f61901260eeb9ac3ef Mon Sep 17 00:00:00 2001 From: d22tny Date: Wed, 20 Nov 2024 19:31:57 +0200 Subject: [PATCH] feat(extra-natives/five): visual settings getter native --- .../src/VisualSettingsNatives.cpp | 39 ++++++++++++++----- ext/native-decls/GetVisualSettingFloat.md | 17 ++++++++ 2 files changed, 46 insertions(+), 10 deletions(-) create mode 100644 ext/native-decls/GetVisualSettingFloat.md diff --git a/code/components/extra-natives-five/src/VisualSettingsNatives.cpp b/code/components/extra-natives-five/src/VisualSettingsNatives.cpp index 60b26c4d1a..cc276c9ba5 100644 --- a/code/components/extra-natives-five/src/VisualSettingsNatives.cpp +++ b/code/components/extra-natives-five/src/VisualSettingsNatives.cpp @@ -114,6 +114,25 @@ static InitFunction initFunction([]() } }); + fx::ScriptEngine::RegisterNativeHandler("GET_VISUAL_SETTING_FLOAT", [](fx::ScriptContext& context) + { + const char* settingName = context.CheckArgument(0); + auto settingHash = HashString(settingName); + + for (int i = 0; i < g_visualSettings->entries.GetCount(); ++i) + { + const VisualSettingsEntry& entry = g_visualSettings->entries[i]; + if (entry.entryHash == settingHash) + { + context.SetResult(entry.value); + return; + } + } + + std::string error = va("Visual setting '%s' doesn't exist.", settingName); + throw std::runtime_error(error); + }); + OnMainGameFrame.Connect([=]() { std::function func; @@ -127,18 +146,18 @@ static InitFunction initFunction([]() static HookFunction hookFunction([]() { -#ifdef GTA_FIVE - g_visualSettings = hook::get_address(hook::get_pattern("48 83 25 ? ? ? ? 00 48 8D ? ? ? ? ? E8 ? ? ? ? E8", 11)); -#elif IS_RDR3 - g_visualSettings = hook::get_address(hook::get_pattern("48 89 2D ? ? ? ? E8 ? ? ? ? E8 ? ? ? ? 48 8D 0D", -11)); -#endif + #ifdef GTA_FIVE + g_visualSettings = hook::get_address(hook::get_pattern("48 83 25 ? ? ? ? 00 48 8D ? ? ? ? ? E8 ? ? ? ? E8", 11)); + #elif IS_RDR3 + g_visualSettings = hook::get_address(hook::get_pattern("48 89 2D ? ? ? ? E8 ? ? ? ? E8 ? ? ? ? 48 8D 0D", -11)); + #endif { -#ifdef GTA_FIVE - auto location = (char*)hook::get_call(hook::get_pattern("48 83 25 ? ? ? ? 00 48 8D ? ? ? ? ? E8 ? ? ? ? E8", 15)); -#elif IS_RDR3 - auto location = (char*)hook::get_call(hook::get_pattern("48 89 2D ? ? ? ? E8 ? ? ? ? E8 ? ? ? ? 48 8D 0D", 7)); -#endif + #ifdef GTA_FIVE + auto location = (char*)hook::get_call(hook::get_pattern("48 83 25 ? ? ? ? 00 48 8D ? ? ? ? ? E8 ? ? ? ? E8", 15)); + #elif IS_RDR3 + auto location = (char*)hook::get_call(hook::get_pattern("48 89 2D ? ? ? ? E8 ? ? ? ? E8 ? ? ? ? 48 8D 0D", 7)); + #endif hook::set_call(&g_origLoadVisualSettingsDat, location + 0x12); hook::call(location + 0x12, LoadVisualSettingsDatStub); diff --git a/ext/native-decls/GetVisualSettingFloat.md b/ext/native-decls/GetVisualSettingFloat.md new file mode 100644 index 0000000000..194c982ef3 --- /dev/null +++ b/ext/native-decls/GetVisualSettingFloat.md @@ -0,0 +1,17 @@ +--- +ns: CFX +apiset: client +--- +## GET_VISUAL_SETTING_FLOAT + +```c +float GET_VISUAL_SETTING_FLOAT(char* name); +``` + +A getter for [SET_VISUAL_SETTING_FLOAT](#_0xD1D31681). + +## Parameters +* **name**: The name of the value to get, such as `pedLight.color.red`. + +## Return value +Returns the floating point value of the specified visual setting on success. \ No newline at end of file