Lua Scripting (#1334)

Closes #83
Fixes #1309
Fixes #1287
Fixes #1129 (actually fixed now)
This commit is contained in:
maybegreat48 2023-06-06 07:40:40 +00:00 committed by GitHub
parent 35bb398c01
commit 03c1a96b67
201 changed files with 156682 additions and 838 deletions

1
.gitignore vendored
View File

@ -6,6 +6,7 @@
# output directory # output directory
build/ build/
out/ out/
__pycache__/
# precompiled headers # precompiled headers
*.ipch *.ipch

View File

@ -15,6 +15,7 @@ include(scripts/pugixml.cmake)
include(scripts/json.cmake) include(scripts/json.cmake)
include(scripts/cpr.cmake) include(scripts/cpr.cmake)
include(scripts/zydis.cmake) include(scripts/zydis.cmake)
include(scripts/lua.cmake)
message("\nFetching custom modules") message("\nFetching custom modules")
include(scripts/imgui.cmake) include(scripts/imgui.cmake)
@ -46,7 +47,7 @@ target_include_directories(YimMenu PRIVATE
) )
target_precompile_headers(YimMenu PRIVATE "${SRC_DIR}/common.hpp") target_precompile_headers(YimMenu PRIVATE "${SRC_DIR}/common.hpp")
target_link_libraries(YimMenu PRIVATE pugixml minhook AsyncLogger dbghelp imgui cpr Zydis) target_link_libraries(YimMenu PRIVATE pugixml minhook AsyncLogger dbghelp imgui cpr Zydis lua_static)
# Warnings as errors # Warnings as errors
set_property(TARGET YimMenu PROPERTY COMPILE_WARNING_AS_ERROR ON) set_property(TARGET YimMenu PROPERTY COMPILE_WARNING_AS_ERROR ON)

View File

@ -3,7 +3,7 @@ include(FetchContent)
FetchContent_Declare( FetchContent_Declare(
gtav_classes gtav_classes
GIT_REPOSITORY https://github.com/Yimura/GTAV-Classes.git GIT_REPOSITORY https://github.com/Yimura/GTAV-Classes.git
GIT_TAG 57548ccd8742f0355fc674e8f4dedee119d640e5 GIT_TAG 9de17746d2e7492725d2e7430ad0f27c05b6c2f0
GIT_PROGRESS TRUE GIT_PROGRESS TRUE
CONFIGURE_COMMAND "" CONFIGURE_COMMAND ""
BUILD_COMMAND "" BUILD_COMMAND ""

12
scripts/lua.cmake Normal file
View File

@ -0,0 +1,12 @@
include(FetchContent)
message("Lua")
FetchContent_Declare(
Lua
GIT_REPOSITORY https://github.com/walterschell/Lua.git
GIT_TAG a2e0125df529894f5e25d7d477b2df4e37690e0f
GIT_PROGRESS TRUE
)
FetchContent_MakeAvailable(Lua)
set_property(TARGET lua_static PROPERTY CXX_STANDARD 23)

View File

@ -6,6 +6,7 @@
#include "script_patches.hpp" #include "script_patches.hpp"
#include "services/context_menu/context_menu_service.hpp" #include "services/context_menu/context_menu_service.hpp"
#include "services/orbital_drone/orbital_drone.hpp" #include "services/orbital_drone/orbital_drone.hpp"
#include "services/tunables/tunables_service.hpp"
#include "services/vehicle/vehicle_control_service.hpp" #include "services/vehicle/vehicle_control_service.hpp"
#include "services/squad_spawner/squad_spawner.hpp" #include "services/squad_spawner/squad_spawner.hpp"
#include "thread_pool.hpp" #include "thread_pool.hpp"
@ -77,7 +78,6 @@ namespace big
{ {
looped::vehicle_auto_drive(); looped::vehicle_auto_drive();
looped::vehicle_boost_behavior(); looped::vehicle_boost_behavior();
looped::vehicle_god_mode();
looped::derail_train(); looped::derail_train();
looped::drive_train(); looped::drive_train();
@ -85,18 +85,6 @@ namespace big
} }
} }
void backend::turnsignal_loop()
{
LOG(INFO) << "Starting script: turnsignal";
while (g_running)
{
looped::vehicle_turn_signals();
script::get_current()->yield();
}
}
void backend::misc_loop() void backend::misc_loop()
{ {
LOG(INFO) << "Starting script: Miscellaneous"; LOG(INFO) << "Starting script: Miscellaneous";
@ -104,7 +92,6 @@ namespace big
while (g_running) while (g_running)
{ {
looped::hud_transition_state(); looped::hud_transition_state();
looped::session_local_time();
looped::session_pop_multiplier_areas(); looped::session_pop_multiplier_areas();
looped::session_force_thunder(); looped::session_force_thunder();
looped::session_randomize_ceo_colors(); looped::session_randomize_ceo_colors();
@ -154,18 +141,6 @@ namespace big
} }
} }
void backend::vehiclefly_loop()
{
LOG(INFO) << "Starting script: Vehicle fly";
while (g_running)
{
looped::vehicle_fly();
script::get_current()->yield();
}
}
void backend::disable_control_action_loop() void backend::disable_control_action_loop()
{ {
LOG(INFO) << "Starting script: Disable Control Action"; LOG(INFO) << "Starting script: Disable Control Action";
@ -212,13 +187,17 @@ namespace big
{ {
while (true) while (true)
{ {
g_vehicle_control_service.tick(); g_vehicle_control_service.tick();
script::get_current()->yield(); script::get_current()->yield();
} }
} }
void backend::tunables_script()
{
g_tunables_service->run_script();
}
void backend::squad_spawner() void backend::squad_spawner()
{ {
while (true) while (true)

View File

@ -10,16 +10,15 @@ namespace big
static void self_loop(); static void self_loop();
static void weapons_loop(); static void weapons_loop();
static void vehicles_loop(); static void vehicles_loop();
static void turnsignal_loop();
static void misc_loop(); static void misc_loop();
static void remote_loop(); static void remote_loop();
static void lscustoms_loop(); static void lscustoms_loop();
static void rainbowpaint_loop(); static void rainbowpaint_loop();
static void vehiclefly_loop();
static void disable_control_action_loop(); static void disable_control_action_loop();
static void world_loop(); static void world_loop();
static void orbital_drone(); static void orbital_drone();
static void vehicle_control(); static void vehicle_control();
static void tunables_script();
static void squad_spawner(); static void squad_spawner();
}; };
} }

View File

@ -30,7 +30,9 @@ namespace big
command::command(const std::string& name, const std::string& label, const std::string& description, std::optional<std::uint8_t> num_args, bool fiber_pool) : command::command(const std::string& name, const std::string& label, const std::string& description, std::optional<std::uint8_t> num_args, bool fiber_pool) :
m_name(name), m_name(name),
m_label(label), m_label(label),
m_label_hash(rage::joaat(label)),
m_description(description), m_description(description),
m_description_hash(rage::joaat(description)),
m_num_args(num_args), m_num_args(num_args),
m_fiber_pool(fiber_pool) m_fiber_pool(fiber_pool)
{ {

View File

@ -11,7 +11,9 @@ namespace big
protected: protected:
std::string m_name; std::string m_name;
std::string m_label; std::string m_label;
rage::joaat_t m_label_hash;
std::string m_description; std::string m_description;
rage::joaat_t m_description_hash;
std::optional<std::uint8_t> m_num_args; std::optional<std::uint8_t> m_num_args;
bool m_fiber_pool; bool m_fiber_pool;
@ -31,13 +33,21 @@ namespace big
{ {
return m_name; return m_name;
} }
inline const std::string& get_label() inline const std::string get_label()
{ {
return m_label; std::string key;
if (key = g_translation_service.get_translation(m_label_hash); key.empty())
key = m_label;
return key;
} }
inline const std::string& get_description() inline const std::string get_description()
{ {
return m_description; std::string key;
if (key = g_translation_service.get_translation(m_description_hash); key.empty())
key = m_description;
return key;
} }
inline const std::optional<std::uint8_t>& get_num_args() inline const std::optional<std::uint8_t>& get_num_args()
{ {

View File

@ -14,7 +14,7 @@ namespace big
virtual void execute(const std::vector<std::uint64_t>&, const std::shared_ptr<command_context> ctx) virtual void execute(const std::vector<std::uint64_t>&, const std::shared_ptr<command_context> ctx)
{ {
ctx->report_error("Money and recovery options are not supported in YimMenu to keep Rockstar/Take Two happy. You can try Kiddion's Modest Menu (free) instead, but make sure to only get it from UnknownCheats.me, the rest are scams and contain malware"); ctx->report_error("Money and recovery options are not supported in YimMenu to keep Rockstar/Take Two happy. You can try Kiddion's Modest Menu (free) instead, but make sure to only get it from UnknownCheats.me, the rest are scams and may contain malware");
} }
}; };

View File

@ -27,5 +27,5 @@ namespace big
} }
}; };
bail_kick g_bail_kick("bailkick", "Bail Kick", "Blocked by most menus", 0); bail_kick g_bail_kick("bailkick", "BAIL_KICK", "BAIL_KICK_DESC", 0);
} }

View File

@ -67,7 +67,7 @@ namespace big
} }
}; };
breakup_kick g_breakup_kick("breakup", "Breakup Kick", "Nearly unblockable but could be detected by others", 0, false); breakup_kick g_breakup_kick("breakup", "BREAKUP_KICK", "BREAKUP_KICK_DESC", 0, false);
bool_command g_show_cheating_message("breakupcheating", "Show Cheating Message", "Shows a \"was detected cheating and has been removed from the session\" instead of the usual leave message when the player gets kicked", bool_command g_show_cheating_message("breakupcheating", "BREAKUP_KICK_SHOW_CHEATING", "BREAKUP_KICK_SHOW_CHEATING_DESC",
g.session.show_cheating_message); g.session.show_cheating_message);
} }

View File

@ -29,5 +29,5 @@ namespace big
} }
}; };
complaint_kick g_complaint_kick("desync", "Desync Kick", "This may take around 10 seconds to kick the player. Does not work against the host", 0);// this is pretty much desync except we don't actually remove the player from CNetworkPlayerMgr complaint_kick g_complaint_kick("desync", "COMPLAINT_KICK", "COMPLAINT_KICK_DESC", 0); // this is pretty much desync except we don't actually remove the player from CNetworkPlayerMgr
} }

View File

@ -24,9 +24,9 @@ namespace big
} }
g_player_service->m_player_to_use_end_session_kick = player; g_player_service->m_player_to_use_end_session_kick = player;
*scr_globals::gsbd.as<int*>() = (int)(__rdtsc() % 50000) + 6;// making the game trigger the broadcast is a bit difficult and requires a little bit of tampering with the value and luck *scr_globals::gsbd.as<int*>() = (int)(__rdtsc() % 50000) + 6; // making the game trigger the broadcast is a bit difficult and requires a little bit of tampering with the value and some luck
} }
}; };
end_session_kick g_end_session_kick("endkick", "End Session Kick", "This may take around 10 seconds to kick the player", 0, false); end_session_kick g_end_session_kick("endkick", "END_KICK", "END_KICK_DESC", 0, false);
} }

View File

@ -23,5 +23,5 @@ namespace big
} }
}; };
null_function_kick g_null_function_kick("nfkick", "Null Function Kick", "It may take around 15 seconds for the player to actually leave the session", 0); null_function_kick g_null_function_kick("nfkick", "NULL_FUNCTION_KICK", "NULL_FUNCTION_KICK_DESC", 0);
} }

View File

@ -44,5 +44,5 @@ namespace big
} }
}; };
oom_kick g_oom_kick("oomkick", "OOM Kick", "Causes the player to be kicked with an alert. This kick has a high chance of backfiring in its current state", 0, false); oom_kick g_oom_kick("oomkick", "OOM_KICK_CMD", "OOM_KICK_CMD_DESC", 0, false);
} }

View File

@ -27,5 +27,5 @@ namespace big
} }
}; };
script_host_kick g_script_host_kick("shkick", "Script Host Kick", "Blocked by most menus", 0, false); script_host_kick g_script_host_kick("shkick", "SCRIPT_HOST_KICK", "SCRIPT_HOST_KICK_DESC", 0, false);
} }

View File

@ -20,5 +20,5 @@ namespace big
} }
}; };
clear_wanted_level g_clear_wanted_level("clearwanted", "Clear Wanted Level", "Clears the player's wanted level", 0); clear_wanted_level g_clear_wanted_level("clearwanted", "CLEAR_WANTED_LEVEL", "CLEAR_WANTED_LEVEL_DESC", 0);
} }

View File

@ -48,5 +48,5 @@ namespace big
} }
}; };
enter_interior g_enter_interior("enterint", "Enter Interior", "Enters the player's interior", 0, false); enter_interior g_enter_interior("enterint", "ENTER_INTERIOR", "ENTER_INTERIOR_DESC", 0, false);
} }

View File

@ -21,5 +21,5 @@ namespace big
} }
}; };
give_ammo g_give_ammo("giveammo", "Give Ammo", "Gives the player some ammo", 0); give_ammo g_give_ammo("giveammo", "GIVE_AMMO", "GIVE_AMMO_DESC", 0);
} }

View File

@ -21,5 +21,5 @@ namespace big
} }
}; };
give_armor g_give_armor("givearmor", "Give Armor", "Gives the player some armor", 0); give_armor g_give_armor("givearmor", "GIVE_ARMOR", "GIVE_ARMOR_DESC", 0);
} }

View File

@ -21,5 +21,5 @@ namespace big
} }
}; };
give_health g_give_health("givehealth", "Give Health", "Gives the player some health", 0); give_health g_give_health("givehealth", "GIVE_HEALTH", "GIVE_HEALTH_DESC", 0);
} }

View File

@ -16,5 +16,5 @@ namespace big
} }
}; };
join_ceo g_join_ceo("joinceo", "Join CEO/MC", "Joins the player's CEO/MC", 0, false); join_ceo g_join_ceo("joinceo", "JOIN_CEO", "JOIN_CEO_DESC", 0, false);
} }

View File

@ -15,5 +15,5 @@ namespace big
} }
}; };
steal_identity g_steal_identity("copymodel", "Steal Identity", "Copies the player's model to your ped", 0, false);// do we really need this? steal_identity g_steal_identity("copymodel", "STEAL_IDENTITY", "STEAL_IDENTITY_DESC", 0, false); // do we really need this?
} }

View File

@ -15,5 +15,5 @@ namespace big
} }
}; };
steal_outfit g_steal_outfit("copyoutfit", "Steal Outfit", "Copies the player's outfit to your ped", 0, false); steal_outfit g_steal_outfit("copyoutfit", "STEAL_OUTFIT", "STEAL_OUTFIT_DESC", 0, false);
} }

View File

@ -40,5 +40,5 @@ namespace big
} }
}; };
ceo_kick g_ceo_kick("ceokick", "CEO Kick", "Kicks an associate from the CEO/MC. You cannot kick leaders of CEOs/MCs anymore", 0); ceo_kick g_ceo_kick("ceokick", "CEO_KICK", "CEO_KICK_DESC", 0);
} }

View File

@ -20,5 +20,5 @@ namespace big
} }
}; };
explode_player g_explode_player("explode", "Explode Player", "Blows the player up", 0); explode_player g_explode_player("explode", "EXPLODE_PLAYER", "EXPLODE_PLAYER_DESC", 0);
} }

View File

@ -23,5 +23,5 @@ namespace big
} }
}; };
force_into_mission g_force_into_mission("mission", "Force Into Mission", "Forces the player into a gunrunning mission", 0); force_into_mission g_force_into_mission("mission", "FORCE_INTO_MISSION", "FORCE_INTO_MISSION_DESC", 0);
} }

View File

@ -41,6 +41,6 @@ namespace big
} }
}; };
give_all_weapons g_give_all_weapons("giveweaps", "Give Weapons", "Gives all weapons to the player", 0, false); give_all_weapons g_give_all_weapons("giveweaps", "GIVE_WEAPONS", "GIVE_WEAPONS_DESC", 0, false);
give_all_weapons_all g_give_all_weapons_all("giveweapsall", "Give Weapons", "Gives weapons to everyone. Don't spam this or you will crash", 0); give_all_weapons_all g_give_all_weapons_all("giveweapsall", "GIVE_WEAPONS", "GIVE_WEAPONS_ALL_DESC", 0);
} }

View File

@ -143,5 +143,5 @@ namespace big
} }
}; };
kick_from_interior g_kick_from_interior("intkick", "Kick From Interior", "Kicks the player from the interior they are in", 0); kick_from_interior g_kick_from_interior("intkick", "KICK_FROM_INTERIOR", "KICK_FROM_INTERIOR_DESC", 0);
} }

View File

@ -29,10 +29,11 @@ namespace big
else else
{ {
// use a private method to kick player from vehicle // use a private method to kick player from vehicle
(*g_pointers->m_gta.m_network_object_mgr)->ChangeOwner(vehicle->m_net_object, g_player_service->get_self()->get_net_game_player(), 0); (*g_pointers->m_gta.m_network_object_mgr)
->ChangeOwner(vehicle->m_net_object, g_player_service->get_self()->get_net_game_player(), 0);
} }
} }
}; };
kick_from_vehicle g_kick_from_vehicle("vehkick", "Vehicle Kick", "Kicks the player from their current vehicle", 0); kick_from_vehicle g_kick_from_vehicle("vehkick", "VEHICLE_KICK", "VEHICLE_KICK_DESC", 0);
} }

View File

@ -39,5 +39,5 @@ namespace big
} }
}; };
kill_player g_kill_player("kill", "Kill Player", "Kills the player, bypassing most forms of interior godmode", 0); kill_player g_kill_player("kill", "KILL_PLAYER", "KILL_PLAYER_DESC", 0);
} }

View File

@ -21,5 +21,5 @@ namespace big
} }
}; };
ragdoll_player g_ragdoll_player("ragdoll", "Ragdoll Player", "Ragdolls the player", 0); ragdoll_player g_ragdoll_player("ragdoll", "RAGDOLL_PLAYER", "RAGDOLL_PLAYER_DESC", 0);
} }

View File

@ -21,5 +21,5 @@ namespace big
} }
}; };
remove_all_weapons g_remove_all_weapons("remweaps", "Remove All Weapons", "Remove all weapons from the player", 0); remove_all_weapons g_remove_all_weapons("remweaps", "REMOVE_ALL_WEAPONS", "REMOVE_ALL_WEAPONS_DESC", 0);
} }

View File

@ -27,5 +27,5 @@ namespace big
} }
}; };
send_fake_ban_message g_send_fake_ban_message("fakeban", "Send Fake Ban Message", "Sends a fake ban notification to the player", 0); send_fake_ban_message g_send_fake_ban_message("fakeban", "FAKE_BAN_MESSAGE", "FAKE_BAN_MESSAGE_DESC", 0);
} }

View File

@ -32,5 +32,5 @@ namespace big
} }
}; };
send_sext g_send_sext("sext", "Send Sext", "Sends a random sext (with an image attachment) to the player", 0); send_sext g_send_sext("sext", "SEND_SEXT", "SEND_SEXT_DESC", 0);
} }

View File

@ -28,5 +28,5 @@ namespace big
} }
}; };
send_to_apartment g_send_to_apartment("apartmenttp", "TP To Apartment", "Teleports the player to the specified apartment index", 1); send_to_apartment g_send_to_apartment("apartmenttp", "TP_TO_APARTMENT", "TP_TO_APARTMENT_DESC", 1);
} }

View File

@ -28,7 +28,7 @@ namespace big
(int64_t)(int)_args[0], (int64_t)(int)_args[0],
(int64_t)self::id, (int64_t)self::id,
(int64_t) false, (int64_t) false,
(int64_t) true,// true means enter sender interior (int64_t) true, // true means enter sender interior
(int64_t) * (uint32_t*)&coords.x, (int64_t) * (uint32_t*)&coords.x,
(int64_t) * (uint32_t*)&coords.y, (int64_t) * (uint32_t*)&coords.y,
(int64_t) * (uint32_t*)&coords.z, (int64_t) * (uint32_t*)&coords.z,
@ -43,5 +43,5 @@ namespace big
} }
}; };
send_to_interior g_send_to_interior("interiortp", "TP To Interior", "Teleports the player to the specified interior index", 1); send_to_interior g_send_to_interior("interiortp", "TP_TO_INTERIOR", "TP_TO_INTERIOR_DESC", 1);
} }

View File

@ -26,5 +26,5 @@ namespace big
} }
}; };
send_to_island g_send_to_island("cayotp", "TP To Cayo Perico", "Teleports the player to Cayo Perico", 0); send_to_island g_send_to_island("cayotp", "TP_TO_CAYO", "TP_TO_CAYO_DESC", 0);
} }

View File

@ -28,5 +28,5 @@ namespace big
} }
}; };
send_to_warehouse g_send_to_warehouse("warehousetp", "TP To Warehouse", "Teleports the player to the specified warehouse index", 1); send_to_warehouse g_send_to_warehouse("warehousetp", "TP_TO_WAREHOUSE", "TP_TO_WAREHOUSE_DESC", 1);
} }

View File

@ -67,5 +67,5 @@ namespace big
} }
}; };
set_wanted_level g_set_wanted_level("wanted", "Set Wanted Level", "Sets the specified wanted level to the player", 1, false); set_wanted_level g_set_wanted_level("wanted", "SET_WANTED_LEVEL", "SET_WANTED_LEVEL_DESC", 1, false);
} }

View File

@ -32,5 +32,5 @@ namespace big
} }
}; };
show_transaction_error g_show_transaction_error("error", "Show Transaction Error", "Shows a transaction error to the player", 0); show_transaction_error g_show_transaction_error("error", "SHOW_TRANSACTION_ERROR", "SHOW_TRANSACTION_ERROR_DESC", 0);
} }

View File

@ -22,5 +22,5 @@ namespace big
} }
}; };
trigger_ceo_raid g_trigger_ceo_raid("ceoraid", "Trigger Special Cargo Raid", "The player has to be in a CEO for this to work", 0); trigger_ceo_raid g_trigger_ceo_raid("ceoraid", "TRIGGER_CEO_RAID", "TRIGGER_CEO_RAID_DESC", 0);
} }

View File

@ -61,10 +61,10 @@ namespace big
return; return;
*script_local(stack, idx).as<int*>() = 1; *script_local(stack, idx).as<int*>() = 1;
*script_local(stack, idx).at(1).as<int*>() = 2;// stage *script_local(stack, idx).at(1).as<int*>() = 2; // stage
*script_local(stack, idx).at(1).at(6).as<int*>() = net_component->get_participant_index(player->get_net_game_player());// beast participant idx *script_local(stack, idx).at(1).at(6).as<int*>() = net_component->get_participant_index(player->get_net_game_player()); // beast participant idx
*script_local(stack, idx).at(1).at(7).as<Player*>() = id; // beast player idx *script_local(stack, idx).at(1).at(7).as<Player*>() = id; // beast player idx
*script_local(stack, idx).at(1).at(2).as<int*>() = INT_MAX;// stopwatch time *script_local(stack, idx).at(1).at(2).as<int*>() = INT_MAX; // stopwatch time
*script_local(stack, idx).at(1).at(2).at(1).as<bool*>() = true; // stopwatch initialized *script_local(stack, idx).at(1).at(2).at(1).as<bool*>() = true; // stopwatch initialized
*script_local(stack, idx).at(1).at(4).at(1).as<bool*>() = false; // destroy old stage 1 stopwatch *script_local(stack, idx).at(1).at(4).at(1).as<bool*>() = false; // destroy old stage 1 stopwatch
*script_local(stack, idx).at(1).at(9).as<int*>() = 2; // some distance check *script_local(stack, idx).at(1).at(9).as<int*>() = 2; // some distance check
@ -126,8 +126,8 @@ namespace big
{ {
*script_local(stack, idx).as<int*>() = 1; *script_local(stack, idx).as<int*>() = 1;
*script_local(stack, idx).at(1).as<int*>() = 2; // stage *script_local(stack, idx).at(1).as<int*>() = 2; // stage
*script_local(stack, idx).at(1).at(6).as<int*>() = __rdtsc();// participant idx *script_local(stack, idx).at(1).at(6).as<int*>() = __rdtsc(); // participant idx
*script_local(stack, idx).at(1).at(7).as<Player*>() = __rdtsc();// beast player idx *script_local(stack, idx).at(1).at(7).as<Player*>() = __rdtsc(); // beast player idx
*script_local(stack, idx).at(1).at(2).as<int*>() = INT_MAX; // stopwatch time *script_local(stack, idx).at(1).at(2).as<int*>() = INT_MAX; // stopwatch time
*script_local(stack, idx).at(1).at(2).at(1).as<bool*>() = true; // stopwatch initialized *script_local(stack, idx).at(1).at(2).at(1).as<bool*>() = true; // stopwatch initialized
*script_local(stack, idx).at(1).at(4).at(1).as<bool*>() = false; // destroy old stage 1 stopwatch *script_local(stack, idx).at(1).at(4).at(1).as<bool*>() = false; // destroy old stage 1 stopwatch
@ -138,8 +138,8 @@ namespace big
// unfortunately we must also turn ourselves into the beast to prevent the script from exiting due to a "missing player" // unfortunately we must also turn ourselves into the beast to prevent the script from exiting due to a "missing player"
*script_local(stack, idx).at(1).at(6).as<int*>() = net_component->m_local_participant_index;// participant idx *script_local(stack, idx).at(1).at(6).as<int*>() = net_component->m_local_participant_index; // participant idx
*script_local(stack, idx).at(1).at(7).as<Player*>() = self::id;// beast player idx *script_local(stack, idx).at(1).at(7).as<Player*>() = self::id; // beast player idx
*script_local(stack, idx).at(1).at(2).as<int*>() = INT_MAX; // stopwatch time *script_local(stack, idx).at(1).at(2).as<int*>() = INT_MAX; // stopwatch time
*script_local(stack, idx).at(83).as<int*>() = 0; // transformed bitset *script_local(stack, idx).at(83).as<int*>() = 0; // transformed bitset
@ -147,6 +147,6 @@ namespace big
} }
}; };
turn_into_beast g_turn_into_beast("beast", "Turn Into Beast", "Turns the player into the beast", 0, false); turn_into_beast g_turn_into_beast("beast", "TURN_INTO_BEAST", "TURN_INTO_BEAST_DESC", 0, false);
turn_into_beast_all g_turn_into_beast_all("beastall", "Turn Everyone Into Beast", "Turns everyone into the beast, including you", 0); turn_into_beast_all g_turn_into_beast_all("beastall", "TURN_INTO_BEAST_ALL", "TURN_INTO_BEAST_ALL_DESC", 0);
} }

View File

@ -1,4 +1,5 @@
#include "backend/player_command.hpp" #include "backend/player_command.hpp"
#include "fiber_pool.hpp"
#include "natives.hpp" #include "natives.hpp"
#include "pointers.hpp" #include "pointers.hpp"
#include "util/teleport.hpp" #include "util/teleport.hpp"
@ -15,5 +16,19 @@ namespace big
} }
}; };
bring g_bring("bring", "Bring", "Teleports the player to you", 0, false); class bring_all : command
{
using command::command;
virtual void execute(const std::vector<std::uint64_t>& _args, const std::shared_ptr<command_context> ctx)
{
for (auto& player : g_player_service->players())
g_fiber_pool->queue_job([player]() {
teleport::bring_player(player.second);
});
}
};
bring g_bring("bring", "BRING", "BRING_DESC", 0, false);
bring_all g_bring_all("bringall", "BRING_ALL", "BRING_ALL_DESC", 0, false);
} }

View File

@ -1,46 +0,0 @@
#include "backend/player_command.hpp"
#include "natives.hpp"
#include "pointers.hpp"
#include "util/teleport.hpp"
namespace big
{
class flip_180 : player_command
{
using player_command::player_command;
virtual void execute(player_ptr player, const std::vector<std::uint64_t>& _args, const std::shared_ptr<command_context> ctx)
{
Ped ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id());
float heading = ENTITY::GET_ENTITY_HEADING(ped);
Vector3 car_coords = ENTITY::GET_ENTITY_COORDS(ped, 1);
if (!PED::IS_PED_IN_ANY_VEHICLE(ped, true))
{
g_notification_service->push_warning("Toxic", "Target player is not in any vehicle.");
}
else
{
Vehicle vehicle = PED::GET_VEHICLE_PED_IS_USING(ped);
float speed = ENTITY::GET_ENTITY_SPEED(vehicle);
if (entity::take_control_of(vehicle))
{
if (heading > 180.0)
heading -= 180.0;
else
heading += 180.0;
ENTITY::SET_ENTITY_COORDS(vehicle, car_coords.x, car_coords.y, car_coords.z, 0, 0, 0, 1);
ENTITY::SET_ENTITY_HEADING(vehicle, heading);
VEHICLE::SET_VEHICLE_FORWARD_SPEED(vehicle, speed);
}
}
}
};
flip_180
g_flip_180("flip180", "Rotate 180", "Rotates their car around", 0)
;
}

View File

@ -16,7 +16,6 @@ namespace big
} }
}; };
set_bounty g_bounty("bounty", "Bounty", "Sets a 10k bounty on the player", 0); set_bounty g_bounty("bounty", "BOUNTY", "BOUNTY_DESC", 0);
bool_command g_anonymous_bounty("anonbounty", "Anonymous Bounty", "Don't show your name when setting a bounty on someone", bool_command g_anonymous_bounty("anonbounty", "BOUNTY_ANON", "BOUNTY_ANON_DESC", g.session.anonymous_bounty);
g.session.anonymous_bounty);
} }

View File

@ -16,5 +16,5 @@ namespace big
} }
}; };
teleport_to_player g_teleport_to_player("playertp", "Teleport", "Teleports you to the player", 0, false); teleport_to_player g_teleport_to_player("playertp", "TELEPORT", "TELEPORT_DESC", 0, false);
} }

View File

@ -18,5 +18,5 @@ namespace big
} }
}; };
teleport_into_vehicle g_teleport_into_vehicle("playervehtp", "Teleport Into Vehicle", "Teleports into the players vehicle. Spectate the player beforehand for best results", 0, false); teleport_into_vehicle g_teleport_into_vehicle("playervehtp", "TELEPORT_INTO_VEHICLE", "TELEPORT_INTO_VEHICLE_DESC", 0, false);
} }

View File

@ -14,7 +14,7 @@ namespace big
Ped ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id()); Ped ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id());
if (!PED::IS_PED_IN_ANY_VEHICLE(ped, true)) if (!PED::IS_PED_IN_ANY_VEHICLE(ped, true))
{ {
g_notification_service->push_warning("Toxic", "Target player is not in a vehicle."); g_notification_service->push_warning("TOXIC"_T.data(), "ERROR_PLAYER_IS_NOT_IN_VEHICLE"_T.data());
} }
else else
{ {
@ -26,7 +26,7 @@ namespace big
} }
else else
{ {
g_notification_service->push_warning("Toxic", "Failed to take control of player vehicle."); g_notification_service->push_warning("TOXIC"_T.data(), "ERROR_FAILED_TO_TAKE_CONTROL"_T.data());
} }
} }
} }

View File

@ -12,23 +12,21 @@ namespace big
virtual void execute(player_ptr player, const std::vector<std::uint64_t>& _args, const std::shared_ptr<command_context> ctx) virtual void execute(player_ptr player, const std::vector<std::uint64_t>& _args, const std::shared_ptr<command_context> ctx)
{ {
Ped ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id()); Ped ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id());
if (!PED::IS_PED_IN_ANY_VEHICLE(ped, true)) if (!PED::IS_PED_IN_ANY_VEHICLE(ped, true))
{ {
g_notification_service->push_warning("Toxic", "Target player is not in a vehicle."); g_notification_service->push_warning("TOXIC"_T.data(), "ERROR_PLAYER_IS_NOT_IN_VEHICLE"_T.data());
} }
else else
{ {
Vehicle vehicle = PED::GET_VEHICLE_PED_IS_USING(ped); Vehicle vehicle = PED::GET_VEHICLE_PED_IS_IN(ped, false);
if (entity::take_control_of(vehicle)) if (entity::take_control_of(vehicle))
{ {
Vehicle vehicle = PED::GET_VEHICLE_PED_IS_USING(ped);
entity::take_control_of(vehicle);
VEHICLE::SET_VEHICLE_TYRES_CAN_BURST(vehicle, true); VEHICLE::SET_VEHICLE_TYRES_CAN_BURST(vehicle, true);
static int tireID = 0;
for (tireID = 0; tireID < 8; tireID++) for (int tire = 0; tire < 8; tire++)
{ {
VEHICLE::SET_VEHICLE_TYRE_BURST(vehicle, tireID, true, 1000.0); VEHICLE::SET_VEHICLE_TYRE_BURST(vehicle, tire, true, 1000.0f);
} }
} }
} }

View File

@ -11,9 +11,10 @@ namespace big
virtual void execute(player_ptr player, const std::vector<std::uint64_t>& _args, const std::shared_ptr<command_context> ctx) virtual void execute(player_ptr player, const std::vector<std::uint64_t>& _args, const std::shared_ptr<command_context> ctx)
{ {
Ped ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id()); Ped ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id());
if (!PED::IS_PED_IN_ANY_VEHICLE(ped, true)) if (!PED::IS_PED_IN_ANY_VEHICLE(ped, true))
{ {
g_notification_service->push_warning("Toxic", "Target player is not in a vehicle."); g_notification_service->push_warning("TOXIC"_T.data(), "ERROR_PLAYER_IS_NOT_IN_VEHICLE"_T.data());
} }
else else
{ {

View File

@ -16,7 +16,7 @@ namespace big
if (!PED::IS_PED_IN_ANY_VEHICLE(ped, true)) if (!PED::IS_PED_IN_ANY_VEHICLE(ped, true))
{ {
g_notification_service->push_warning("Toxic", "Target player is not in a vehicle."); g_notification_service->push_warning("TOXIC"_T.data(), "ERROR_PLAYER_IS_NOT_IN_VEHICLE"_T.data());
} }
else else
{ {

View File

@ -0,0 +1,46 @@
#include "backend/player_command.hpp"
#include "natives.hpp"
#include "pointers.hpp"
#include "util/teleport.hpp"
namespace big
{
class flip_180 : player_command
{
using player_command::player_command;
virtual void execute(player_ptr player, const std::vector<std::uint64_t>& _args, const std::shared_ptr<command_context> ctx)
{
Ped player_ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id());
Vehicle vehicle = PED::GET_VEHICLE_PED_IS_IN(player_ped, false);
float heading = ENTITY::GET_ENTITY_HEADING(vehicle);
Vector3 flipCar180Coords = ENTITY::GET_ENTITY_COORDS(vehicle, 1);
if (!PED::IS_PED_IN_ANY_VEHICLE(player_ped, true))
{
g_notification_service->push_warning("TOXIC"_T.data(), "ERROR_PLAYER_IS_NOT_IN_VEHICLE"_T.data());
}
else
{
if (entity::take_control_of(vehicle))
{
if (heading > 180.0)
{
heading -= 180.0;
}
else
{
heading += 180.0;
ENTITY::SET_ENTITY_COORDS(vehicle, flipCar180Coords.x, flipCar180Coords.y, flipCar180Coords.z, 0, 0, 0, 1);
ENTITY::SET_ENTITY_HEADING(vehicle, heading);
VEHICLE::SET_VEHICLE_FORWARD_SPEED(vehicle, ENTITY::GET_ENTITY_SPEED(vehicle));
}
}
}
}
};
flip_180
g_flip_180("flip180", "Rotate 180", "Rotates their car around", 0)
;
}

View File

@ -12,9 +12,10 @@ namespace big
virtual void execute(player_ptr player, const std::vector<std::uint64_t>& _args, const std::shared_ptr<command_context> ctx) virtual void execute(player_ptr player, const std::vector<std::uint64_t>& _args, const std::shared_ptr<command_context> ctx)
{ {
Entity ent = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id()); Entity ent = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id());
if (!PED::IS_PED_IN_ANY_VEHICLE(ent, true)) if (!PED::IS_PED_IN_ANY_VEHICLE(ent, true))
{ {
g_notification_service->push_warning("Toxic", "Target player is not in any vehicle."); g_notification_service->push_warning("TOXIC"_T.data(), "ERROR_PLAYER_IS_NOT_IN_VEHICLE"_T.data());
} }
else else
{ {

View File

@ -13,7 +13,7 @@ namespace big
Ped ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id()); Ped ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id());
if (!PED::IS_PED_IN_ANY_VEHICLE(ped, true)) if (!PED::IS_PED_IN_ANY_VEHICLE(ped, true))
{ {
g_notification_service->push_warning("Toxic", "Target player is not in a vehicle."); g_notification_service->push_warning("TOXIC"_T.data(), "ERROR_PLAYER_IS_NOT_IN_VEHICLE"_T.data());
} }
else else
{ {

View File

@ -12,17 +12,20 @@ namespace big
virtual void execute(player_ptr player, const std::vector<std::uint64_t>& _args, const std::shared_ptr<command_context> ctx) virtual void execute(player_ptr player, const std::vector<std::uint64_t>& _args, const std::shared_ptr<command_context> ctx)
{ {
int lockStatus = VEHICLE::GET_VEHICLE_DOOR_LOCK_STATUS(player->id()); int lockStatus = VEHICLE::GET_VEHICLE_DOOR_LOCK_STATUS(player->id());
Entity ent = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id()); Ped ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id());
if (!PED::IS_PED_IN_ANY_VEHICLE(ent, true))
if (!PED::IS_PED_IN_ANY_VEHICLE(ped, true))
{ {
g_notification_service->push_warning("Toxic", "Target player is not in a vehicle."); g_notification_service->push_warning("TOXIC"_T.data(), "ERROR_PLAYER_IS_NOT_IN_VEHICLE"_T.data());
} }
else else
{ {
if (entity::take_control_of(ent)) Vehicle veh = PED::GET_VEHICLE_PED_IS_IN(ped, false);
if (entity::take_control_of(veh))
{ {
entity::take_control_of(PED::GET_VEHICLE_PED_IS_USING(player->id())); entity::take_control_of(veh);
VEHICLE::SET_VEHICLE_DOORS_LOCKED(PED::GET_VEHICLE_PED_IS_USING(player->id()), 4); VEHICLE::SET_VEHICLE_DOORS_LOCKED(veh, 4);
} }
} }
} }

View File

@ -14,7 +14,7 @@ namespace big
Ped ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id()); Ped ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id());
if (!PED::IS_PED_IN_ANY_VEHICLE(ped, true)) if (!PED::IS_PED_IN_ANY_VEHICLE(ped, true))
{ {
g_notification_service->push_warning("Toxic", "Target player is not in a vehicle."); g_notification_service->push_warning("TOXIC"_T.data(), "ERROR_PLAYER_IS_NOT_IN_VEHICLE"_T.data());
} }
else else
{ {
@ -22,7 +22,7 @@ namespace big
if (entity::take_control_of(vehicle)) if (entity::take_control_of(vehicle))
{ {
for (int i = 0; i < 7; i++) for (int i = 0; i < VEHICLE::GET_NUMBER_OF_VEHICLE_DOORS(i); i++)
{ {
VEHICLE::SET_VEHICLE_DOOR_OPEN(vehicle, i, true, false); VEHICLE::SET_VEHICLE_DOOR_OPEN(vehicle, i, true, false);
} }

View File

@ -14,12 +14,16 @@ namespace big
Ped ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id()); Ped ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id());
if (PED::IS_PED_IN_ANY_VEHICLE(ped, false)) if (PED::IS_PED_IN_ANY_VEHICLE(ped, false))
{ {
entity::take_control_of(PED::GET_VEHICLE_PED_IS_USING(ped)); Vehicle vehicle = PED::GET_VEHICLE_PED_IS_IN(ped, false);
Vehicle UserVeh = PED::GET_VEHICLE_PED_IS_IN(ped, false);
static int windowID = 0; if (entity::take_control_of(vehicle))
for (windowID = 0; windowID < 10; windowID++)
{ {
VEHICLE::SMASH_VEHICLE_WINDOW(UserVeh, windowID); int window = 0;
for (window = 0; window < 8; window++)
{
VEHICLE::SMASH_VEHICLE_WINDOW(vehicle, window);
}
} }
} }
} }

View File

@ -13,14 +13,15 @@ namespace big
Ped ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id()); Ped ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id());
if (!PED::IS_PED_IN_ANY_VEHICLE(ped, true)) if (!PED::IS_PED_IN_ANY_VEHICLE(ped, true))
{ {
g_notification_service->push_warning("Toxic", "Target player is not in a vehicle."); g_notification_service->push_warning("TOXIC"_T.data(), "ERROR_PLAYER_IS_NOT_IN_VEHICLE"_T.data());
} }
else else
{ {
Vehicle vehicle = PED::GET_VEHICLE_PED_IS_USING(ped); Vehicle vehicle = PED::GET_VEHICLE_PED_IS_USING(ped);
if (entity::take_control_of(vehicle)) if (entity::take_control_of(vehicle))
{ {
VEHICLE::SET_VEHICLE_FORWARD_SPEED(vehicle, 0); VEHICLE::BRING_VEHICLE_TO_HALT(vehicle, 0.0f, 1, 0);
} }
else else
{ {

View File

@ -10,9 +10,9 @@ namespace big
virtual void execute(player_ptr player, const std::vector<std::uint64_t>& _args, const std::shared_ptr<command_context> ctx) virtual void execute(player_ptr player, const std::vector<std::uint64_t>& _args, const std::shared_ptr<command_context> ctx)
{ {
if (PED::IS_PED_IN_ANY_VEHICLE((player->id()), false)) if (PED::IS_PED_IN_ANY_VEHICLE(player->id(), false))
{ {
entity::take_control_of(PED::GET_VEHICLE_PED_IS_USING(player->id())); if (entity::take_control_of(PED::GET_VEHICLE_PED_IS_USING(player->id())))
VEHICLE::SET_VEHICLE_DOORS_LOCKED(PED::GET_VEHICLE_PED_IS_USING(player->id()), 0); VEHICLE::SET_VEHICLE_DOORS_LOCKED(PED::GET_VEHICLE_PED_IS_USING(player->id()), 0);
} }
} }

View File

@ -12,9 +12,18 @@ namespace big
virtual void execute(player_ptr player, const std::vector<std::uint64_t>& _args, const std::shared_ptr<command_context> ctx) virtual void execute(player_ptr player, const std::vector<std::uint64_t>& _args, const std::shared_ptr<command_context> ctx)
{ {
Vehicle vehicle = PED::GET_VEHICLE_PED_IS_IN(PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id()), false); Ped ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id());
Vehicle vehicle = PED::GET_VEHICLE_PED_IS_IN(ped, false);
if (!PED::IS_PED_IN_ANY_VEHICLE(ped, true))
{
g_notification_service->push_warning("TOXIC"_T.data(), "ERROR_PLAYER_IS_NOT_IN_VEHICLE"_T.data());
}
else
{
vehicle::max_vehicle(vehicle); vehicle::max_vehicle(vehicle);
} }
}
}; };
upgrade_vehicle g_upgrade_vehicle("upgradeveh", "Upgrade Vehicle", "Upgrades players vehicle", 0); upgrade_vehicle g_upgrade_vehicle("upgradeveh", "Upgrade Vehicle", "Upgrades players vehicle", 0);

View File

@ -13,12 +13,13 @@ namespace big
virtual void execute(player_ptr player, const std::vector<std::uint64_t>& _args, const std::shared_ptr<command_context> ctx) virtual void execute(player_ptr player, const std::vector<std::uint64_t>& _args, const std::shared_ptr<command_context> ctx)
{ {
Ped ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id()); Ped ped = PLAYER::GET_PLAYER_PED_SCRIPT_INDEX(player->id());
if (PED::IS_PED_IN_ANY_VEHICLE(ped, false)) if (PED::IS_PED_IN_ANY_VEHICLE(ped, false))
{ {
entity::take_control_of(PED::GET_VEHICLE_PED_IS_USING(ped)); Vehicle vehicle = PED::GET_VEHICLE_PED_IS_IN(ped, false);
Vehicle UserVeh = PED::GET_VEHICLE_PED_IS_IN(ped, false);
VEHICLE::SET_VEHICLE_WINDOW_TINT(UserVeh, WINDOWTINT_BLACK); if (entity::take_control_of(vehicle))
VEHICLE::SET_VEHICLE_WINDOW_TINT(vehicle, WINDOWTINT_BLACK);
} }
} }
}; };

View File

@ -14,5 +14,5 @@ namespace big
} }
}; };
heal g_heal("heal", "Heal", "Restores full health and armor", 0); heal g_heal("heal", "HEAL", "HEAL_DESC", 0);
} }

View File

@ -3,7 +3,7 @@
namespace big namespace big
{ {
class int_command : command class int_command : public command
{ {
protected: protected:
int& m_value; int& m_value;
@ -19,5 +19,13 @@ namespace big
{ {
return m_value; return m_value;
} }
inline int get_lower_bound()
{
return m_lower_bound;
}
inline int get_upper_bound()
{
return m_upper_bound;
}
}; };
} }

View File

@ -28,7 +28,6 @@ namespace big
static void self_hud(); static void self_hud();
static void self_dance_mode(); static void self_dance_mode();
static void session_local_time();
static void session_pop_multiplier_areas(); static void session_pop_multiplier_areas();
static void session_force_thunder(); static void session_force_thunder();
static void session_block_jobs(); static void session_block_jobs();
@ -43,11 +42,8 @@ namespace big
static void vehicle_auto_drive(); static void vehicle_auto_drive();
static void vehicle_boost_behavior(); static void vehicle_boost_behavior();
static void vehicle_fly();
static void vehicle_god_mode();
static void vehicle_ls_customs(); static void vehicle_ls_customs();
static void vehicle_rainbow_paint(); static void vehicle_rainbow_paint();
static void vehicle_turn_signals();
static void weapons_ammo_special_type(); static void weapons_ammo_special_type();
static void weapons_cage_gun(); static void weapons_cage_gun();

View File

@ -14,6 +14,5 @@ namespace big
} }
}; };
clean_player_looped g_clean_player_looped("cleanloop", "Keep Player Clean", "Prevents wetness and decals from being applied on you", clean_player_looped g_clean_player_looped("cleanloop", "KEEP_PLAYER_CLEAN", "KEEP_PLAYER_CLEAN_DESC", g.self.clean_player);
g.self.clean_player);
} }

View File

@ -18,9 +18,10 @@ namespace big
ENTITY::SET_ENTITY_COORDS_NO_OFFSET(self::ped, self::pos.x, self::pos.y, self::pos.z, 0, 0, 0); ENTITY::SET_ENTITY_COORDS_NO_OFFSET(self::ped, self::pos.x, self::pos.y, self::pos.z, 0, 0, 0);
TASK::CLEAR_PED_TASKS_IMMEDIATELY(self::ped); TASK::CLEAR_PED_TASKS_IMMEDIATELY(self::ped);
MISC::FORCE_GAME_STATE_PLAYING(); MISC::FORCE_GAME_STATE_PLAYING();
MISC::TERMINATE_ALL_SCRIPTS_WITH_THIS_NAME("respawn_controller");
} }
} }
}; };
fast_respawn g_fast_respawn("fastrespawn", "Instant Respawn", "Makes you respawn instantly when you die", g.self.fast_respawn); fast_respawn g_fast_respawn("fastrespawn", "INSTANT_RESPAWN", "INSTANT_RESPAWN_DESC", g.self.fast_respawn);
} }

View File

@ -71,7 +71,7 @@ namespace big
Vector3 rot = CAM::GET_CAM_ROT(camera, 2); Vector3 rot = CAM::GET_CAM_ROT(camera, 2);
//float pitch = math::deg_to_rad(rot.x); // vertical //float pitch = math::deg_to_rad(rot.x); // vertical
//float roll = rot.y; //float roll = rot.y;
float yaw = math::deg_to_rad(rot.z);// horizontal float yaw = math::deg_to_rad(rot.z); // horizontal
position.x += (vecChange.x * cos(yaw) - vecChange.y * sin(yaw)) * mult; position.x += (vecChange.x * cos(yaw) - vecChange.y * sin(yaw)) * mult;
position.y += (vecChange.x * sin(yaw) + vecChange.y * cos(yaw)) * mult; position.y += (vecChange.x * sin(yaw) + vecChange.y * cos(yaw)) * mult;
@ -95,5 +95,5 @@ namespace big
} }
}; };
free_cam g_free_cam("freecam", "Freecam", "Allows you to move your camera freely?", g.self.free_cam); free_cam g_free_cam("freecam", "FREECAM", "FREECAM_DESC", g.self.free_cam);
} }

View File

@ -37,5 +37,5 @@ namespace big
static bool true_ref = true; static bool true_ref = true;
godmode_internal g_godmode_internal("$$godmode", "", "", true_ref); godmode_internal g_godmode_internal("$$godmode", "", "", true_ref);
bool_command g_godmode("godmode", "God Mode", "Prevents you from taking any form of damage", g.self.god_mode); bool_command g_godmode("godmode", "GODMODE", "GODMODE_DESC", g.self.god_mode);
} }

View File

@ -1,6 +1,6 @@
#include "natives.hpp"
#include "backend/looped_command.hpp" #include "backend/looped_command.hpp"
#include "gta/enums.hpp" #include "gta/enums.hpp"
#include "natives.hpp"
namespace big namespace big
{ {
@ -21,5 +21,5 @@ namespace big
} }
}; };
health_regen_looped g_health_regen_looped("healthregen", "Override Health Regen", "Turn on the regen multiplier you have set.", g.self.healthregen); health_regen_looped g_health_regen_looped("healthregen", "HEALTH_REGEN", "HEALTH_REGEN_DESC", g.self.healthregen);
} }

View File

@ -36,7 +36,6 @@ namespace big
} }
}; };
invisibility g_invisibility("invis", "Invisiblity", "Makes you invisible", g.self.invisibility); invisibility g_invisibility("invis", "INVISIBILITY", "INVISIBILITY_DESC", g.self.invisibility);
bool_command g_local_visibility("localvis", "Visible Locally", "Makes you visible to yourself, but other players would still not be able to see you", bool_command g_local_visibility("localvis", "LOCAL_VISIBILITY", "LOCAL_VISIBILITY_DESC", g.self.local_visibility);
g.self.local_visibility);
} }

View File

@ -20,5 +20,5 @@ namespace big
} }
}; };
mobile_radio g_mobile_radio("mobileradio", "Mobile Radio", "Allows you to listen to the radio on foot", g.self.mobile_radio); mobile_radio g_mobile_radio("mobileradio", "MOBILE_RADIO", "MOBILE_RADIO_DESC", g.self.mobile_radio);
} }

View File

@ -28,6 +28,5 @@ namespace big
->m_bounding_box_max_xyz_margin_w.w = 0.25; ->m_bounding_box_max_xyz_margin_w.w = 0.25;
} }
}; };
no_collision no_collision g_no_collision("nocollision", "NO_COLLISION", "NO_COLLISION_DESC", g.self.no_collision);
g_no_collision("nocollision", "No Collision", "Allows you to walk through vehicles and most obstacles", g.self.no_collision);
} }

View File

@ -20,5 +20,5 @@ namespace big
} }
}; };
no_ragdoll g_no_ragdoll("noragdoll", "No Ragdoll", "Prevents you from ragdolling", g.self.no_ragdoll); no_ragdoll g_no_ragdoll("noragdoll", "NO_RAGDOLL", "NO_RAGDOLL_DESC", g.self.no_ragdoll);
} }

View File

@ -22,6 +22,5 @@ namespace big
} }
}; };
no_water_collision no_water_collision g_no_water_collision("walkunder", "WALK_UNDERWATER", "WALK_UNDERWATER_DESC", g.self.no_water_collision);
g_no_water_collision("walkunder", "Walk Underwater", "Allows you to walk and shoot underwater", g.self.no_water_collision);
} }

View File

@ -3,8 +3,8 @@
#include "fiber_pool.hpp" #include "fiber_pool.hpp"
#include "gta/enums.hpp" #include "gta/enums.hpp"
#include "natives.hpp" #include "natives.hpp"
#include "util/entity.hpp"
#include "services/orbital_drone/orbital_drone.hpp" #include "services/orbital_drone/orbital_drone.hpp"
#include "util/entity.hpp"
namespace big namespace big
{ {
@ -94,5 +94,5 @@ namespace big
} }
}; };
noclip g_noclip("noclip", "No Clip", "Allows you to fly through the map", g.self.noclip); noclip g_noclip("noclip", "NO_CLIP", "NO_CLIP_DESC", g.self.noclip);
} }

View File

@ -20,5 +20,5 @@ namespace big
} }
}; };
off_radar g_off_radar("otr", "Off Radar", "Hides your blip from other players", g.self.off_radar); off_radar g_off_radar("otr", "OFF_RADAR", "OFF_RADAR_DESC", g.self.off_radar);
} }

View File

@ -4,6 +4,7 @@
namespace big namespace big
{ {
// this doesn't actually work
class partwater : looped_command class partwater : looped_command
{ {
using looped_command::looped_command; using looped_command::looped_command;
@ -30,5 +31,5 @@ namespace big
} }
}; };
partwater g_partwater("partwater", "Part Water", "Makes you like Moses", g.world.water.part_water); partwater g_partwater("partwater", "PART_WATER", "PART_WATER_DESC", g.world.water.part_water);
} }

View File

@ -33,12 +33,12 @@ namespace big
1, 1,
1, 1,
1); 1);
STREAMING::REMOVE_PTFX_ASSET();
} }
} }
void show_vehicle_ptfx_effect(const char* fx_name, const char* name) void show_vehicle_ptfx_effect(const char* fx_name, const char* name)
{ {
STREAMING::REQUEST_NAMED_PTFX_ASSET(fx_name);
for (const auto& ptfx_bone : ptfx_vehicle_pos) for (const auto& ptfx_bone : ptfx_vehicle_pos)
{ {
GRAPHICS::USE_PARTICLE_FX_ASSET(fx_name); GRAPHICS::USE_PARTICLE_FX_ASSET(fx_name);
@ -65,7 +65,12 @@ namespace big
else else
show_vehicle_ptfx_effect(g.self.ptfx_effects.asset, g.self.ptfx_effects.effect); show_vehicle_ptfx_effect(g.self.ptfx_effects.asset, g.self.ptfx_effects.effect);
} }
virtual void on_disable() override
{
STREAMING::REMOVE_PTFX_ASSET();
}
}; };
ptfx_looped g_ptfx_looped("ptfx", "Enable PTFX", "Show nice PTFX Effects on your character", g.self.ptfx_effects.show); ptfx_looped g_ptfx_looped("ptfx", "PTFX_CMD", "PTFX_CMD_DESC", g.self.ptfx_effects.show);
} }

View File

@ -61,5 +61,5 @@ namespace big
} }
}; };
super_run g_super_run("fastrun", "Super Run", "Makes you run much faster", g.self.super_run); super_run g_super_run("fastrun", "SUPER_RUN", "SUPER_RUN_DESC", g.self.super_run);
} }

View File

@ -37,5 +37,5 @@ namespace big
} }
}; };
superman g_superman("superman", "Superman", "Fly like a superman", g.self.superman); superman g_superman("superman", "SUPERMAN", "SUPERMAN_DESC", g.self.superman);
} }

View File

@ -16,6 +16,5 @@ namespace big
} }
}; };
unlimited_oxygen unlimited_oxygen g_unlimited_oxygen("infoxy", "UNLIMITED_OXYGEN", "UNLIMITED_OXYGEN_DESC", g.self.unlimited_oxygen);
g_unlimited_oxygen("infoxy", "Unlimited Oxygen", "Allows you to stay underwater without losing oxygen", g.self.unlimited_oxygen);
} }

View File

@ -1,30 +0,0 @@
#include "backend/looped/looped.hpp"
#include "natives.hpp"
namespace big
{
static bool toggled = true;
void looped::session_local_time()
{
if (g.session.override_time)
{
if (toggled)
{
NETWORK::NETWORK_GET_GLOBAL_MULTIPLAYER_CLOCK(&g.session.custom_time.hour,
&g.session.custom_time.minute,
&g.session.custom_time.second);
toggled = false;
}
NETWORK::NETWORK_OVERRIDE_CLOCK_TIME(g.session.custom_time.hour,
g.session.custom_time.minute,
g.session.custom_time.second);
}
else
{
NETWORK::NETWORK_CLEAR_CLOCK_TIME_OVERRIDE();
toggled = true;
}
}
}

View File

@ -10,14 +10,10 @@ namespace big
virtual void on_tick() override virtual void on_tick() override
{ {
//this is a hack to prevent the warning notify.. teleport::to_blip((int)BlipIcons::Waypoint);
if (!teleport::to_blip((int)BlipIcons::Waypoint))
return;
teleport::to_waypoint();
} }
}; };
auto_tp_to_waypoint g_auto_tp_to_waypoint("autotptowp", "Auto-Teleport To Waypoint", "Automatically teleports you to a waypoint as soon as you set one.", auto_tp_to_waypoint g_auto_tp_to_waypoint("autotptowp", "Auto-Teleport To Waypoint", "Automatically teleports you to a waypoint as soon as you set one",
g.self.auto_tp); g.self.auto_tp);
} }

View File

@ -9,7 +9,7 @@ namespace big
{ {
void looped::vehicle_auto_drive() void looped::vehicle_auto_drive()
{ {
static std::map<AutoDriveStyle, int> driving_style_flags = {{AutoDriveStyle::LAW_ABIDING, 443}, {AutoDriveStyle::THE_ROAD_IS_YOURS, 787004}}; static std::unordered_map<AutoDriveStyle, int> driving_style_flags = {{AutoDriveStyle::LAW_ABIDING, 443}, {AutoDriveStyle::THE_ROAD_IS_YOURS, 787004}};
static int changing_driving_styles = false; static int changing_driving_styles = false;
static AutoDriveDestination current_destination = AutoDriveDestination::STOPPED; static AutoDriveDestination current_destination = AutoDriveDestination::STOPPED;

View File

@ -12,45 +12,32 @@ namespace big
const rage::joaat_t drive_on_water_surface_hash = RAGE_JOAAT("stt_prop_stunt_bblock_xl3"); const rage::joaat_t drive_on_water_surface_hash = RAGE_JOAAT("stt_prop_stunt_bblock_xl3");
Vector3 drive_on_water_last_loc; Vector3 drive_on_water_last_loc;
Object surface;
void drive_on_water_hide_surface() void drive_on_water_hide_surface()
{ {
Object surface = OBJECT::GET_CLOSEST_OBJECT_OF_TYPE(drive_on_water_last_loc.x, if (surface && entity::take_control_of(surface, 0))
drive_on_water_last_loc.y,
drive_on_water_last_loc.z,
4.0,
drive_on_water_surface_hash,
0,
0,
1);
if (surface)
{ {
entity::take_control_of(surface);
ENTITY::SET_ENTITY_COORDS(surface, 0, 0, -1000.0f, 0, 0, 0, 1); ENTITY::SET_ENTITY_COORDS(surface, 0, 0, -1000.0f, 0, 0, 0, 1);
ENTITY::SET_ENTITY_AS_NO_LONGER_NEEDED(&surface); ENTITY::SET_ENTITY_AS_NO_LONGER_NEEDED(&surface);
ENTITY::DELETE_ENTITY(&surface); ENTITY::DELETE_ENTITY(&surface);
WATER::RESET_DEEP_OCEAN_SCALER(); surface = 0;
} }
WATER::RESET_DEEP_OCEAN_SCALER();
} }
virtual void on_tick() override virtual void on_tick() override
{ {
Vector3 location = ENTITY::GET_ENTITY_COORDS(self::veh, 1); Vector3 location = ENTITY::GET_ENTITY_COORDS(self::veh, true);
float height = 0; float height = 0;
if (self::veh)
WATER::SET_DEEP_OCEAN_SCALER(0); WATER::SET_DEEP_OCEAN_SCALER(0);
if (location.z - height < 10 && WATER::GET_WATER_HEIGHT_NO_WAVES(location.x, location.y, location.z, &height) && self::veh)
{
Object surface = OBJECT::GET_CLOSEST_OBJECT_OF_TYPE(drive_on_water_last_loc.x,
drive_on_water_last_loc.y,
drive_on_water_last_loc.z,
4.0,
drive_on_water_surface_hash,
0,
0,
1);
if (self::veh && location.z - height < 10
&& WATER::GET_WATER_HEIGHT_NO_WAVES(location.x, location.y, location.z, &height))
{
if (ENTITY::DOES_ENTITY_EXIST(surface) && height > -50.0f) if (ENTITY::DOES_ENTITY_EXIST(surface) && height > -50.0f)
{ {
entity::take_control_of(surface); entity::take_control_of(surface);
@ -68,7 +55,7 @@ namespace big
if (location.z < height - 2.f) if (location.z < height - 2.f)
{ {
entity::take_control_of(self::veh); if (entity::take_control_of(self::veh, 0))
ENTITY::SET_ENTITY_COORDS(self::veh, location.x, location.y, height, 0, 0, 0, 0); ENTITY::SET_ENTITY_COORDS(self::veh, location.x, location.y, height, 0, 0, 0, 0);
} }
} }
@ -90,7 +77,6 @@ namespace big
1, 1,
0); 0);
entity::take_control_of(surface);
ENTITY::FREEZE_ENTITY_POSITION(surface, 1); ENTITY::FREEZE_ENTITY_POSITION(surface, 1);
ENTITY::SET_ENTITY_ALPHA(surface, 0, 1); ENTITY::SET_ENTITY_ALPHA(surface, 0, 1);
ENTITY::SET_ENTITY_VISIBLE(surface, false, 0); ENTITY::SET_ENTITY_VISIBLE(surface, false, 0);

View File

@ -1,17 +1,39 @@
#include "backend/looped/looped.hpp" #include "backend/looped_command.hpp"
#include "gta/enums.hpp" #include "gta/enums.hpp"
#include "natives.hpp" #include "natives.hpp"
#include "util/entity.hpp"
namespace big namespace big
{ {
class vehicle_fly : looped_command
{
using looped_command::looped_command;
static bool last_fly_tick = false; Vehicle last_vehicle = 0;
void do_vehicle_fly() void cleanup(Vehicle vehicle)
{
VEHICLE::SET_VEHICLE_GRAVITY(vehicle, true);
ENTITY::SET_ENTITY_COLLISION(vehicle, true, true);
if (g.vehicle.fly.stop_on_exit)
{
VEHICLE::SET_VEHICLE_FORWARD_SPEED(vehicle, 0.0);
}
}
virtual void on_tick() override
{ {
Vehicle vehicle = self::veh; Vehicle vehicle = self::veh;
if (last_vehicle != vehicle)
{
if (last_vehicle)
cleanup(last_vehicle);
last_vehicle = vehicle;
}
if (vehicle)
{
Vector3 cam_pos = CAM::GET_GAMEPLAY_CAM_ROT(0); Vector3 cam_pos = CAM::GET_GAMEPLAY_CAM_ROT(0);
ENTITY::SET_ENTITY_ROTATION(vehicle, cam_pos.x, cam_pos.y, cam_pos.z, 1, true); ENTITY::SET_ENTITY_ROTATION(vehicle, cam_pos.x, cam_pos.y, cam_pos.z, 1, true);
ENTITY::SET_ENTITY_COLLISION(vehicle, !g.vehicle.fly.no_collision, true); ENTITY::SET_ENTITY_COLLISION(vehicle, !g.vehicle.fly.no_collision, true);
@ -23,7 +45,6 @@ namespace big
locspeed *= 2; locspeed *= 2;
} }
if (PAD::IS_CONTROL_PRESSED(2, (int)ControllerInputs::INPUT_VEH_ACCELERATE)) if (PAD::IS_CONTROL_PRESSED(2, (int)ControllerInputs::INPUT_VEH_ACCELERATE))
{ {
if (g.vehicle.fly.dont_stop) if (g.vehicle.fly.dont_stop)
@ -92,56 +113,16 @@ namespace big
VEHICLE::SET_VEHICLE_FORWARD_SPEED(vehicle, 0.0); VEHICLE::SET_VEHICLE_FORWARD_SPEED(vehicle, 0.0);
} }
if (TASK::GET_IS_TASK_ACTIVE(self::ped, 2))
{
g.vehicle.fly.enabled = false;
VEHICLE::SET_VEHICLE_GRAVITY(vehicle, true);
ENTITY::SET_ENTITY_COLLISION(vehicle, true, true);
if (g.vehicle.fly.stop_on_exit)
{
VEHICLE::SET_VEHICLE_FORWARD_SPEED(vehicle, 0.0);
}
}
}
void looped::vehicle_fly()
{
Vehicle vehicle = self::veh;
if (g.vehicle.fly.enabled)
{
last_fly_tick = true;
if (!vehicle)
{
g_notification_service->push_warning("Warning", "Please be in a vehicle before enabling vehicle fly.");
g.vehicle.fly.enabled = false;
return;
}
else
{
if (NETWORK::NETWORK_HAS_CONTROL_OF_ENTITY(vehicle))
{
do_vehicle_fly();
VEHICLE::SET_VEHICLE_GRAVITY(vehicle, false); VEHICLE::SET_VEHICLE_GRAVITY(vehicle, false);
} }
else }
virtual void on_disable() override
{ {
for (int i = 0; i < 5; i++) if (self::veh)
{ cleanup(self::veh);
entity::take_control_of(vehicle);
g_notification_service->push_warning("Warning", "Failed to take control of the vehicle.");
}
}
}
}
else
{
if (last_fly_tick)
{
ENTITY::SET_ENTITY_COLLISION(vehicle, true, true);
VEHICLE::SET_VEHICLE_GRAVITY(vehicle, true);
last_fly_tick = false;
}
}
} }
};
vehicle_fly g_vehicle_fly("vehiclefly", "Vehicle Fly", "Fly with any land vehicle", g.vehicle.fly.enabled);
} }

View File

@ -1,3 +1,5 @@
#include "backend/bool_command.hpp"
#include "backend/int_command.hpp"
#include "backend/looped/looped.hpp" #include "backend/looped/looped.hpp"
#include "natives.hpp" #include "natives.hpp"
#include "script.hpp" #include "script.hpp"
@ -127,4 +129,16 @@ namespace big
last_rgb_run_time = std::chrono::system_clock::now(); last_rgb_run_time = std::chrono::system_clock::now();
} }
} }
bool_command g_rainbow_paint_primary("rainbowpri", "Rainbow Paint: Apply to Primary", "Applies active rainbow effect to the current vehicle's primary color",
g.vehicle.rainbow_paint.primary);
bool_command g_rainbow_paint_secondary("rainbowsec", "Rainbow Paint: Apply to Secondary", "Applies active rainbow effect to the current vehicle's secondary color",
g.vehicle.rainbow_paint.secondary);
bool_command g_rainbow_paint_neon("rainbowneons", "Rainbow Paint: Apply to Neons", "Applies active rainbow effect to the current vehicle's neon color",
g.vehicle.rainbow_paint.neon);
bool_command g_rainbow_paint_smoke("rainbowsmoke", "Rainbow Paint: Apply to Tire Smoke", "Applies active rainbow effect to the current vehicle's tire smoke color",
g.vehicle.rainbow_paint.smoke);
int_command g_rainbow_paint_speed("rainbowspeed", "Rainbow Paint: Speed", "Speed of the rainbow paint effect",
g.vehicle.rainbow_paint.speed, 1, 10);
} }

View File

@ -1,4 +1,4 @@
#include "backend/looped/looped.hpp" #include "backend/looped_command.hpp"
#include "fiber_pool.hpp" #include "fiber_pool.hpp"
#include "gta/enums.hpp" #include "gta/enums.hpp"
#include "natives.hpp" #include "natives.hpp"
@ -6,8 +6,10 @@
#include "util/is_key_pressed.hpp" #include "util/is_key_pressed.hpp"
#include "windows.h" #include "windows.h"
struct key_state namespace big
{ {
struct key_state
{
key_state(int v_key) : key_state(int v_key) :
v_key(v_key) v_key(v_key)
{ {
@ -23,14 +25,21 @@ struct key_state
uint8_t state = up; uint8_t state = up;
int v_key; int v_key;
}; };
inline key_state right_signal_key{'L'}; class turn_signals : looped_command
inline key_state left_signal_key{'J'}; {
inline key_state hazzards_key{'K'}; using looped_command::looped_command;
void update_key_state(key_state& key_last_tick) key_state right_signal_key{'L'};
{ key_state left_signal_key{'J'};
key_state hazzards_key{'K'};
std::optional<std::chrono::system_clock::time_point> queued_left_turn_signal;
std::optional<std::chrono::system_clock::time_point> queued_right_turn_signal;
bool hazzards = false;
void update_key_state(key_state& key_last_tick)
{
if (big::is_key_pressed(key_last_tick.v_key)) if (big::is_key_pressed(key_last_tick.v_key))
{ {
switch (key_last_tick.state) switch (key_last_tick.state)
@ -49,28 +58,27 @@ void update_key_state(key_state& key_last_tick)
case key_state::just_released: key_last_tick.state = key_state::up; break; case key_state::just_released: key_last_tick.state = key_state::up; break;
} }
} }
} }
void update_key_states()
void update_key_states() {
{
update_key_state(left_signal_key); update_key_state(left_signal_key);
update_key_state(hazzards_key); update_key_state(hazzards_key);
update_key_state(right_signal_key); update_key_state(right_signal_key);
} }
struct signal_state struct signal_state
{ {
enum enum
{ {
right, right,
left, left,
hazzards hazzards
}; };
}; };
inline void set_turn_signals(int signal_state, bool on) inline void set_turn_signals(int signal_state, bool on)
{ {
static constexpr int off = 0; static constexpr int off = 0;
if (self::veh && big::g.vehicle.turn_signals) if (self::veh && big::g.vehicle.turn_signals)
@ -93,42 +101,29 @@ inline void set_turn_signals(int signal_state, bool on)
break; break;
} }
} }
}
namespace big
{
static bool b_last_turn_signals = false;
void looped::vehicle_turn_signals()
{
static bool hazzards = false;
bool b_turn_signals = g.vehicle.turn_signals;
if (!b_turn_signals && b_turn_signals != b_last_turn_signals)
{
VEHICLE::SET_VEHICLE_INDICATOR_LIGHTS(PED::GET_VEHICLE_PED_IS_IN(PLAYER::PLAYER_PED_ID(), false), 0, 0);
VEHICLE::SET_VEHICLE_INDICATOR_LIGHTS(PED::GET_VEHICLE_PED_IS_IN(PLAYER::PLAYER_PED_ID(), false), 1, 0);
} }
if (g.vehicle.turn_signals) virtual void on_enable() override
{ {
static bool ran_once = [] {
g_notification_service->push("Instructions", "Manual: J = Left, L = Right, K = Toggle Hazzards"); g_notification_service->push("Instructions", "Manual: J = Left, L = Right, K = Toggle Hazzards");
return true;
}();
} }
virtual void on_tick() override
{
update_key_states(); update_key_states();
if (left_signal_key.state == key_state::just_pressed || g.vehicle.auto_turn_signals && PAD::IS_CONTROL_PRESSED(0, (int)ControllerInputs::INPUT_VEH_MOVE_LEFT_ONLY)) if (left_signal_key.state == key_state::just_pressed || g.vehicle.auto_turn_signals && PAD::IS_CONTROL_PRESSED(0, (int)ControllerInputs::INPUT_VEH_MOVE_LEFT_ONLY)
|| queued_left_turn_signal.has_value() && queued_left_turn_signal.value() - std::chrono::system_clock::now() > 1500ms)
{ {
set_turn_signals(signal_state::left, true); set_turn_signals(signal_state::left, true);
queued_left_turn_signal = std::nullopt;
} }
if (right_signal_key.state == key_state::just_pressed || g.vehicle.auto_turn_signals && PAD::IS_CONTROL_PRESSED(0, (int)ControllerInputs::INPUT_VEH_MOVE_RIGHT_ONLY)) if (right_signal_key.state == key_state::just_pressed || g.vehicle.auto_turn_signals && PAD::IS_CONTROL_PRESSED(0, (int)ControllerInputs::INPUT_VEH_MOVE_RIGHT_ONLY)
|| queued_right_turn_signal.has_value() && queued_right_turn_signal.value() - std::chrono::system_clock::now() > 1500ms)
{ {
set_turn_signals(signal_state::right, true); set_turn_signals(signal_state::right, true);
queued_right_turn_signal = std::nullopt;
} }
if (hazzards_key.state == key_state::just_pressed && !hazzards) if (hazzards_key.state == key_state::just_pressed && !hazzards)
@ -142,25 +137,29 @@ namespace big
hazzards = false; hazzards = false;
} }
if (!queued_left_turn_signal.has_value() && !queued_right_turn_signal.has_value())
{
if (PAD::IS_CONTROL_JUST_RELEASED(0, (int)ControllerInputs::INPUT_VEH_MOVE_LEFT_ONLY)) if (PAD::IS_CONTROL_JUST_RELEASED(0, (int)ControllerInputs::INPUT_VEH_MOVE_LEFT_ONLY))
{ {
if (g.vehicle.turn_signals) queued_left_turn_signal = std::chrono::system_clock::now();
{
script::get_current()->yield(1500ms);
}
set_turn_signals(signal_state::left, false);
} }
if (PAD::IS_CONTROL_JUST_RELEASED(0, (int)ControllerInputs::INPUT_VEH_MOVE_RIGHT_ONLY)) if (PAD::IS_CONTROL_JUST_RELEASED(0, (int)ControllerInputs::INPUT_VEH_MOVE_RIGHT_ONLY))
{ {
if (g.vehicle.turn_signals) queued_right_turn_signal = std::chrono::system_clock::now();
{ }
script::get_current()->yield(1500ms);
} }
set_turn_signals(signal_state::right, false);
} }
b_last_turn_signals = g.vehicle.turn_signals; virtual void on_disable() override
{
if (self::veh)
{
VEHICLE::SET_VEHICLE_INDICATOR_LIGHTS(self::veh, 0, 0);
VEHICLE::SET_VEHICLE_INDICATOR_LIGHTS(self::veh, 1, 0);
} }
}
};
turn_signals g_turn_signals("turnsignals", "Turn Signals", "Makes your car invisible", g.vehicle.turn_signals);
} }

View File

@ -1,14 +1,18 @@
#include "backend/looped/looped.hpp" #include "backend/looped/looped.hpp"
#include "backend/looped_command.hpp"
#include "natives.hpp" #include "natives.hpp"
#include "util/misc.hpp"
namespace big namespace big
{ {
static uint32_t last_bits = 0; class vehicle_godmode_internal : looped_command
static float last_water_collistion_strength = 0; {
static bool last_driving; using looped_command::looped_command;
void looped::vehicle_god_mode() uint32_t last_bits = 0;
float last_water_collistion_strength = 0;
bool last_driving = false;
virtual void on_tick() override
{ {
if (g_local_player == nullptr || g_local_player->m_vehicle == nullptr) if (g_local_player == nullptr || g_local_player->m_vehicle == nullptr)
{ {
@ -49,4 +53,19 @@ namespace big
last_bits = bits; last_bits = bits;
} }
} }
virtual void on_disable() override
{
if (g_local_player && g_local_player->m_vehicle)
{
g_local_player->m_vehicle->m_deform_god = 0x9C;
g_local_player->m_vehicle->m_damage_bits = 0;
}
}
};
static bool true_ref = true;
vehicle_godmode_internal g_vehicle_godmode_internal("$$vehgodmode", "", "", true_ref);
bool_command g_vehicle_godmode("vehgodmode", "Vehicle God Mode", "Prevents your vehicle from taking any form of damage",
g.vehicle.god_mode);
} }

View File

@ -10,7 +10,8 @@ namespace big
virtual void on_tick() override virtual void on_tick() override
{ {
if (self::veh && PAD::IS_CONTROL_JUST_PRESSED(0, (int)ControllerInputs::INPUT_VEH_HANDBRAKE)) PAD::DISABLE_CONTROL_ACTION(0, (int)ControllerInputs::INPUT_VEH_HANDBRAKE, false);
if (self::veh && PAD::IS_DISABLED_CONTROL_JUST_PRESSED(0, (int)ControllerInputs::INPUT_VEH_HANDBRAKE))
{ {
ENTITY::APPLY_FORCE_TO_ENTITY(self::veh, 1, 0.0, 0.0, 20, 0.0, 0.0, 0.0, 0, 0, 1, 1, 0, 1); ENTITY::APPLY_FORCE_TO_ENTITY(self::veh, 1, 0.0, 0.0, 20, 0.0, 0.0, 0.0, 0, 0, 1, 1, 0, 1);
} }

View File

@ -17,31 +17,31 @@ namespace big
float local_fov_change = g.weapons.aimbot.fov; float local_fov_change = g.weapons.aimbot.fov;
for (auto ped : entity::get_entities(false, true)) for (auto ped : entity::get_entities(false, true))
{ {
if (ENTITY::HAS_ENTITY_CLEAR_LOS_TO_ENTITY(self::ped, ped, 17) && !ENTITY::IS_ENTITY_DEAD(ped, 0))// Tracetype is always 17. LOS check if (!ENTITY::IS_ENTITY_DEAD(ped, 0)) // Tracetype is always 17. LOS check
{ {
int relation = PED::GET_RELATIONSHIP_BETWEEN_PEDS(ped, self::ped);// relation for enemy check int relation = PED::GET_RELATIONSHIP_BETWEEN_PEDS(ped, self::ped); // relation for enemy check
int type = PED::GET_PED_TYPE(ped);// for police check, cop types are 6, swat is 27 int type = PED::GET_PED_TYPE(ped); // for police check, cop types are 6, swat is 27
Vector3 world_position = ENTITY::GET_ENTITY_COORDS(ped, false); Vector3 world_position = ENTITY::GET_ENTITY_COORDS(ped, false);
if (SYSTEM::VDIST(self::pos.x, if (SYSTEM::VDIST2(self::pos.x,
self::pos.y, self::pos.y,
self::pos.z, self::pos.z,
world_position.x, world_position.x,
world_position.y, world_position.y,
world_position.z) world_position.z)
> g.weapons.aimbot.distance) > (g.weapons.aimbot.distance * g.weapons.aimbot.distance))
continue;// If the entity is further than our preset distance then just skip it continue; // If the entity is further than our preset distance then just skip it
if (PED::IS_PED_A_PLAYER(ped) && g.weapons.aimbot.on_player)// check if its a player if (PED::IS_PED_A_PLAYER(ped) && g.weapons.aimbot.on_player) // check if its a player
{ {
goto aimbot_handler; goto aimbot_handler;
} }
else if (((relation == 4) || (relation == 5)) && g.weapons.aimbot.on_enemy)// relation 4 and 5 are for enemies else if (((relation == 4) || (relation == 5)) && g.weapons.aimbot.on_enemy) // relation 4 and 5 are for enemies
{ {
goto aimbot_handler; goto aimbot_handler;
} }
else if (((type == 6 && !PED::IS_PED_MODEL(ped, rage::joaat("s_m_y_uscg_01"))) || type == 27 ||// s_m_y_uscg_01 = us coast guard 1 (techniaclly military) else if (((type == 6 && !PED::IS_PED_MODEL(ped, rage::joaat("s_m_y_uscg_01"))) || type == 27 || // s_m_y_uscg_01 = us coast guard 1 (technically military)
PED::IS_PED_MODEL(ped, rage::joaat("s_m_y_ranger_01")) || PED::IS_PED_MODEL(ped, rage::joaat("s_f_y_ranger_01")))// ranger models PED::IS_PED_MODEL(ped, rage::joaat("s_m_y_ranger_01")) || PED::IS_PED_MODEL(ped, rage::joaat("s_f_y_ranger_01"))) // ranger models
&& g.weapons.aimbot.on_police) && g.weapons.aimbot.on_police)
{ {
goto aimbot_handler; goto aimbot_handler;
@ -50,10 +50,14 @@ namespace big
// Update aim lock coords // Update aim lock coords
aimbot_handler: aimbot_handler:
{// Jump to here to handle instead of continue statements {
if (!ENTITY::HAS_ENTITY_CLEAR_LOS_TO_ENTITY(self::ped, ped, 17))
continue;
// Jump to here to handle instead of continue statements
aim_lock = aim_lock =
ENTITY::GET_WORLD_POSITION_OF_ENTITY_BONE(ped, PED::GET_PED_BONE_INDEX(ped, g.weapons.aimbot.selected_bone)); ENTITY::GET_WORLD_POSITION_OF_ENTITY_BONE(ped, PED::GET_PED_BONE_INDEX(ped, g.weapons.aimbot.selected_bone));
if ((aim_lock.x != 0) && (aim_lock.y != 0) && (aim_lock.z != 0))// Ensure none of the coords are = to 0 if ((aim_lock.x != 0) && (aim_lock.y != 0) && (aim_lock.z != 0)) // Ensure none of the coords are = to 0
{ {
Vector2 screen_dim, movement; Vector2 screen_dim, movement;
GRAPHICS::GET_SCREEN_COORD_FROM_WORLD_COORD(aim_lock.x, GRAPHICS::GET_SCREEN_COORD_FROM_WORLD_COORD(aim_lock.x,
@ -61,22 +65,22 @@ namespace big
aim_lock.z, aim_lock.z,
&screen_dim.x, &screen_dim.x,
&screen_dim.y); &screen_dim.y);
if ((screen_dim.x >= 0) && (screen_dim.y >= 0))// Make sure updated screen dim is greater than 0 if ((screen_dim.x >= 0) && (screen_dim.y >= 0)) // Make sure updated screen dim is greater than 0
{ {
auto& io = ImGui::GetIO(); auto& io = ImGui::GetIO();
ImVec2 center(io.DisplaySize.x / 2.f, io.DisplaySize.y / 2.f);// Use ImGui to get the display size ImVec2 center(io.DisplaySize.x / 2.f, io.DisplaySize.y / 2.f); // Use ImGui to get the display size
//Screen dim is a float between 0-1, multiply the float by screen coords //Screen dim is a float between 0-1, multiply the float by screen coords
screen_dim.x *= io.DisplaySize.x; screen_dim.x *= io.DisplaySize.x;
screen_dim.y *= io.DisplaySize.y; screen_dim.y *= io.DisplaySize.y;
if (screen_dim.x > center.x)//If the location is greater than the center (right side) if (screen_dim.x > center.x) //If the location is greater than the center (right side)
{// Get the amount of distance we need to move, so center of the screen - our location { // Get the amount of distance we need to move, so center of the screen - our location
movement.x = -(center.x - screen_dim.x); movement.x = -(center.x - screen_dim.x);
if (movement.x + center.x > center.x * 2) if (movement.x + center.x > center.x * 2)
movement.x = 0; movement.x = 0;
} }
else else
{// if the location is on the left side { // if the location is on the left side
movement.x = screen_dim.x - center.x; movement.x = screen_dim.x - center.x;
if (movement.x + center.x < 0) if (movement.x + center.x < 0)
movement.x = 0; movement.x = 0;
@ -97,7 +101,7 @@ namespace big
} }
if (sqrt(pow(movement.x, 2) + pow(movement.y, 2)) < local_fov_change) if (sqrt(pow(movement.x, 2) + pow(movement.y, 2)) < local_fov_change)
{// sqrt of movment x and y ^ 2, handles fov math { // sqrt of movment x and y ^ 2, handles fov math
local_fov_change = sqrt(pow(movement.x, 2) + pow(movement.y, 2)); local_fov_change = sqrt(pow(movement.x, 2) + pow(movement.y, 2));
mouse_movement.x = movement.x; mouse_movement.x = movement.x;
mouse_movement.y = movement.y; mouse_movement.y = movement.y;
@ -116,32 +120,32 @@ namespace big
if (update_time_now) if (update_time_now)
{ {
current_time = std::chrono::system_clock::now(); current_time = std::chrono::system_clock::now();
update_time_now = false;//lockout update_time_now = false; //lockout
} }
std::chrono::duration<double> elapsed_time = std::chrono::system_clock::now() - current_time; std::chrono::duration<double> elapsed_time = std::chrono::system_clock::now() - current_time;
if (elapsed_time.count() > 0.f) if (elapsed_time.count() > 0.f)
{ {
INPUT mouse_handle;// MOUSEINPUT mi; INPUT mouse_handle; // MOUSEINPUT mi;
mouse_handle.type = INPUT_MOUSE; mouse_handle.type = INPUT_MOUSE;
mouse_handle.mi.dwFlags = MOUSEEVENTF_MOVE;// Type = Mouse movement, and the event is emulating the mouse movement mouse_handle.mi.dwFlags = MOUSEEVENTF_MOVE; // Type = Mouse movement, and the event is emulating the mouse movement
// Update the mouse by moving it with how much we need / smoothing speed // Update the mouse by moving it with how much we need / smoothing speed
mouse_handle.mi.dx = mouse_movement.x / (g.weapons.aimbot.smoothing ? g.weapons.aimbot.smoothing_speed : 2); mouse_handle.mi.dx = mouse_movement.x / (g.weapons.aimbot.smoothing ? g.weapons.aimbot.smoothing_speed : 2);
mouse_handle.mi.dy = mouse_movement.y / (g.weapons.aimbot.smoothing ? g.weapons.aimbot.smoothing_speed : 2); mouse_handle.mi.dy = mouse_movement.y / (g.weapons.aimbot.smoothing ? g.weapons.aimbot.smoothing_speed : 2);
SendInput(1, &mouse_handle, sizeof(mouse_handle));//handles the input SendInput(1, &mouse_handle, sizeof(mouse_handle)); //handles the input
//Reset our variables //Reset our variables
mouse_movement.x = 0, mouse_movement.y = 0; mouse_movement.x = 0, mouse_movement.y = 0;
update_time_now = true;//reset our time update_time_now = true; //reset our time
} }
} }
} }
}; };
aimbot g_aimbot("aimbot", "Aimbot", "lock on and kill", g.weapons.aimbot.enable); aimbot g_aimbot("aimbot", "Aimbot", "Lock on and kill", g.weapons.aimbot.enable);
bool_command g_smoothing("smoothing", "Smoothing", "Controls the snappiness of your lock on", g.weapons.aimbot.smoothing); bool_command g_smoothing("smoothing", "Smoothing", "Controls the snappiness of your lock on", g.weapons.aimbot.smoothing);
bool_command g_aimbot_on_player("aimatplayer", "Player", "If you suck at pvp this is for you.", g.weapons.aimbot.on_player); bool_command g_aimbot_on_player("aimatplayer", "Player", "If you suck at PVP, this is for you", g.weapons.aimbot.on_player);
bool_command g_aimbot_on_npc("aimatnpc", "NPC", "Generally kills normal NPCs", g.weapons.aimbot.on_npc); bool_command g_aimbot_on_npc("aimatnpc", "NPC", "Generally kills normal NPCs", g.weapons.aimbot.on_npc);
bool_command g_aimbot_on_police("aimatpolice", "Police", "Locks onto cops to kill", g.weapons.aimbot.on_police); bool_command g_aimbot_on_police("aimatpolice", "Police", "Locks onto cops to kill", g.weapons.aimbot.on_police);
bool_command bool_command

View File

@ -1,18 +0,0 @@
#include "backend/looped_command.hpp"
#include "natives.hpp"
namespace big
{
class force_crosshairs : looped_command
{
using looped_command::looped_command;
virtual void on_tick() override
{
HUD::SHOW_HUD_COMPONENT_THIS_FRAME(static_cast<int>(HudComponents::RETICLE));
}
};
force_crosshairs g_force_crosshairs("crosshairs", "Force Crosshairs", "Shows the crosshair even when you are not aiming",
g.weapons.force_crosshairs);// do we need this?
}

View File

@ -1,5 +1,5 @@
#include "natives.hpp"
#include "backend/looped_command.hpp" #include "backend/looped_command.hpp"
#include "natives.hpp"
namespace big namespace big
{ {
@ -17,13 +17,6 @@ namespace big
WEAPON::SET_WEAPON_DAMAGE_MODIFIER(weapon, g.weapons.increased_damage); WEAPON::SET_WEAPON_DAMAGE_MODIFIER(weapon, g.weapons.increased_damage);
} }
} }
virtual void on_disable() override
{
Hash weapon{};
WEAPON::GET_CURRENT_PED_WEAPON(self::ped, &weapon, 0);
WEAPON::SET_WEAPON_DAMAGE_MODIFIER(weapon, 1);
}
}; };
increased_damage increased_damage

View File

@ -20,18 +20,21 @@ namespace big
if (g_local_player->m_weapon_manager) if (g_local_player->m_weapon_manager)
{ {
if (p_modified_weapon != g_local_player->m_weapon_manager->m_weapon_info if (p_modified_weapon != g_local_player->m_weapon_manager->m_weapon_info)
&& g_local_player->m_weapon_manager->m_weapon_info)
{ {
if (p_modified_weapon) if (p_modified_weapon)
p_modified_weapon->m_weapon_range = og_range; p_modified_weapon->m_weapon_range = og_range;
og_range = g_local_player->m_weapon_manager->m_weapon_info->m_weapon_range;
p_modified_weapon = g_local_player->m_weapon_manager->m_weapon_info; p_modified_weapon = g_local_player->m_weapon_manager->m_weapon_info;
if (g_local_player->m_weapon_manager->m_weapon_info)
{
og_range = g_local_player->m_weapon_manager->m_weapon_info->m_weapon_range;
g_local_player->m_weapon_manager->m_weapon_info->m_weapon_range = 1000.0f; g_local_player->m_weapon_manager->m_weapon_info->m_weapon_range = 1000.0f;
} }
} }
} }
}
virtual void on_disable() override virtual void on_disable() override
{ {

View File

@ -21,17 +21,21 @@ namespace big
auto* const weapon_mgr = g_local_player->m_weapon_manager; auto* const weapon_mgr = g_local_player->m_weapon_manager;
if (weapon_mgr) if (weapon_mgr)
{ {
if (p_modified_weapon != weapon_mgr->m_weapon_info && weapon_mgr->m_weapon_info) if (p_modified_weapon != weapon_mgr->m_weapon_info)
{ {
if (p_modified_weapon) if (p_modified_weapon)
p_modified_weapon->m_explosion_shake_amplitude = og_recoil_value; p_modified_weapon->m_explosion_shake_amplitude = og_recoil_value;
og_recoil_value = weapon_mgr->m_weapon_info->m_explosion_shake_amplitude;
p_modified_weapon = weapon_mgr->m_weapon_info; p_modified_weapon = weapon_mgr->m_weapon_info;
if (weapon_mgr->m_weapon_info)
{
og_recoil_value = weapon_mgr->m_weapon_info->m_explosion_shake_amplitude;
weapon_mgr->m_weapon_info->m_explosion_shake_amplitude = 0.0f; weapon_mgr->m_weapon_info->m_explosion_shake_amplitude = 0.0f;
} }
} }
} }
}
virtual void on_disable() override virtual void on_disable() override
{ {

View File

@ -21,17 +21,21 @@ namespace big
auto* const weapon_mgr = g_local_player->m_weapon_manager; auto* const weapon_mgr = g_local_player->m_weapon_manager;
if (weapon_mgr) if (weapon_mgr)
{ {
if (p_modified_weapon != weapon_mgr->m_weapon_info && weapon_mgr->m_weapon_info) if (p_modified_weapon != weapon_mgr->m_weapon_info)
{ {
if (p_modified_weapon) if (p_modified_weapon)
p_modified_weapon->m_accuracy_spread = og_spread_value; p_modified_weapon->m_accuracy_spread = og_spread_value;
og_spread_value = weapon_mgr->m_weapon_info->m_accuracy_spread;
p_modified_weapon = weapon_mgr->m_weapon_info; p_modified_weapon = weapon_mgr->m_weapon_info;
if (weapon_mgr->m_weapon_info)
{
og_spread_value = weapon_mgr->m_weapon_info->m_accuracy_spread;
weapon_mgr->m_weapon_info->m_accuracy_spread = 0.0f; weapon_mgr->m_weapon_info->m_accuracy_spread = 0.0f;
} }
} }
} }
}
virtual void on_disable() override virtual void on_disable() override
{ {

View File

@ -7,7 +7,6 @@
namespace big namespace big
{ {
class blackhole : looped_command class blackhole : looped_command
{ {
using looped_command::looped_command; using looped_command::looped_command;
@ -64,10 +63,10 @@ namespace big
} }
}; };
blackhole g_blackhole("blackhole", "Blackhole", "Spawns a black hole that picks up all the peds and vehicles in your area.", blackhole g_blackhole("blackhole", "Blackhole", "Spawns a blackhole that picks up all the peds and vehicles in your area",
g.world.blackhole.enable); g.world.blackhole.enable);
bool_command g_blackhole_peds("blackholeincpeds", "Peds", "Includes all nearby peds in the blackholes path of destruction", bool_command g_blackhole_peds("blackholeincpeds", "Peds", "Includes all nearby peds in the blackhole's path of destruction",
g.world.blackhole.include_peds); g.world.blackhole.include_peds);
bool_command g_blackhole_vehicles("blackholeincvehs", "Vehicles", "Includes all nearby vehicles in the blackholes path of destruction", bool_command g_blackhole_vehicles("blackholeincvehs", "Vehicles", "Includes all nearby vehicles in the blackhole's path of destruction",
g.world.blackhole.include_vehicles); g.world.blackhole.include_vehicles);
} }

View File

@ -3,7 +3,6 @@
namespace big namespace big
{ {
class combative : looped_command class combative : looped_command
{ {
using looped_command::looped_command; using looped_command::looped_command;
@ -13,13 +12,15 @@ namespace big
MISC::SET_RIOT_MODE_ENABLED(true); MISC::SET_RIOT_MODE_ENABLED(true);
} }
virtual void on_tick() override {} virtual void on_tick() override
{
}
virtual void on_disable() override virtual void on_disable() override
{ {
MISC::SET_RIOT_MODE_ENABLED(false); MISC::SET_RIOT_MODE_ENABLED(false);
} }
}; };
combative g_combative("riotmode", "Riot Mode", "Make nearby peds attack eachother", g.world.nearby.combative);
combative g_combative("riotmode", "Riot Mode", "Make nearby peds attack each other", g.world.nearby.combative);
} }

Some files were not shown because too many files have changed in this diff Show More