mirror of
https://github.com/songoda/UltimateStacker.git
synced 2024-11-23 10:35:22 +01:00
spawner fix
This commit is contained in:
parent
93a64e0362
commit
c827354d9e
@ -3,13 +3,9 @@ package com.songoda.ultimatestacker.spawner;
|
|||||||
import com.songoda.ultimatestacker.UltimateStacker;
|
import com.songoda.ultimatestacker.UltimateStacker;
|
||||||
import com.songoda.ultimatestacker.utils.Reflection;
|
import com.songoda.ultimatestacker.utils.Reflection;
|
||||||
import com.songoda.ultimatestacker.utils.ServerVersion;
|
import com.songoda.ultimatestacker.utils.ServerVersion;
|
||||||
import org.bukkit.Bukkit;
|
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
import org.bukkit.block.CreatureSpawner;
|
import org.bukkit.block.CreatureSpawner;
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
|
||||||
import java.lang.reflect.Method;
|
|
||||||
|
|
||||||
public class SpawnerStack {
|
public class SpawnerStack {
|
||||||
|
|
||||||
private final Location location;
|
private final Location location;
|
||||||
@ -31,8 +27,15 @@ public class SpawnerStack {
|
|||||||
public void setAmount(int amount) {
|
public void setAmount(int amount) {
|
||||||
this.amount = amount;
|
this.amount = amount;
|
||||||
|
|
||||||
|
int count = 4 * amount;
|
||||||
|
int maxNearby = amount > 6 ? amount + 3 : 6;
|
||||||
CreatureSpawner creatureSpawner = (CreatureSpawner)location.getBlock().getState();
|
CreatureSpawner creatureSpawner = (CreatureSpawner)location.getBlock().getState();
|
||||||
Reflection.setRange(creatureSpawner, 4 * amount, amount > 6 ? amount + 3 : 6);
|
if (UltimateStacker.getInstance().isServerVersionAtLeast(ServerVersion.V1_12)) {
|
||||||
|
creatureSpawner.setMaxNearbyEntities(maxNearby);
|
||||||
|
creatureSpawner.setSpawnCount(count);
|
||||||
|
} else {
|
||||||
|
Reflection.updateSpawner(creatureSpawner, count, maxNearby);
|
||||||
|
}
|
||||||
creatureSpawner.update();
|
creatureSpawner.update();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9,9 +9,9 @@ import java.lang.reflect.Method;
|
|||||||
public class Reflection {
|
public class Reflection {
|
||||||
private static Class<?> clazzCraftCreatureSpawner, clazzTileEntityMobSpawner = null;
|
private static Class<?> clazzCraftCreatureSpawner, clazzTileEntityMobSpawner = null;
|
||||||
private static Method methodGetTileEntity, methodGetSpawner;
|
private static Method methodGetTileEntity, methodGetSpawner;
|
||||||
private static Field fieldSpawnRange, fieldMaxNearbyEntities;
|
private static Field fieldSpawnount, fieldMaxNearbyEntities;
|
||||||
|
|
||||||
public static CreatureSpawner setRange(CreatureSpawner creatureSpawner, int amount, int max) {
|
public static CreatureSpawner updateSpawner(CreatureSpawner creatureSpawner, int count, int max) {
|
||||||
try {
|
try {
|
||||||
if (creatureSpawner == null) return creatureSpawner;
|
if (creatureSpawner == null) return creatureSpawner;
|
||||||
if (clazzCraftCreatureSpawner == null) {
|
if (clazzCraftCreatureSpawner == null) {
|
||||||
@ -21,16 +21,16 @@ public class Reflection {
|
|||||||
Class<?> clazzMobSpawnerAbstract = Class.forName("net.minecraft.server." + ver + ".MobSpawnerAbstract");
|
Class<?> clazzMobSpawnerAbstract = Class.forName("net.minecraft.server." + ver + ".MobSpawnerAbstract");
|
||||||
methodGetTileEntity = clazzCraftCreatureSpawner.getDeclaredMethod("getTileEntity");
|
methodGetTileEntity = clazzCraftCreatureSpawner.getDeclaredMethod("getTileEntity");
|
||||||
methodGetSpawner = clazzTileEntityMobSpawner.getDeclaredMethod("getSpawner");
|
methodGetSpawner = clazzTileEntityMobSpawner.getDeclaredMethod("getSpawner");
|
||||||
fieldSpawnRange = clazzMobSpawnerAbstract.getDeclaredField("spawnRange");
|
fieldSpawnount = clazzMobSpawnerAbstract.getDeclaredField("spawnRange");
|
||||||
fieldSpawnRange.setAccessible(true);
|
fieldSpawnount.setAccessible(true);
|
||||||
fieldMaxNearbyEntities = clazzMobSpawnerAbstract.getDeclaredField("maxNearbyEntities");
|
fieldMaxNearbyEntities = clazzMobSpawnerAbstract.getDeclaredField("spawnCount");
|
||||||
fieldSpawnRange.setAccessible(true);
|
fieldSpawnount.setAccessible(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
Object objCraftCreatureSpawner = clazzCraftCreatureSpawner.cast(creatureSpawner);
|
Object objCraftCreatureSpawner = clazzCraftCreatureSpawner.cast(creatureSpawner);
|
||||||
Object objTileEntityMobSpawner = clazzTileEntityMobSpawner.cast(methodGetTileEntity.invoke(objCraftCreatureSpawner));
|
Object objTileEntityMobSpawner = clazzTileEntityMobSpawner.cast(methodGetTileEntity.invoke(objCraftCreatureSpawner));
|
||||||
Object objMobSpawnerAbstract = methodGetSpawner.invoke(objTileEntityMobSpawner);
|
Object objMobSpawnerAbstract = methodGetSpawner.invoke(objTileEntityMobSpawner);
|
||||||
fieldSpawnRange.set(objMobSpawnerAbstract, amount);
|
fieldSpawnount.set(objMobSpawnerAbstract, count);
|
||||||
fieldMaxNearbyEntities.set(objMobSpawnerAbstract, max);
|
fieldMaxNearbyEntities.set(objMobSpawnerAbstract, max);
|
||||||
|
|
||||||
} catch (ReflectiveOperationException e) {
|
} catch (ReflectiveOperationException e) {
|
||||||
|
Loading…
Reference in New Issue
Block a user