[SA] Allow quick teleport MapSize to be changable
This commit is contained in:
parent
b555f4449d
commit
46732744c0
@ -405,6 +405,9 @@ Wasted = "Wasted!"
|
|||||||
AddLocation = "Add location"
|
AddLocation = "Add location"
|
||||||
Coordinates = "Coordinates"
|
Coordinates = "Coordinates"
|
||||||
CustomLocationRemoveOnly = "You can only remove custom location"
|
CustomLocationRemoveOnly = "You can only remove custom location"
|
||||||
|
CustomMapSize = "Custom map size"
|
||||||
|
CustomMapSizeHint = "Custom game map size for quick teleport. Only needed for Total Conversion mods (SAxVCxLC)"
|
||||||
|
Height = "Height"
|
||||||
InsertCoord = "Insert coordinates"
|
InsertCoord = "Insert coordinates"
|
||||||
InvalidCoord = "Invalid coordinates"
|
InvalidCoord = "Invalid coordinates"
|
||||||
InvalidLocation = "Invalid location"
|
InvalidLocation = "Invalid location"
|
||||||
@ -420,6 +423,7 @@ TargetBlipText = "Target blip not found. You need to place it on the map first"
|
|||||||
TeleportCenter = "Teleport to center"
|
TeleportCenter = "Teleport to center"
|
||||||
TeleportMarker = "Teleport to marker"
|
TeleportMarker = "Teleport to marker"
|
||||||
TeleportToCoord = "Teleport to coordinates"
|
TeleportToCoord = "Teleport to coordinates"
|
||||||
|
Width = "Width"
|
||||||
|
|
||||||
[Updater]
|
[Updater]
|
||||||
Failed = "Failed to check for updates"
|
Failed = "Failed to check for updates"
|
||||||
|
@ -22,21 +22,41 @@ public:
|
|||||||
DataStore(const char* fileName, bool isPathPredefined = false) noexcept;
|
DataStore(const char* fileName, bool isPathPredefined = false) noexcept;
|
||||||
|
|
||||||
// Returns data from store structure
|
// Returns data from store structure
|
||||||
std::string Get(const char* key, const char* defaultVal) noexcept
|
std::string Get(const char* key, const char* defaultVal, bool writeOnNone = false) noexcept
|
||||||
{
|
{
|
||||||
if (pTable)
|
if (pTable)
|
||||||
{
|
{
|
||||||
return (*pTable).at_path(key).value_or(defaultVal);
|
std::optional<std::string> option = pTable->at_path(key).value<std::string>();
|
||||||
|
|
||||||
|
if (option.has_value())
|
||||||
|
{
|
||||||
|
return option.value();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (writeOnNone)
|
||||||
|
{
|
||||||
|
Set(key, std::string(defaultVal));
|
||||||
}
|
}
|
||||||
return defaultVal;
|
return defaultVal;
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
T Get(const char* key, const T& defaultVal) noexcept
|
T Get(const char* key, const T& defaultVal, bool writeOnNone = false) noexcept
|
||||||
{
|
{
|
||||||
if (pTable)
|
if (pTable)
|
||||||
{
|
{
|
||||||
return (*pTable).at_path(key).value_or(defaultVal);
|
std::optional<T> option = pTable->at_path(key).value<T>();
|
||||||
|
|
||||||
|
if (option.has_value())
|
||||||
|
{
|
||||||
|
return option.value();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (writeOnNone)
|
||||||
|
{
|
||||||
|
Set(key, defaultVal);
|
||||||
}
|
}
|
||||||
return defaultVal;
|
return defaultVal;
|
||||||
}
|
}
|
||||||
|
@ -86,7 +86,8 @@ void Menu::ShowPage()
|
|||||||
ImGui::Spacing();
|
ImGui::Spacing();
|
||||||
ImGui::Spacing();
|
ImGui::Spacing();
|
||||||
ImGui::SameLine();
|
ImGui::SameLine();
|
||||||
if (ImGui::Combo(TEXT("Menu.Position"), (int*)&Overlay::m_nSelectedPos, "Custom\0Top left\0Top right\0Bottom left\0Bottom right\0"))
|
if (ImGui::Combo(TEXT("Menu.Position"), reinterpret_cast<int*>(&Overlay::m_nSelectedPos),
|
||||||
|
"Custom\0Top left\0Top right\0Bottom left\0Bottom right\0"))
|
||||||
{
|
{
|
||||||
gConfig.Set<int>("Overlay.SelectedPosition", static_cast<int>(Overlay::m_nSelectedPos));
|
gConfig.Set<int>("Overlay.SelectedPosition", static_cast<int>(Overlay::m_nSelectedPos));
|
||||||
}
|
}
|
||||||
@ -129,13 +130,13 @@ void Menu::ShowPage()
|
|||||||
gConfig.Set("Overlay.ShowLocationName", Overlay::m_bLocName);
|
gConfig.Set("Overlay.ShowLocationName", Overlay::m_bLocName);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ImGui::NextColumn();
|
||||||
|
|
||||||
if (ImGui::Checkbox(TEXT("Menu.ShowModelInfo"), &Overlay::m_bModelInfo))
|
if (ImGui::Checkbox(TEXT("Menu.ShowModelInfo"), &Overlay::m_bModelInfo))
|
||||||
{
|
{
|
||||||
gConfig.Set("Overlay.ShowModelInfo", Overlay::m_bModelInfo);
|
gConfig.Set("Overlay.ShowModelInfo", Overlay::m_bModelInfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
ImGui::NextColumn();
|
|
||||||
|
|
||||||
if (ImGui::Checkbox(TEXT("Menu.ShowPedTasks"), &Overlay::m_bPedTasks))
|
if (ImGui::Checkbox(TEXT("Menu.ShowPedTasks"), &Overlay::m_bPedTasks))
|
||||||
{
|
{
|
||||||
gConfig.Set("Overlay.ShowPedTasks", Overlay::m_bPedTasks);
|
gConfig.Set("Overlay.ShowPedTasks", Overlay::m_bPedTasks);
|
||||||
|
@ -23,7 +23,7 @@ void Overlay::Init()
|
|||||||
m_bMemUsage = gConfig.Get("Overlay.ShowMemoryUsage", false);
|
m_bMemUsage = gConfig.Get("Overlay.ShowMemoryUsage", false);
|
||||||
m_bVehHealth = gConfig.Get("Overlay.ShowVehicleHealth", false);
|
m_bVehHealth = gConfig.Get("Overlay.ShowVehicleHealth", false);
|
||||||
m_bVehSpeed = gConfig.Get("Overlay.ShowVehicleSpeed", false);
|
m_bVehSpeed = gConfig.Get("Overlay.ShowVehicleSpeed", false);
|
||||||
m_nSelectedPos = (DisplayPos)gConfig.Get("Overlay.SelectedPosition", (int)DisplayPos::BOTTOM_RIGHT);
|
m_nSelectedPos = (eDisplayPos)gConfig.Get("Overlay.SelectedPosition", (int)eDisplayPos::BottomRight);
|
||||||
m_fPos.x = gConfig.Get("Overlay.PosX", 0);
|
m_fPos.x = gConfig.Get("Overlay.PosX", 0);
|
||||||
m_fPos.y = gConfig.Get("Overlay.PosY", 0);
|
m_fPos.y = gConfig.Get("Overlay.PosY", 0);
|
||||||
m_fTextCol[0] = gConfig.Get("Overlay.TextColor.Red", 1.0f);
|
m_fTextCol[0] = gConfig.Get("Overlay.TextColor.Red", 1.0f);
|
||||||
@ -154,6 +154,7 @@ void Overlay::ProcessPedTasks()
|
|||||||
for (size_t i = 0; i != TASK_SECONDARY_MAX; ++i)
|
for (size_t i = 0; i != TASK_SECONDARY_MAX; ++i)
|
||||||
{
|
{
|
||||||
CTask *pTask = pPed->m_pIntelligence->m_TaskMgr.m_aSecondaryTasks[i];
|
CTask *pTask = pPed->m_pIntelligence->m_TaskMgr.m_aSecondaryTasks[i];
|
||||||
|
|
||||||
if (pTask)
|
if (pTask)
|
||||||
{
|
{
|
||||||
const char *name = taskNames[pTask->GetId()];
|
const char *name = taskNames[pTask->GetId()];
|
||||||
@ -379,7 +380,7 @@ void Overlay::ProcessInfoBox()
|
|||||||
ImGuiWindowFlags window_flags = ImGuiWindowFlags_NoDecoration | ImGuiWindowFlags_AlwaysAutoResize |
|
ImGuiWindowFlags window_flags = ImGuiWindowFlags_NoDecoration | ImGuiWindowFlags_AlwaysAutoResize |
|
||||||
ImGuiWindowFlags_NoSavedSettings | ImGuiWindowFlags_NoFocusOnAppearing | ImGuiWindowFlags_NoNav;
|
ImGuiWindowFlags_NoSavedSettings | ImGuiWindowFlags_NoFocusOnAppearing | ImGuiWindowFlags_NoNav;
|
||||||
|
|
||||||
if (m_nSelectedPos == DisplayPos::CUSTOM)
|
if (m_nSelectedPos == eDisplayPos::Custom)
|
||||||
{
|
{
|
||||||
if (m_fPos.x != NULL && m_fPos.y != NULL)
|
if (m_fPos.x != NULL && m_fPos.y != NULL)
|
||||||
{
|
{
|
||||||
@ -393,25 +394,25 @@ void Overlay::ProcessInfoBox()
|
|||||||
window_flags |= ImGuiWindowFlags_NoMove;
|
window_flags |= ImGuiWindowFlags_NoMove;
|
||||||
ImVec2 pos, pivot;
|
ImVec2 pos, pivot;
|
||||||
|
|
||||||
if (m_nSelectedPos == DisplayPos::TOP_LEFT)
|
if (m_nSelectedPos == eDisplayPos::TopLeft)
|
||||||
{
|
{
|
||||||
pos = ImVec2(offset, offset);
|
pos = ImVec2(offset, offset);
|
||||||
pivot = ImVec2(0.0f, 0.0f);
|
pivot = ImVec2(0.0f, 0.0f);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_nSelectedPos == DisplayPos::TOP_RIGHT)
|
if (m_nSelectedPos == eDisplayPos::TopRight)
|
||||||
{
|
{
|
||||||
pos = ImVec2(io.DisplaySize.x - offset, offset);
|
pos = ImVec2(io.DisplaySize.x - offset, offset);
|
||||||
pivot = ImVec2(1.0f, 0.0f);
|
pivot = ImVec2(1.0f, 0.0f);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_nSelectedPos == DisplayPos::BOTTOM_LEFT)
|
if (m_nSelectedPos == eDisplayPos::BottomLeft)
|
||||||
{
|
{
|
||||||
pos = ImVec2(offset, io.DisplaySize.y - offset);
|
pos = ImVec2(offset, io.DisplaySize.y - offset);
|
||||||
pivot = ImVec2(0.0f, 1.0f);
|
pivot = ImVec2(0.0f, 1.0f);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_nSelectedPos == DisplayPos::BOTTOM_RIGHT)
|
if (m_nSelectedPos == eDisplayPos::BottomRight)
|
||||||
{
|
{
|
||||||
pos = ImVec2(io.DisplaySize.x - offset, io.DisplaySize.y - offset);
|
pos = ImVec2(io.DisplaySize.x - offset, io.DisplaySize.y - offset);
|
||||||
pivot = ImVec2(1.0f, 1.0f);
|
pivot = ImVec2(1.0f, 1.0f);
|
||||||
|
@ -11,13 +11,13 @@
|
|||||||
class Overlay
|
class Overlay
|
||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
enum DisplayPos
|
enum class eDisplayPos
|
||||||
{
|
{
|
||||||
CUSTOM,
|
Custom,
|
||||||
TOP_LEFT,
|
TopLeft,
|
||||||
TOP_RIGHT,
|
TopRight,
|
||||||
BOTTOM_LEFT,
|
BottomLeft,
|
||||||
BOTTOM_RIGHT
|
BottomRight
|
||||||
};
|
};
|
||||||
static inline std::vector<CEntity*> m_EntityList;
|
static inline std::vector<CEntity*> m_EntityList;
|
||||||
static inline const float m_fMaxDistance = 50.0f;
|
static inline const float m_fMaxDistance = 50.0f;
|
||||||
@ -53,7 +53,7 @@ public:
|
|||||||
static inline bool m_bVehHealth;
|
static inline bool m_bVehHealth;
|
||||||
static inline bool m_bVehSpeed;
|
static inline bool m_bVehSpeed;
|
||||||
static inline float m_fTextCol[4] = {1.0f, 1.0f, 1.0f, 1.0f};
|
static inline float m_fTextCol[4] = {1.0f, 1.0f, 1.0f, 1.0f};
|
||||||
static inline DisplayPos m_nSelectedPos = DisplayPos::BOTTOM_RIGHT;
|
static inline eDisplayPos m_nSelectedPos = eDisplayPos::BottomRight;
|
||||||
|
|
||||||
Overlay() = delete;
|
Overlay() = delete;
|
||||||
Overlay(Overlay&) = delete;
|
Overlay(Overlay&) = delete;
|
||||||
|
@ -38,6 +38,8 @@ void Teleport::Init()
|
|||||||
{
|
{
|
||||||
m_bTeleportMarker = gConfig.Get("Features.TeleportMarker", false);
|
m_bTeleportMarker = gConfig.Get("Features.TeleportMarker", false);
|
||||||
m_bQuickTeleport = gConfig.Get("Features.QuickTeleport", false);
|
m_bQuickTeleport = gConfig.Get("Features.QuickTeleport", false);
|
||||||
|
m_fMapSize.x = gConfig.Get("Game.MapSizeX", 6000.0f);
|
||||||
|
m_fMapSize.y = gConfig.Get("Game.MapSizeY", 6000.0f);
|
||||||
|
|
||||||
Events::processScriptsEvent += []
|
Events::processScriptsEvent += []
|
||||||
{
|
{
|
||||||
@ -110,8 +112,8 @@ void Teleport::Init()
|
|||||||
pos.y -= size/2;
|
pos.y -= size/2;
|
||||||
|
|
||||||
// Convert image space to map space
|
// Convert image space to map space
|
||||||
pos.x = pos.x / size * 6000;
|
pos.x = pos.x / size * m_fMapSize.x;
|
||||||
pos.y = pos.y / size * 6000;
|
pos.y = pos.y / size * m_fMapSize.y;
|
||||||
pos.y *= -1;
|
pos.y *= -1;
|
||||||
|
|
||||||
WarpPlayer<eTeleportType::MapPosition>(CVector(pos.x, pos.y, 0.0f));
|
WarpPlayer<eTeleportType::MapPosition>(CVector(pos.x, pos.y, 0.0f));
|
||||||
@ -325,7 +327,34 @@ void Teleport::ShowPage()
|
|||||||
{
|
{
|
||||||
WarpPlayer<eTeleportType::Coordinate>(CVector(0, 0, 23));
|
WarpPlayer<eTeleportType::Coordinate>(CVector(0, 0, 23));
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
ImGui::Dummy(ImVec2(0, 20));
|
||||||
|
|
||||||
|
if (m_bQuickTeleport)
|
||||||
|
{
|
||||||
|
if (ImGui::CollapsingHeader(TEXT("Teleport.CustomMapSize")))
|
||||||
|
{
|
||||||
|
ImGui::TextWrapped(TEXT("Teleport.CustomMapSizeHint"));
|
||||||
|
ImGui::Spacing();
|
||||||
|
if (Widget::InputFloat(TEXT("Teleport.Width"), &m_fMapSize.x, 1.0f, 0.0f, 9999999))
|
||||||
|
{
|
||||||
|
gConfig.Set("Game.MapSizeX", m_fMapSize.x);
|
||||||
|
}
|
||||||
|
if (Widget::InputFloat(TEXT("Teleport.Height"), &m_fMapSize.y, 1.0f, 0.0f, 9999999))
|
||||||
|
{
|
||||||
|
gConfig.Set("Game.MapSizeY", m_fMapSize.y);
|
||||||
|
}
|
||||||
|
ImGui::Spacing();
|
||||||
|
if (ImGui::Button(TEXT("Game.ResetDefault"), Widget::CalcSize()))
|
||||||
|
{
|
||||||
|
m_fMapSize = {6000.0f, 6000.0f};
|
||||||
|
gConfig.Set("Game.MapSizeX", m_fMapSize.x);
|
||||||
|
gConfig.Set("Game.MapSizeY", m_fMapSize.y);
|
||||||
|
}
|
||||||
|
ImGui::Spacing();
|
||||||
|
ImGui::Separator();
|
||||||
|
}
|
||||||
|
}
|
||||||
ImGui::EndChild();
|
ImGui::EndChild();
|
||||||
}
|
}
|
||||||
ImGui::EndTabItem();
|
ImGui::EndTabItem();
|
||||||
|
@ -15,6 +15,7 @@ private:
|
|||||||
static inline bool m_bTeleportMarker;
|
static inline bool m_bTeleportMarker;
|
||||||
static inline char m_nInputBuffer[INPUT_BUFFER_SIZE];
|
static inline char m_nInputBuffer[INPUT_BUFFER_SIZE];
|
||||||
static inline char m_nLocationBuffer[INPUT_BUFFER_SIZE];
|
static inline char m_nLocationBuffer[INPUT_BUFFER_SIZE];
|
||||||
|
static inline ImVec2 m_fMapSize;
|
||||||
|
|
||||||
struct TPMarker
|
struct TPMarker
|
||||||
{
|
{
|
||||||
|
@ -634,6 +634,43 @@ bool Widget::CheckboxBits(const char* label, uint flag, const char* hint)
|
|||||||
return rtn;
|
return rtn;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool Widget::InputFloat(const char* label, float *val, float change, float min, float max)
|
||||||
|
{
|
||||||
|
bool state = false;
|
||||||
|
ImGui::SetNextItemWidth(ImGui::GetWindowContentRegionWidth() / 2.0f);
|
||||||
|
if (ImGui::InputFloat(std::format("##{}", label).c_str(), val))
|
||||||
|
{
|
||||||
|
if (min != max)
|
||||||
|
{
|
||||||
|
*val = (*val < min) ? min : *val;
|
||||||
|
*val = (*val > max) ? max : *val;
|
||||||
|
}
|
||||||
|
state = true;
|
||||||
|
}
|
||||||
|
ImGui::SameLine(0.0, 4.0);
|
||||||
|
int size = ImGui::GetFrameHeight();
|
||||||
|
if (ImGui::Button(std::format("-##{}", label).c_str(), ImVec2(size, size)))
|
||||||
|
{
|
||||||
|
if (min != max && (*val - change) > min)
|
||||||
|
{
|
||||||
|
*val -= change;
|
||||||
|
}
|
||||||
|
state = true;
|
||||||
|
}
|
||||||
|
ImGui::SameLine(0.0, 4.0);
|
||||||
|
if (ImGui::Button(std::format("+##{}", label).c_str(), ImVec2(size, size)))
|
||||||
|
{
|
||||||
|
if (min != max && (*val + change) < max)
|
||||||
|
{
|
||||||
|
*val += change;
|
||||||
|
}
|
||||||
|
state = true;
|
||||||
|
}
|
||||||
|
ImGui::SameLine(0.0, 4.0);
|
||||||
|
ImGui::LabelText(label, "%s", label);
|
||||||
|
return state;
|
||||||
|
}
|
||||||
|
|
||||||
void Widget::EditAddr(const char* label, uint address, float min, float def, float max, float mul, float change)
|
void Widget::EditAddr(const char* label, uint address, float min, float def, float max, float mul, float change)
|
||||||
{
|
{
|
||||||
if (ImGui::CollapsingHeader(label))
|
if (ImGui::CollapsingHeader(label))
|
||||||
@ -665,37 +702,10 @@ void Widget::EditAddr(const char* label, uint address, float min, float def, flo
|
|||||||
|
|
||||||
int size = ImGui::GetFrameHeight();
|
int size = ImGui::GetFrameHeight();
|
||||||
|
|
||||||
if (ImGui::InputFloat(("##" + std::string(label)).c_str(), &val))
|
if (InputFloat(std::format("Set##{}", label).c_str(), &val, change, min, max))
|
||||||
{
|
{
|
||||||
if (val < min)
|
|
||||||
{
|
|
||||||
val = min;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (val > max)
|
|
||||||
{
|
|
||||||
val = max;
|
|
||||||
}
|
|
||||||
patch::SetFloat(address, val / mul);
|
patch::SetFloat(address, val / mul);
|
||||||
}
|
}
|
||||||
|
|
||||||
ImGui::SameLine(0.0, 4.0);
|
|
||||||
if (ImGui::Button("-", ImVec2(size, size)) && (val - change) > min)
|
|
||||||
{
|
|
||||||
val -= change;
|
|
||||||
if (val < min)
|
|
||||||
patch::SetFloat(address, val / mul);
|
|
||||||
}
|
|
||||||
ImGui::SameLine(0.0, 4.0);
|
|
||||||
if (ImGui::Button("+", ImVec2(size, size)) && (val + change) < max)
|
|
||||||
{
|
|
||||||
val += change;
|
|
||||||
patch::SetFloat(address, val / mul);
|
|
||||||
}
|
|
||||||
ImGui::SameLine(0.0, 4.0);
|
|
||||||
ImGui::Text("Set");
|
|
||||||
|
|
||||||
|
|
||||||
ImGui::Spacing();
|
ImGui::Spacing();
|
||||||
|
|
||||||
if (ImGui::Button(("Minimum##" + std::string(label)).c_str(), CalcSize(items)))
|
if (ImGui::Button(("Minimum##" + std::string(label)).c_str(), CalcSize(items)))
|
||||||
|
@ -64,6 +64,9 @@ public:
|
|||||||
// ImGui::TextFilter with hint support
|
// ImGui::TextFilter with hint support
|
||||||
static void Filter(const char* label, ImGuiTextFilter& filter, const char* hint);
|
static void Filter(const char* label, ImGuiTextFilter& filter, const char* hint);
|
||||||
|
|
||||||
|
// Input Float widget with increment & decrement buttons
|
||||||
|
static bool InputFloat(const char* label, float *val, float change = 1.0f, float min = -1.0f, float max = -1.0f);
|
||||||
|
|
||||||
// Draws ResourceStore images in the interface
|
// Draws ResourceStore images in the interface
|
||||||
static void ImageList(ResourceStore &store, ArgCallback clickFunc, ArgCallbackRtn getNameFunc,
|
static void ImageList(ResourceStore &store, ArgCallback clickFunc, ArgCallbackRtn getNameFunc,
|
||||||
ArgCallbackRtnBool verifyFunc = nullptr);
|
ArgCallbackRtnBool verifyFunc = nullptr);
|
||||||
|
Loading…
Reference in New Issue
Block a user