From 9b80c035e0b8b05527b5917ce3fb57100449c1e2 Mon Sep 17 00:00:00 2001 From: Jerome Montino Date: Thu, 2 Jun 2022 19:53:33 +0800 Subject: [PATCH] Added ore and some other items to Attack Modifiers. --- cheat-base/vendor/imgui | 2 +- .../src/user/cheat/player/RapidFire.cpp | 23 ++++++++++++++++--- 2 files changed, 21 insertions(+), 4 deletions(-) diff --git a/cheat-base/vendor/imgui b/cheat-base/vendor/imgui index 47fb633..af916cd 160000 --- a/cheat-base/vendor/imgui +++ b/cheat-base/vendor/imgui @@ -1 +1 @@ -Subproject commit 47fb633e73f69e1ba57cef16cd077ddc4d97f0ee +Subproject commit af916cdf1aa41243b493c217c8d4256c04aa8921 diff --git a/cheat-library/src/user/cheat/player/RapidFire.cpp b/cheat-library/src/user/cheat/player/RapidFire.cpp index 5e2fa3c..4d5dcd2 100644 --- a/cheat-library/src/user/cheat/player/RapidFire.cpp +++ b/cheat-library/src/user/cheat/player/RapidFire.cpp @@ -183,6 +183,17 @@ namespace cheat::feature return attackerID == avatarID || IsAvatarOwner(attacker); } + bool IsValidByFilter(game::Entity* entity) + { + if (game::filters::combined::OrganicTargets.IsValid(entity) || + game::filters::combined::Ores.IsValid(entity) || + game::filters::puzzle::Geogranum.IsValid(entity) || + game::filters::puzzle::LargeRockPile.IsValid(entity) || + game::filters::puzzle::SmallRockPile.IsValid(entity)) + return true; + return false; + } + // Raises when any entity do hit event. // Just recall attack few times (regulating by combatProp) // It's not tested well, so, I think, anticheat can detect it. @@ -196,24 +207,30 @@ namespace cheat::feature auto& manager = game::EntityManager::instance(); auto originalTarget = manager.entity(targetID); - if (!game::filters::combined::OrganicTargets.IsValid(originalTarget)) + if (!IsValidByFilter(originalTarget)) return CALL_ORIGIN(LCBaseCombat_DoHitEntity_Hook, __this, targetID, attackResult, ignoreCheckCanBeHitInMP, method); std::vector validEntities; validEntities.push_back(originalTarget); - + if (rapidFire.f_MultiTarget) { - auto filteredEntities = manager.entities(game::filters::combined::Monsters); + auto filteredEntities = manager.entities(); for (const auto& entity : filteredEntities) { auto distance = originalTarget->distance(entity); + if (entity->runtimeID() == manager.avatar()->runtimeID()) + continue; + if (entity->runtimeID() == targetID) continue; if (distance > rapidFire.f_MultiTargetRadius) continue; + if (!IsValidByFilter(entity)) + continue; + validEntities.push_back(entity); } }