From ffd79ec387ad72c7d347908e27460f1249b34db1 Mon Sep 17 00:00:00 2001 From: Grinch_ Date: Sun, 10 Jul 2022 00:11:37 +0600 Subject: [PATCH] [SA] Freecam fixes --- resource/common/locale/English.toml | 8 ------ src/game.cpp | 44 +++++++++++++++++++++++------ 2 files changed, 35 insertions(+), 17 deletions(-) diff --git a/resource/common/locale/English.toml b/resource/common/locale/English.toml index 569b30c..1f24e15 100644 --- a/resource/common/locale/English.toml +++ b/resource/common/locale/English.toml @@ -49,14 +49,6 @@ DaysPassed = "Days passed" DisableCheats = "Disable cheats" DisableReplay = "Disable F1 & F3 replay" Enable = "Enable" -EnableText = """ -Forward: I\tBackward: K - -Left: J\t\t Right: L - -Slower: RCtrl\tFaster: RShift - -Zoom: Mouse wheel""" ExtraColors = "Extra colors" ExtraSunny = "Extra sunny" FailMission = "Fail current mission" diff --git a/src/game.cpp b/src/game.cpp index 7ec8241..9ed75ed 100644 --- a/src/game.cpp +++ b/src/game.cpp @@ -81,7 +81,7 @@ void Freecam::Process() SetHelpMessage(TEXT("Game.PlayerTeleported")); } - if (KeyPressed(VK_MENU)) + if (KeyPressed(VK_MENU) && m_nMul > 1) { speed /= 2; } @@ -100,12 +100,20 @@ void Freecam::Process() float angle; Command(m_nPed, &angle); - pos.x += speed * cos(angle * 3.14159f / 180.0f); - pos.y += speed * sin(angle * 3.14159f / 180.0f); - - if (!KeyPressed(VK_SPACE)) + + if (KeyPressed(VK_CONTROL)) { - pos.z += speed * 2 * sin(m_fTotalMouse.y / 3 * 3.14159f / 180.0f); + pos.z += speed * sin(90.0f / 3 * 3.14159f / 180.0f); + } + else + { + pos.x += speed * cos(angle * 3.14159f / 180.0f); + pos.y += speed * sin(angle * 3.14159f / 180.0f); + + if (!KeyPressed(VK_SPACE)) + { + pos.z += speed * 2 * sin(m_fTotalMouse.y / 3 * 3.14159f / 180.0f); + } } } @@ -126,7 +134,7 @@ void Freecam::Process() if (CPad::NewMouseControllerState.wheelUp) { - if (KeyPressed(VK_CONTROL) && m_nMul != 10) + if (KeyPressed(VK_CONTROL)) { if (m_fFOV > 10.0f) { @@ -148,7 +156,7 @@ void Freecam::Process() if (CPad::NewMouseControllerState.wheelDown) { - if (KeyPressed(VK_CONTROL) && m_nMul != 1) + if (KeyPressed(VK_CONTROL)) { if (m_fFOV < 115.0f) { @@ -757,7 +765,7 @@ void Game::ShowPage() if (ImGui::BeginTabItem(TEXT("Game.Freecam"))) { ImGui::Spacing(); - if (Widget::Checkbox(TEXT("Game.Enable"), &Freecam::m_bEnabled, TEXT("Game.EnableText"))) + if (Widget::Checkbox(TEXT("Game.Enable"), &Freecam::m_bEnabled)) { if (!Freecam::m_bEnabled) { @@ -819,6 +827,24 @@ void Game::ShowPage() ImGui::TableNextColumn(); ImGui::Text(freeCamRight.GetNameString().c_str()); + ImGui::TableNextRow(); + ImGui::TableNextColumn(); + ImGui::Text(""); + ImGui::TableNextColumn(); + ImGui::Text(""); + + ImGui::TableNextRow(); + ImGui::TableNextColumn(); + ImGui::Text("Up"); + ImGui::TableNextColumn(); + ImGui::Text((freeCamForward.GetNameString() + " + Ctrl").c_str()); + + ImGui::TableNextRow(); + ImGui::TableNextColumn(); + ImGui::Text("Down"); + ImGui::TableNextColumn(); + ImGui::Text((freeCamBackward.GetNameString() + " + Ctrl").c_str()); + ImGui::TableNextRow(); ImGui::TableNextColumn(); ImGui::Text("");