mirror of
https://github.com/Mr-X-GTA/YimMenu.git
synced 2025-01-11 19:42:24 +08:00
feat(Vehicle Controller): Added vehicle window controls (#1607)
* feat(Overlay): Added Invisibility indicator and its able to save on unload * feat(Vehicle Controller): Added vehicle window controls
This commit is contained in:
parent
feeaa2ddbd
commit
13d5d81cea
@ -772,8 +772,9 @@ namespace big
|
|||||||
bool show_infinite_mag = false;
|
bool show_infinite_mag = false;
|
||||||
bool show_aimbot = false;
|
bool show_aimbot = false;
|
||||||
bool show_triggerbot = false;
|
bool show_triggerbot = false;
|
||||||
|
bool show_invisibility = false;
|
||||||
|
|
||||||
NLOHMANN_DEFINE_TYPE_INTRUSIVE(ingame_overlay_indicators, show_player_godmode, show_off_radar, show_vehicle_godmode, show_never_wanted, show_always_full_ammo, show_infinite_ammo, show_infinite_mag, show_aimbot, show_triggerbot)
|
NLOHMANN_DEFINE_TYPE_INTRUSIVE(ingame_overlay_indicators, show_player_godmode, show_off_radar, show_vehicle_godmode, show_never_wanted, show_always_full_ammo, show_infinite_ammo, show_infinite_mag, show_aimbot, show_triggerbot, show_invisibility)
|
||||||
} ingame_overlay_indicators{};
|
} ingame_overlay_indicators{};
|
||||||
|
|
||||||
struct vehicle_control
|
struct vehicle_control
|
||||||
@ -786,7 +787,7 @@ namespace big
|
|||||||
NLOHMANN_DEFINE_TYPE_INTRUSIVE(vehicle_control, operation_animation, max_summon_range, render_distance_on_veh)
|
NLOHMANN_DEFINE_TYPE_INTRUSIVE(vehicle_control, operation_animation, max_summon_range, render_distance_on_veh)
|
||||||
} vehicle_control{};
|
} vehicle_control{};
|
||||||
|
|
||||||
NLOHMANN_DEFINE_TYPE_INTRUSIVE(window, background_color, demo, text_color, button_color, frame_color, gui_scale, switched_view, ingame_overlay, vehicle_control)
|
NLOHMANN_DEFINE_TYPE_INTRUSIVE(window, background_color, demo, text_color, button_color, frame_color, gui_scale, switched_view, ingame_overlay, vehicle_control, ingame_overlay_indicators)
|
||||||
} window{};
|
} window{};
|
||||||
|
|
||||||
struct context_menu
|
struct context_menu
|
||||||
|
@ -1910,6 +1910,15 @@ enum class eDoorId
|
|||||||
VEH_EXT_BOOT
|
VEH_EXT_BOOT
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum class eWindowId
|
||||||
|
{
|
||||||
|
WINDOW_INVALID_ID = -1,
|
||||||
|
FRONT_LEFT_WINDOW = 0,
|
||||||
|
FRONT_RIGHT_WINDOW = 1,
|
||||||
|
REAR_LEFT_WINDOW = 2,
|
||||||
|
REAR_RIGHT_WINDOW = 3,
|
||||||
|
};
|
||||||
|
|
||||||
enum class eVehicleSeats
|
enum class eVehicleSeats
|
||||||
{
|
{
|
||||||
DRIVER = -1,
|
DRIVER = -1,
|
||||||
@ -1920,15 +1929,11 @@ enum class eVehicleSeats
|
|||||||
OUTSIDE_RIGHT,
|
OUTSIDE_RIGHT,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum class eCombatAbilityLevel{
|
enum class eCombatAbilityLevel
|
||||||
|
{
|
||||||
POOR,
|
POOR,
|
||||||
AVERAGE,
|
AVERAGE,
|
||||||
PROFESSIONAL
|
PROFESSIONAL
|
||||||
};
|
};
|
||||||
|
|
||||||
NLOHMANN_JSON_SERIALIZE_ENUM(eCombatAbilityLevel,
|
NLOHMANN_JSON_SERIALIZE_ENUM(eCombatAbilityLevel, {{eCombatAbilityLevel::POOR, "poor"}, {eCombatAbilityLevel::AVERAGE, "average"}, {eCombatAbilityLevel::PROFESSIONAL, "professional"}})
|
||||||
{
|
|
||||||
{eCombatAbilityLevel::POOR, "poor"},
|
|
||||||
{eCombatAbilityLevel::AVERAGE, "average"},
|
|
||||||
{eCombatAbilityLevel::PROFESSIONAL, "professional"}
|
|
||||||
})
|
|
||||||
|
@ -125,6 +125,14 @@ namespace big
|
|||||||
vehicle::operate_vehicle_door(m_controlled_vehicle.handle, door, open);
|
vehicle::operate_vehicle_door(m_controlled_vehicle.handle, door, open);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void vehicle_control::operate_window(eWindowId window, bool open)
|
||||||
|
{
|
||||||
|
if (g.window.vehicle_control.operation_animation)
|
||||||
|
animated_vehicle_operation(self::ped);
|
||||||
|
|
||||||
|
vehicle::operate_vehicle_window(m_controlled_vehicle.handle, window, open);
|
||||||
|
}
|
||||||
|
|
||||||
void vehicle_control::operate_lights(bool headlights, bool highbeams)
|
void vehicle_control::operate_lights(bool headlights, bool highbeams)
|
||||||
{
|
{
|
||||||
if (g.window.vehicle_control.operation_animation)
|
if (g.window.vehicle_control.operation_animation)
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
namespace big
|
namespace big
|
||||||
{
|
{
|
||||||
constexpr auto MAX_VEHICLE_DOORS = 6;
|
constexpr auto MAX_VEHICLE_DOORS = 6;
|
||||||
|
constexpr auto MAX_VEHICLE_WINDOWS = 4;
|
||||||
constexpr auto MAX_VEHICLE_LOCK_STATES = 11;
|
constexpr auto MAX_VEHICLE_LOCK_STATES = 11;
|
||||||
constexpr auto VEH_OP_ANIM_DICT = "ANIM@MP_PLAYER_INTMENU@KEY_FOB@";
|
constexpr auto VEH_OP_ANIM_DICT = "ANIM@MP_PLAYER_INTMENU@KEY_FOB@";
|
||||||
constexpr auto VEH_OP_ANIM = "FOB_CLICK";
|
constexpr auto VEH_OP_ANIM = "FOB_CLICK";
|
||||||
@ -17,6 +18,11 @@ namespace big
|
|||||||
bool valid;
|
bool valid;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct vehicle_window
|
||||||
|
{
|
||||||
|
eWindowId id;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
struct controlled_vehicle
|
struct controlled_vehicle
|
||||||
{
|
{
|
||||||
@ -24,6 +30,7 @@ namespace big
|
|||||||
CVehicle* ptr;
|
CVehicle* ptr;
|
||||||
char model_name[100];
|
char model_name[100];
|
||||||
vehicle_door doors[6];
|
vehicle_door doors[6];
|
||||||
|
vehicle_window windows[4];
|
||||||
int doorCount;
|
int doorCount;
|
||||||
eVehicleLockState lockstate;
|
eVehicleLockState lockstate;
|
||||||
bool engine;
|
bool engine;
|
||||||
@ -32,8 +39,7 @@ namespace big
|
|||||||
bool radio;
|
bool radio;
|
||||||
int radiochannel;
|
int radiochannel;
|
||||||
int convertibelstate;
|
int convertibelstate;
|
||||||
int headlights,
|
int headlights, highbeams;
|
||||||
highbeams;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class vehicle_control
|
class vehicle_control
|
||||||
@ -62,6 +68,7 @@ namespace big
|
|||||||
|
|
||||||
void animated_vehicle_operation(Ped ped);
|
void animated_vehicle_operation(Ped ped);
|
||||||
void operate_door(eDoorId, bool);
|
void operate_door(eDoorId, bool);
|
||||||
|
void operate_window(eWindowId, bool);
|
||||||
void operate_lights(bool headlights, bool highbeams);
|
void operate_lights(bool headlights, bool highbeams);
|
||||||
void operate_neons(int index, bool toggle);
|
void operate_neons(int index, bool toggle);
|
||||||
void summon_vehicle();
|
void summon_vehicle();
|
||||||
|
@ -746,6 +746,35 @@ namespace big::vehicle
|
|||||||
return success;
|
return success;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline bool operate_vehicle_window(Vehicle veh, eWindowId windowId, bool open)
|
||||||
|
{
|
||||||
|
bool success = false;
|
||||||
|
if (ENTITY::DOES_ENTITY_EXIST(veh))
|
||||||
|
{
|
||||||
|
for (int i = 0; i < 4; i++)
|
||||||
|
{
|
||||||
|
if (windowId == eWindowId::WINDOW_INVALID_ID)
|
||||||
|
{
|
||||||
|
if (open)
|
||||||
|
VEHICLE::ROLL_DOWN_WINDOWS(veh);
|
||||||
|
else
|
||||||
|
VEHICLE::ROLL_UP_WINDOW(veh, i);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((int)windowId == i)
|
||||||
|
{
|
||||||
|
if (open)
|
||||||
|
VEHICLE::ROLL_DOWN_WINDOW(veh, i);
|
||||||
|
else
|
||||||
|
VEHICLE::ROLL_UP_WINDOW(veh, i);
|
||||||
|
|
||||||
|
success = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return success;
|
||||||
|
}
|
||||||
|
|
||||||
inline bool operate_vehicle_headlights(Vehicle veh, bool lights, bool highbeams)
|
inline bool operate_vehicle_headlights(Vehicle veh, bool lights, bool highbeams)
|
||||||
{
|
{
|
||||||
if (ENTITY::DOES_ENTITY_EXIST(veh))
|
if (ENTITY::DOES_ENTITY_EXIST(veh))
|
||||||
|
@ -58,6 +58,9 @@ namespace big
|
|||||||
|
|
||||||
if (g.window.ingame_overlay_indicators.show_triggerbot)
|
if (g.window.ingame_overlay_indicators.show_triggerbot)
|
||||||
components::overlay_indicator("Triggerbot", g.weapons.triggerbot);
|
components::overlay_indicator("Triggerbot", g.weapons.triggerbot);
|
||||||
|
|
||||||
|
if (g.window.ingame_overlay_indicators.show_invisibility)
|
||||||
|
components::overlay_indicator("Invisibility", g.self.invisibility);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (g.window.ingame_overlay.show_position && g_local_player)
|
if (g.window.ingame_overlay.show_position && g_local_player)
|
||||||
|
@ -69,13 +69,16 @@ namespace big
|
|||||||
ImGui::Checkbox("Show Vehicle Godmode", &g.window.ingame_overlay_indicators.show_vehicle_godmode);
|
ImGui::Checkbox("Show Vehicle Godmode", &g.window.ingame_overlay_indicators.show_vehicle_godmode);
|
||||||
ImGui::Checkbox("Show Never Wanted", &g.window.ingame_overlay_indicators.show_never_wanted);
|
ImGui::Checkbox("Show Never Wanted", &g.window.ingame_overlay_indicators.show_never_wanted);
|
||||||
ImGui::EndGroup();
|
ImGui::EndGroup();
|
||||||
|
|
||||||
ImGui::SameLine();
|
ImGui::SameLine();
|
||||||
|
|
||||||
ImGui::BeginGroup();
|
ImGui::BeginGroup();
|
||||||
ImGui::Checkbox("Show Infinite Ammo", &g.window.ingame_overlay_indicators.show_infinite_ammo);
|
ImGui::Checkbox("Show Infinite Ammo", &g.window.ingame_overlay_indicators.show_infinite_ammo);
|
||||||
ImGui::Checkbox("Show Always Full Ammo", &g.window.ingame_overlay_indicators.show_always_full_ammo);
|
ImGui::Checkbox("Show Always Full Ammo", &g.window.ingame_overlay_indicators.show_always_full_ammo);
|
||||||
ImGui::Checkbox("Show Infinite Magazine", &g.window.ingame_overlay_indicators.show_infinite_mag);
|
ImGui::Checkbox("Show Infinite Magazine", &g.window.ingame_overlay_indicators.show_infinite_mag);
|
||||||
ImGui::Checkbox("Show Aimbot", &g.window.ingame_overlay_indicators.show_aimbot);
|
ImGui::Checkbox("Show Aimbot", &g.window.ingame_overlay_indicators.show_aimbot);
|
||||||
ImGui::Checkbox("Show Triggerbot", &g.window.ingame_overlay_indicators.show_triggerbot);
|
ImGui::Checkbox("Show Triggerbot", &g.window.ingame_overlay_indicators.show_triggerbot);
|
||||||
|
ImGui::Checkbox("Show Invisibility", &g.window.ingame_overlay_indicators.show_invisibility);
|
||||||
ImGui::EndGroup();
|
ImGui::EndGroup();
|
||||||
|
|
||||||
ImGui::TreePop();
|
ImGui::TreePop();
|
||||||
|
@ -109,6 +109,48 @@ namespace big
|
|||||||
ImGui::EndGroup();
|
ImGui::EndGroup();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void render_windows_tab()
|
||||||
|
{
|
||||||
|
const char* const windownames[4]{
|
||||||
|
"Front left",
|
||||||
|
"Front right",
|
||||||
|
"Back left",
|
||||||
|
"Back right",
|
||||||
|
};
|
||||||
|
|
||||||
|
ImGui::BeginGroup();
|
||||||
|
ImGui::Spacing();
|
||||||
|
ImGui::SetNextItemWidth(200);
|
||||||
|
components::button("Roll Down All", [] {
|
||||||
|
g_vehicle_control_service.operate_window(eWindowId::WINDOW_INVALID_ID, true);
|
||||||
|
});
|
||||||
|
ImGui::SameLine();
|
||||||
|
components::button("Roll Up All", [] {
|
||||||
|
g_vehicle_control_service.operate_window(eWindowId::WINDOW_INVALID_ID, false);
|
||||||
|
});
|
||||||
|
ImGui::EndGroup();
|
||||||
|
|
||||||
|
ImGui::Spacing();
|
||||||
|
ImGui::Separator();
|
||||||
|
|
||||||
|
ImGui::BeginGroup();
|
||||||
|
for (int i = 0; i < 4; i++)
|
||||||
|
{
|
||||||
|
ImGui::SetNextItemWidth(200);
|
||||||
|
ImGui::PushID(i);
|
||||||
|
ImGui::Text(windownames[i]);
|
||||||
|
ImGui::SameLine(300);
|
||||||
|
components::button("Roll Down", [i] {
|
||||||
|
g_vehicle_control_service.operate_window((eWindowId)i, true);
|
||||||
|
});
|
||||||
|
ImGui::SameLine();
|
||||||
|
components::button("Roll Up", [i] {
|
||||||
|
g_vehicle_control_service.operate_window((eWindowId)i, false);
|
||||||
|
});
|
||||||
|
ImGui::PopID();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void render_lights_tab()
|
void render_lights_tab()
|
||||||
{
|
{
|
||||||
const char* const neonnames[4]{
|
const char* const neonnames[4]{
|
||||||
@ -321,6 +363,13 @@ namespace big
|
|||||||
ImGui::EndTabItem();
|
ImGui::EndTabItem();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (ImGui::BeginTabItem("Windows"))
|
||||||
|
{
|
||||||
|
render_windows_tab();
|
||||||
|
|
||||||
|
ImGui::EndTabItem();
|
||||||
|
}
|
||||||
|
|
||||||
if (ImGui::BeginTabItem("Lights"))
|
if (ImGui::BeginTabItem("Lights"))
|
||||||
{
|
{
|
||||||
render_lights_tab();
|
render_lights_tab();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user