Merge pull request #203

Updated Aiming (added configurable targets)
This commit is contained in:
Will FP 2022-04-21 14:10:52 +01:00 committed by GitHub
commit f00ed90b76
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 28 additions and 1 deletions

View File

@ -1,5 +1,7 @@
package com.willfp.ecoenchants.enchantments.ecoenchants.special;
import com.willfp.eco.core.entities.Entities;
import com.willfp.eco.core.entities.TestableEntity;
import com.willfp.eco.core.integrations.antigrief.AntigriefManager;
import com.willfp.ecoenchants.enchantments.EcoEnchant;
import com.willfp.ecoenchants.enchantments.EcoEnchants;
@ -15,16 +17,23 @@ import org.bukkit.event.entity.ProjectileLaunchEvent;
import org.bukkit.util.Vector;
import org.jetbrains.annotations.NotNull;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.concurrent.atomic.AtomicInteger;
@SuppressWarnings({"unchecked", "unused"})
public class Aiming extends EcoEnchant {
private final List<TestableEntity> targets = new ArrayList<>();
public Aiming() {
super(
"aiming", EnchantmentType.SPECIAL
);
targets.clear();
targets.addAll(this.getConfig().getStrings(EcoEnchants.CONFIG_LOCATION + "targets").stream().map(
Entities::lookup
).toList());
}
@EventHandler
@ -74,6 +83,7 @@ public class Aiming extends EcoEnchant {
Runnable runnable = this.getPlugin().getRunnableFactory().create(bukkitRunnable -> {
List<LivingEntity> nearbyEntities = (List<LivingEntity>) (List<?>) Arrays.asList(arrow.getNearbyEntities(finalDistance, finalDistance, finalDistance).stream()
.filter(entity -> entity instanceof LivingEntity)
.filter(entity -> this.targets.stream().anyMatch(target -> target.matches(entity)))
.map(entity -> (LivingEntity) entity)
.filter(entity -> !entity.equals(player))
.filter(entity -> !(entity instanceof Enderman))

View File

@ -29,4 +29,21 @@ config:
scale-on-force: true # Scale distance based on bow pull
require-full-force: true # Require full bow pull (works with rapid) If true, then scale-on-force is irrelevant.
check-ticks: 10 # Ticks between rotations
checks-per-level: 2 # Amount of times to rotate arrow per level (prevents "floating")
checks-per-level: 2 # Amount of times to rotate arrow per level (prevents "floating")
targets: # List of entity lookups (https://plugins.auxilor.io/all-plugins/the-entity-lookup-system)
- "zombie"
- "creeper"
- "player"
- "skeleton"
- "spider"
- "wither"
- "ender_dragon"
- "wither_skeleton"
- "husk"
- "piglin"
- "hoglin"
- "pig"
- "chicken"
- "cow"
- "cave_spider"
- "horse"