mirror of
https://github.com/SunsetMkt/Akebi-GC.git
synced 2025-01-09 02:53:43 +08:00
add auto in custom teleport
This commit is contained in:
parent
582f5e31fa
commit
c4f9d18fda
@ -17,15 +17,19 @@
|
|||||||
namespace cheat::feature
|
namespace cheat::feature
|
||||||
{
|
{
|
||||||
CustomTeleports::CustomTeleports() : Feature(),
|
CustomTeleports::CustomTeleports() : Feature(),
|
||||||
NF(f_Enabled, "Custom Teleport", "CustomTeleports", false),
|
NF(f_Enabled, "Custom Teleport", "CustomTeleports", false),
|
||||||
NF(f_Next, "Teleport Next", "CustomTeleports", Hotkey(VK_OEM_6)),
|
NF(f_Next, "Teleport Next", "CustomTeleports", Hotkey(VK_OEM_6)),
|
||||||
NF(f_Previous, "Teleport Previous", "CustomTeleports", Hotkey(VK_OEM_4)),
|
NF(f_Previous, "Teleport Previous", "CustomTeleports", Hotkey(VK_OEM_4)),
|
||||||
NF(f_Interpolate, "Custom Teleport", "CustomTeleports", false),
|
NF(f_Auto, "Auto Teleport", "CustomTeleports", false),
|
||||||
NF(f_Speed, "Interpolation Speed", "CustomTeleports", 10.0f),
|
NF(f_DelayTime, "Delay time (in s)", "CustomTeleports", 20),
|
||||||
dir(util::GetCurrentPath() / "teleports")
|
NF(f_Interpolate, "Interpolate Teleport", "CustomTeleports", false),
|
||||||
|
NF(f_Speed, "Interpolation Speed", "CustomTeleports", 10.0f),
|
||||||
|
dir(util::GetCurrentPath() / "teleports"),
|
||||||
|
nextTime(0)
|
||||||
{
|
{
|
||||||
f_Next.value().PressedEvent += MY_METHOD_HANDLER(CustomTeleports::OnNext);
|
f_Next.value().PressedEvent += MY_METHOD_HANDLER(CustomTeleports::OnNext);
|
||||||
f_Previous.value().PressedEvent += MY_METHOD_HANDLER(CustomTeleports::OnPrevious);
|
f_Previous.value().PressedEvent += MY_METHOD_HANDLER(CustomTeleports::OnPrevious);
|
||||||
|
events::GameUpdateEvent += MY_METHOD_HANDLER(CustomTeleports::OnGameUpdate);
|
||||||
}
|
}
|
||||||
|
|
||||||
const FeatureGUIInfo& CustomTeleports::GetGUIInfo() const
|
const FeatureGUIInfo& CustomTeleports::GetGUIInfo() const
|
||||||
@ -188,13 +192,38 @@ namespace cheat::feature
|
|||||||
|
|
||||||
void CustomTeleports::OnPrevious()
|
void CustomTeleports::OnPrevious()
|
||||||
{
|
{
|
||||||
|
if (f_Auto) return;
|
||||||
OnTeleportKeyPressed(false);
|
OnTeleportKeyPressed(false);
|
||||||
}
|
}
|
||||||
void CustomTeleports::OnNext()
|
void CustomTeleports::OnNext()
|
||||||
{
|
{
|
||||||
|
if (f_Auto) return;
|
||||||
OnTeleportKeyPressed(true);
|
OnTeleportKeyPressed(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CustomTeleports::OnGameUpdate()
|
||||||
|
{
|
||||||
|
if (!f_Enabled || !f_Auto)
|
||||||
|
return;
|
||||||
|
|
||||||
|
auto currentTime = util::GetCurrentTimeMillisec();
|
||||||
|
if (currentTime < nextTime)
|
||||||
|
return;
|
||||||
|
|
||||||
|
auto loadingManager = GET_SINGLETON(MoleMole_LoadingManager);
|
||||||
|
if (loadingManager == nullptr || !app::MoleMole_LoadingManager_IsLoaded(loadingManager, nullptr))
|
||||||
|
return;
|
||||||
|
|
||||||
|
auto camera = app::Camera_get_main(nullptr);
|
||||||
|
if (camera == nullptr) return;
|
||||||
|
|
||||||
|
if (!app::Behaviour_get_isActiveAndEnabled(reinterpret_cast<app::Behaviour*>(camera), nullptr))
|
||||||
|
return;
|
||||||
|
|
||||||
|
nextTime = currentTime + (int64_t)f_DelayTime * 1000;
|
||||||
|
OnTeleportKeyPressed(true);
|
||||||
|
}
|
||||||
|
|
||||||
void itr(std::regex exp, std::string name, std::string s)
|
void itr(std::regex exp, std::string name, std::string s)
|
||||||
{
|
{
|
||||||
std::sregex_iterator itr(name.begin(), name.end(), exp);
|
std::sregex_iterator itr(name.begin(), name.end(), exp);
|
||||||
@ -267,19 +296,22 @@ namespace cheat::feature
|
|||||||
}
|
}
|
||||||
ImGui::InputTextMultiline("JSON input", &JSONBuffer_, ImVec2(0, 50), ImGuiInputTextFlags_AllowTabInput);
|
ImGui::InputTextMultiline("JSON input", &JSONBuffer_, ImVec2(0, 50), ImGuiInputTextFlags_AllowTabInput);
|
||||||
|
|
||||||
ConfigWidget("Teleport Next", f_Next, true, "Press to teleport next of selected");
|
ConfigWidget("Teleport Next", f_Next, true, "Press to teleport next of selected.");
|
||||||
ConfigWidget("Teleport Previous", f_Previous, true, "Press to teleport previous of selected");
|
ConfigWidget("Teleport Previous", f_Previous, true, "Press to teleport previous of selected.");
|
||||||
ConfigWidget("Enable", f_Enabled,
|
ConfigWidget("Enable", f_Enabled,
|
||||||
"Enable teleport-through-list functionality\n"
|
"Enable teleport-through-list functionality.\n"
|
||||||
"Usage:\n"
|
"Usage:\n"
|
||||||
"1. Put Checkmark to the teleports you want to teleport using hotkey\n"
|
"1. Put Checkmark to the teleports you want to teleport using hotkey\n"
|
||||||
"2. Single click the teleport (with checkmark) to select where you want to start\n"
|
"2. Single click the teleport (with checkmark) to select where you want to start\n"
|
||||||
"3. You can now press Next or Previous Hotkey to Teleport through the Checklist\n"
|
"3. You can now press Next or Previous Hotkey to Teleport through the Checklist\n"
|
||||||
"Initially it will teleport the player to the selection made\n"
|
"Initially it will teleport the player to the selection made\n"
|
||||||
"Note: Double click or click the arrow to open teleport details");
|
"Note: Double click or click the arrow to open teleport details");
|
||||||
ConfigWidget("Enable Interpolation", f_Interpolate, "Enable interpolation between teleports when using keybinds");
|
ConfigWidget("Enable Interpolation", f_Interpolate, "Enable interpolation between teleports when using keybinds."); ImGui::SameLine(); ImGui::SetNextItemWidth(300.0f);
|
||||||
ConfigWidget("Interpolation Speed", f_Speed, 0.1f, 0.1f, 99.0f,
|
ConfigWidget("Interpolation Speed", f_Speed, 0.1f, 0.1f, 99.0f,
|
||||||
"Interpolation speed.\n recommended setting below or equal to 0.1.");
|
"Interpolation speed.\n recommended setting below or equal to 0.1.");
|
||||||
|
ConfigWidget("Auto Teleport", f_Auto, "Enable automatic forward teleporation between teleports"); ImGui::SameLine(); ImGui::SetNextItemWidth(300.0f);
|
||||||
|
ConfigWidget("Delay Time (s)", f_DelayTime, 1, 0, 60, "Delay (in s) between teleport.\n"
|
||||||
|
"Note: This is not fully tested detection-wise.\nNot recommended with low values.");
|
||||||
|
|
||||||
if (ImGui::Button("Delete Checked"))
|
if (ImGui::Button("Delete Checked"))
|
||||||
{
|
{
|
||||||
@ -396,9 +428,12 @@ namespace cheat::feature
|
|||||||
|
|
||||||
if (ImGui::Button(("Select##Button" + stringIndex).c_str()))
|
if (ImGui::Button(("Select##Button" + stringIndex).c_str()))
|
||||||
{
|
{
|
||||||
selectedIndex = index;
|
auto isChecked = checkedIndices.find(index) != checkedIndices.end();
|
||||||
selectedByClick = true;
|
if (isChecked) {
|
||||||
UpdateIndexName();
|
selectedIndex = index;
|
||||||
|
selectedByClick = true;
|
||||||
|
UpdateIndexName();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
ImGui::TableNextColumn();
|
ImGui::TableNextColumn();
|
||||||
|
|
||||||
@ -432,7 +467,7 @@ namespace cheat::feature
|
|||||||
|
|
||||||
void CustomTeleports::DrawStatus()
|
void CustomTeleports::DrawStatus()
|
||||||
{
|
{
|
||||||
ImGui::Text("Custom Teleport\n[%s]", selectedIndexName);
|
ImGui::Text("Custom Teleport\n[%s|%s]", f_Auto ? "Auto" : "Manual", selectedIndexName);
|
||||||
}
|
}
|
||||||
|
|
||||||
CustomTeleports &CustomTeleports::GetInstance()
|
CustomTeleports &CustomTeleports::GetInstance()
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
|
|
||||||
#include <cheat-base/cheat/Feature.h>
|
#include <cheat-base/cheat/Feature.h>
|
||||||
#include <cheat-base/config/Config.h>
|
#include <cheat-base/config/Config.h>
|
||||||
|
#include <cheat-base/thread-safe.h>
|
||||||
#include <set>
|
#include <set>
|
||||||
|
|
||||||
namespace cheat::feature
|
namespace cheat::feature
|
||||||
@ -27,9 +28,11 @@ namespace cheat::feature
|
|||||||
public:
|
public:
|
||||||
config::Field<config::Toggle<Hotkey>> f_Enabled;
|
config::Field<config::Toggle<Hotkey>> f_Enabled;
|
||||||
config::Field<config::Toggle<Hotkey>> f_Interpolate;
|
config::Field<config::Toggle<Hotkey>> f_Interpolate;
|
||||||
|
config::Field<config::Toggle<Hotkey>> f_Auto;
|
||||||
config::Field<float> f_Speed;
|
config::Field<float> f_Speed;
|
||||||
config::Field<Hotkey> f_Next;
|
config::Field<Hotkey> f_Next;
|
||||||
config::Field<Hotkey> f_Previous;
|
config::Field<Hotkey> f_Previous;
|
||||||
|
config::Field<int> f_DelayTime;
|
||||||
static CustomTeleports& GetInstance();
|
static CustomTeleports& GetInstance();
|
||||||
const FeatureGUIInfo& GetGUIInfo() const override;
|
const FeatureGUIInfo& GetGUIInfo() const override;
|
||||||
|
|
||||||
@ -44,6 +47,7 @@ namespace cheat::feature
|
|||||||
void DrawMain() override;
|
void DrawMain() override;
|
||||||
virtual bool NeedStatusDraw() const override;
|
virtual bool NeedStatusDraw() const override;
|
||||||
void DrawStatus() override;
|
void DrawStatus() override;
|
||||||
|
void OnGameUpdate();
|
||||||
|
|
||||||
std::vector<Teleport> Teleports;
|
std::vector<Teleport> Teleports;
|
||||||
std::filesystem::path dir;
|
std::filesystem::path dir;
|
||||||
@ -55,6 +59,7 @@ namespace cheat::feature
|
|||||||
int selectedIndex = -1;
|
int selectedIndex = -1;
|
||||||
std::string selectedName;
|
std::string selectedName;
|
||||||
std::string selectedIndexName;
|
std::string selectedIndexName;
|
||||||
|
SafeValue<int64_t> nextTime;
|
||||||
CustomTeleports();
|
CustomTeleports();
|
||||||
void TeleportTo(app::Vector3 position, bool interpolate);
|
void TeleportTo(app::Vector3 position, bool interpolate);
|
||||||
void OnTeleportKeyPressed(bool next);
|
void OnTeleportKeyPressed(bool next);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user