2018-10-14 14:27:18 +02:00
|
|
|
package de.ellpeck.naturesaura;
|
|
|
|
|
2020-01-21 21:04:44 +01:00
|
|
|
import com.mojang.blaze3d.platform.GlStateManager;
|
2020-01-28 18:08:56 +01:00
|
|
|
import com.mojang.blaze3d.systems.RenderSystem;
|
2018-11-12 22:04:40 +01:00
|
|
|
import de.ellpeck.naturesaura.api.NaturesAuraAPI;
|
2020-01-25 19:18:45 +01:00
|
|
|
import de.ellpeck.naturesaura.api.aura.container.IAuraContainer;
|
2018-11-11 13:26:19 +01:00
|
|
|
import de.ellpeck.naturesaura.api.aura.item.IAuraRecharge;
|
2018-10-18 13:34:37 +02:00
|
|
|
import de.ellpeck.naturesaura.blocks.tiles.TileEntityImpl;
|
2019-02-09 21:55:40 +01:00
|
|
|
import de.ellpeck.naturesaura.chunk.AuraChunk;
|
2020-01-26 19:26:50 +01:00
|
|
|
import de.ellpeck.naturesaura.compat.Compat;
|
2020-01-23 22:40:03 +01:00
|
|
|
import net.minecraft.advancements.Advancement;
|
2018-11-12 00:32:35 +01:00
|
|
|
import net.minecraft.block.Block;
|
2019-10-20 22:30:49 +02:00
|
|
|
import net.minecraft.block.BlockState;
|
2018-10-16 11:49:30 +02:00
|
|
|
import net.minecraft.client.Minecraft;
|
|
|
|
import net.minecraft.client.renderer.RenderHelper;
|
2019-10-20 22:30:49 +02:00
|
|
|
import net.minecraft.entity.item.ItemEntity;
|
|
|
|
import net.minecraft.entity.item.ItemFrameEntity;
|
|
|
|
import net.minecraft.entity.player.PlayerEntity;
|
|
|
|
import net.minecraft.entity.player.ServerPlayerEntity;
|
2019-01-27 13:57:34 +01:00
|
|
|
import net.minecraft.item.Item;
|
2018-10-16 01:36:30 +02:00
|
|
|
import net.minecraft.item.ItemStack;
|
2018-11-20 11:44:07 +01:00
|
|
|
import net.minecraft.item.crafting.Ingredient;
|
2020-01-21 21:04:44 +01:00
|
|
|
import net.minecraft.nbt.INBT;
|
|
|
|
import net.minecraft.state.IProperty;
|
2018-10-14 14:27:18 +02:00
|
|
|
import net.minecraft.tileentity.TileEntity;
|
2020-01-21 21:04:44 +01:00
|
|
|
import net.minecraft.util.*;
|
2018-11-05 16:36:10 +01:00
|
|
|
import net.minecraft.util.math.AxisAlignedBB;
|
2018-10-14 14:27:18 +02:00
|
|
|
import net.minecraft.util.math.BlockPos;
|
2020-01-23 02:20:02 +01:00
|
|
|
import net.minecraft.util.math.ChunkPos;
|
2019-02-21 12:27:54 +01:00
|
|
|
import net.minecraft.util.math.Vec3d;
|
2020-01-21 21:04:44 +01:00
|
|
|
import net.minecraft.world.IWorld;
|
2018-10-14 14:27:18 +02:00
|
|
|
import net.minecraft.world.World;
|
2020-01-23 02:20:02 +01:00
|
|
|
import net.minecraft.world.chunk.AbstractChunkProvider;
|
2020-01-21 21:04:44 +01:00
|
|
|
import net.minecraft.world.chunk.Chunk;
|
|
|
|
import net.minecraftforge.api.distmarker.Dist;
|
|
|
|
import net.minecraftforge.api.distmarker.OnlyIn;
|
2018-10-20 21:19:08 +02:00
|
|
|
import net.minecraftforge.common.capabilities.Capability;
|
2018-11-12 22:04:40 +01:00
|
|
|
import net.minecraftforge.common.capabilities.CapabilityManager;
|
2018-10-20 21:19:08 +02:00
|
|
|
import net.minecraftforge.common.capabilities.ICapabilityProvider;
|
2020-01-21 21:04:44 +01:00
|
|
|
import net.minecraftforge.common.util.LazyOptional;
|
2019-02-17 22:51:05 +01:00
|
|
|
import net.minecraftforge.items.IItemHandler;
|
2018-10-18 13:34:37 +02:00
|
|
|
import net.minecraftforge.items.IItemHandlerModifiable;
|
2020-01-21 21:04:44 +01:00
|
|
|
import net.minecraftforge.registries.ForgeRegistries;
|
2020-01-22 01:32:26 +01:00
|
|
|
import net.minecraftforge.registries.IForgeRegistry;
|
|
|
|
import net.minecraftforge.registries.IForgeRegistryEntry;
|
2020-01-26 19:26:50 +01:00
|
|
|
import org.apache.commons.lang3.tuple.ImmutableTriple;
|
2018-10-18 18:00:21 +02:00
|
|
|
import org.lwjgl.opengl.GL11;
|
2020-01-26 19:26:50 +01:00
|
|
|
import top.theillusivec4.curios.api.CuriosAPI;
|
2018-10-14 14:27:18 +02:00
|
|
|
|
2018-10-20 21:19:08 +02:00
|
|
|
import javax.annotation.Nonnull;
|
|
|
|
import javax.annotation.Nullable;
|
2020-01-22 01:32:26 +01:00
|
|
|
import java.lang.reflect.Field;
|
|
|
|
import java.lang.reflect.Modifier;
|
2018-10-14 14:27:18 +02:00
|
|
|
import java.util.List;
|
2020-01-22 01:32:26 +01:00
|
|
|
import java.util.Locale;
|
2020-01-26 19:26:50 +01:00
|
|
|
import java.util.Optional;
|
2019-02-09 21:55:40 +01:00
|
|
|
import java.util.function.Consumer;
|
2018-11-14 19:14:03 +01:00
|
|
|
import java.util.function.Function;
|
2020-01-26 19:26:50 +01:00
|
|
|
import java.util.function.Predicate;
|
2018-10-14 14:27:18 +02:00
|
|
|
|
|
|
|
public final class Helper {
|
|
|
|
|
2020-01-21 21:04:44 +01:00
|
|
|
public static boolean getTileEntitiesInArea(IWorld world, BlockPos pos, int radius, Function<TileEntity, Boolean> consumer) {
|
2020-01-29 18:18:41 +01:00
|
|
|
for (int x = pos.getX() - radius >> 4; x <= pos.getX() + radius >> 4; x++) {
|
|
|
|
for (int z = pos.getZ() - radius >> 4; z <= pos.getZ() + radius >> 4; z++) {
|
2020-01-23 02:01:05 +01:00
|
|
|
Chunk chunk = getLoadedChunk(world, x, z);
|
2020-01-22 16:03:39 +01:00
|
|
|
if (chunk != null) {
|
|
|
|
for (BlockPos tilePos : chunk.getTileEntitiesPos()) {
|
2020-01-21 21:04:44 +01:00
|
|
|
if (tilePos.distanceSq(pos) <= radius * radius)
|
2020-01-24 20:49:09 +01:00
|
|
|
if (consumer.apply(chunk.getTileEntity(tilePos)))
|
2018-11-14 19:14:03 +01:00
|
|
|
return true;
|
2018-10-14 14:27:18 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2018-11-14 19:14:03 +01:00
|
|
|
return false;
|
2018-10-14 14:27:18 +02:00
|
|
|
}
|
|
|
|
|
2019-02-09 21:55:40 +01:00
|
|
|
public static void getAuraChunksInArea(World world, BlockPos pos, int radius, Consumer<AuraChunk> consumer) {
|
2020-01-29 18:18:41 +01:00
|
|
|
for (int x = pos.getX() - radius >> 4; x <= pos.getX() + radius >> 4; x++) {
|
|
|
|
for (int z = pos.getZ() - radius >> 4; z <= pos.getZ() + radius >> 4; z++) {
|
2020-01-23 02:01:05 +01:00
|
|
|
Chunk chunk = getLoadedChunk(world, x, z);
|
2020-01-22 16:03:39 +01:00
|
|
|
if (chunk != null) {
|
2020-01-21 21:04:44 +01:00
|
|
|
AuraChunk auraChunk = (AuraChunk) chunk.getCapability(NaturesAuraAPI.capAuraChunk, null).orElse(null);
|
|
|
|
if (auraChunk != null)
|
2019-02-09 21:55:40 +01:00
|
|
|
consumer.accept(auraChunk);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-10-20 22:30:49 +02:00
|
|
|
public static List<ItemFrameEntity> getAttachedItemFrames(World world, BlockPos pos) {
|
|
|
|
List<ItemFrameEntity> frames = world.getEntitiesWithinAABB(ItemFrameEntity.class, new AxisAlignedBB(pos).grow(0.25));
|
2018-11-05 16:36:10 +01:00
|
|
|
for (int i = frames.size() - 1; i >= 0; i--) {
|
2019-10-20 22:30:49 +02:00
|
|
|
ItemFrameEntity frame = frames.get(i);
|
2020-01-22 23:21:52 +01:00
|
|
|
BlockPos framePos = frame.getHangingPosition().offset(frame.getHorizontalFacing().getOpposite());
|
2018-11-05 16:36:10 +01:00
|
|
|
if (!pos.equals(framePos))
|
|
|
|
frames.remove(i);
|
|
|
|
}
|
|
|
|
return frames;
|
|
|
|
}
|
|
|
|
|
2020-01-23 02:01:05 +01:00
|
|
|
public static Chunk getLoadedChunk(IWorld world, int x, int z) {
|
2020-01-23 02:20:02 +01:00
|
|
|
// DO NOT EDIT PLEASE FOR THE LOVE OF GOD
|
|
|
|
// This is very finicky and easily causes the game to hang for some reason
|
|
|
|
AbstractChunkProvider provider = world.getChunkProvider();
|
|
|
|
if (provider.isChunkLoaded(new ChunkPos(x, z)))
|
|
|
|
return provider.getChunk(x, z, false);
|
|
|
|
return null;
|
2018-10-30 18:18:56 +01:00
|
|
|
}
|
|
|
|
|
2018-10-15 18:36:46 +02:00
|
|
|
public static int blendColors(int c1, int c2, float ratio) {
|
|
|
|
int a = (int) ((c1 >> 24 & 0xFF) * ratio + (c2 >> 24 & 0xFF) * (1 - ratio));
|
|
|
|
int r = (int) ((c1 >> 16 & 0xFF) * ratio + (c2 >> 16 & 0xFF) * (1 - ratio));
|
|
|
|
int g = (int) ((c1 >> 8 & 0xFF) * ratio + (c2 >> 8 & 0xFF) * (1 - ratio));
|
|
|
|
int b = (int) ((c1 & 0xFF) * ratio + (c2 & 0xFF) * (1 - ratio));
|
2020-01-29 18:18:41 +01:00
|
|
|
return (a & 255) << 24 | (r & 255) << 16 | (g & 255) << 8 | b & 255;
|
2018-10-15 18:36:46 +02:00
|
|
|
}
|
2018-10-16 01:36:30 +02:00
|
|
|
|
2018-11-08 18:03:58 +01:00
|
|
|
public static boolean areItemsEqual(ItemStack first, ItemStack second, boolean nbt) {
|
|
|
|
if (!ItemStack.areItemsEqual(first, second))
|
|
|
|
return false;
|
2020-01-21 21:04:44 +01:00
|
|
|
return !nbt || ItemStack.areItemStackTagsEqual(first, second);
|
2018-11-08 18:03:58 +01:00
|
|
|
}
|
|
|
|
|
2019-10-20 22:30:49 +02:00
|
|
|
@OnlyIn(Dist.CLIENT)
|
2018-10-18 18:00:21 +02:00
|
|
|
public static void renderItemInGui(ItemStack stack, int x, int y, float scale) {
|
2020-01-28 18:08:56 +01:00
|
|
|
RenderSystem.pushMatrix();
|
2018-10-18 18:00:21 +02:00
|
|
|
GlStateManager.enableBlend();
|
|
|
|
GlStateManager.blendFunc(GL11.GL_SRC_ALPHA, GL11.GL_ONE_MINUS_SRC_ALPHA);
|
2020-01-28 18:08:56 +01:00
|
|
|
RenderHelper.setupGuiFlatDiffuseLighting();
|
2020-01-21 21:04:44 +01:00
|
|
|
GlStateManager.enableDepthTest();
|
2020-01-28 18:08:56 +01:00
|
|
|
RenderSystem.enableRescaleNormal();
|
|
|
|
RenderSystem.translatef(x, y, 0);
|
|
|
|
RenderSystem.scalef(scale, scale, scale);
|
2020-01-21 21:04:44 +01:00
|
|
|
Minecraft.getInstance().getItemRenderer().renderItemAndEffectIntoGUI(stack, 0, 0);
|
|
|
|
Minecraft.getInstance().getItemRenderer().renderItemOverlayIntoGUI(Minecraft.getInstance().fontRenderer, stack, 0, 0, null);
|
2018-10-18 18:00:21 +02:00
|
|
|
RenderHelper.disableStandardItemLighting();
|
2020-01-28 18:08:56 +01:00
|
|
|
RenderSystem.popMatrix();
|
2018-10-18 18:00:21 +02:00
|
|
|
}
|
|
|
|
|
2020-01-28 18:08:56 +01:00
|
|
|
public static ActionResultType putStackOnTile(PlayerEntity player, Hand hand, BlockPos pos, int slot, boolean sound) {
|
2018-10-18 13:34:37 +02:00
|
|
|
TileEntity tile = player.world.getTileEntity(pos);
|
|
|
|
if (tile instanceof TileEntityImpl) {
|
|
|
|
IItemHandlerModifiable handler = ((TileEntityImpl) tile).getItemHandler(null);
|
|
|
|
if (handler != null) {
|
|
|
|
ItemStack handStack = player.getHeldItem(hand);
|
|
|
|
if (!handStack.isEmpty()) {
|
|
|
|
ItemStack remain = handler.insertItem(slot, handStack, player.world.isRemote);
|
|
|
|
if (!ItemStack.areItemStacksEqual(remain, handStack)) {
|
2018-10-24 12:42:04 +02:00
|
|
|
if (sound)
|
|
|
|
player.world.playSound(player, pos.getX() + 0.5, pos.getY() + 0.5, pos.getZ() + 0.5,
|
2020-01-21 21:04:44 +01:00
|
|
|
SoundEvents.ENTITY_ITEM_FRAME_ADD_ITEM, SoundCategory.PLAYERS, 0.75F, 1F);
|
2018-10-24 12:42:04 +02:00
|
|
|
if (!player.world.isRemote)
|
2018-10-18 13:34:37 +02:00
|
|
|
player.setHeldItem(hand, remain);
|
2020-01-28 18:08:56 +01:00
|
|
|
return ActionResultType.SUCCESS;
|
2018-10-18 13:34:37 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!handler.getStackInSlot(slot).isEmpty()) {
|
2018-10-24 12:42:04 +02:00
|
|
|
if (sound)
|
|
|
|
player.world.playSound(player, pos.getX() + 0.5, pos.getY() + 0.5, pos.getZ() + 0.5,
|
2020-01-21 21:04:44 +01:00
|
|
|
SoundEvents.ENTITY_ITEM_FRAME_REMOVE_ITEM, SoundCategory.PLAYERS, 0.75F, 1F);
|
2018-10-18 13:34:37 +02:00
|
|
|
if (!player.world.isRemote) {
|
2019-01-18 12:29:18 +01:00
|
|
|
ItemStack stack = handler.getStackInSlot(slot);
|
|
|
|
if (!player.addItemStackToInventory(stack)) {
|
2020-01-28 18:08:56 +01:00
|
|
|
ItemEntity item = new ItemEntity(player.world, player.getPosX(), player.getPosY(), player.getPosZ(), stack);
|
2020-01-21 21:04:44 +01:00
|
|
|
player.world.addEntity(item);
|
2019-01-18 12:29:18 +01:00
|
|
|
}
|
2018-10-18 13:34:37 +02:00
|
|
|
handler.setStackInSlot(slot, ItemStack.EMPTY);
|
|
|
|
}
|
2020-01-28 18:08:56 +01:00
|
|
|
return ActionResultType.SUCCESS;
|
2018-10-18 13:34:37 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-01-28 18:08:56 +01:00
|
|
|
return ActionResultType.FAIL;
|
2018-10-18 13:34:37 +02:00
|
|
|
}
|
2018-10-20 21:19:08 +02:00
|
|
|
|
2018-12-01 18:56:05 +01:00
|
|
|
public static ICapabilityProvider makeRechargeProvider(ItemStack stack, boolean needsSelected) {
|
2018-10-20 21:19:08 +02:00
|
|
|
return new ICapabilityProvider() {
|
2018-12-01 18:56:05 +01:00
|
|
|
private final IAuraRecharge recharge = (container, containerSlot, itemSlot, isSelected) -> {
|
|
|
|
if (isSelected || !needsSelected) {
|
2020-01-25 19:18:45 +01:00
|
|
|
return rechargeAuraItem(stack, container, 300);
|
2018-10-20 21:19:08 +02:00
|
|
|
}
|
2018-12-01 18:56:05 +01:00
|
|
|
return false;
|
2018-10-20 21:19:08 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
@Nullable
|
|
|
|
@Override
|
2020-01-21 21:04:44 +01:00
|
|
|
public <T> LazyOptional<T> getCapability(@Nonnull Capability<T> capability, @Nullable Direction facing) {
|
|
|
|
if (capability == NaturesAuraAPI.capAuraRecharge)
|
|
|
|
return LazyOptional.of(() -> (T) this.recharge);
|
|
|
|
return LazyOptional.empty();
|
2018-10-20 21:19:08 +02:00
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
2018-11-12 00:32:35 +01:00
|
|
|
|
2020-01-25 19:18:45 +01:00
|
|
|
public static boolean rechargeAuraItem(ItemStack stack, IAuraContainer container, int toDrain) {
|
|
|
|
if (stack.getDamage() > 0 && container.drainAura(toDrain, true) >= toDrain) {
|
|
|
|
stack.setDamage(stack.getDamage() - 1);
|
|
|
|
container.drainAura(toDrain, false);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2019-10-20 22:30:49 +02:00
|
|
|
public static BlockState getStateFromString(String raw) {
|
2018-11-12 00:32:35 +01:00
|
|
|
String[] split = raw.split("\\[");
|
2020-01-21 21:04:44 +01:00
|
|
|
Block block = ForgeRegistries.BLOCKS.getValue(new ResourceLocation(split[0]));
|
2018-11-12 00:32:35 +01:00
|
|
|
if (block != null) {
|
2019-10-20 22:30:49 +02:00
|
|
|
BlockState state = block.getDefaultState();
|
2018-11-12 00:32:35 +01:00
|
|
|
if (split.length > 1) {
|
|
|
|
for (String part : split[1].replace("]", "").split(",")) {
|
|
|
|
String[] keyValue = part.split("=");
|
2020-01-21 21:04:44 +01:00
|
|
|
for (IProperty<?> prop : state.getProperties()) {
|
2019-10-20 22:30:49 +02:00
|
|
|
BlockState changed = findProperty(state, prop, keyValue[0], keyValue[1]);
|
2018-11-12 00:32:35 +01:00
|
|
|
if (changed != null) {
|
|
|
|
state = changed;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return state;
|
|
|
|
} else
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2019-10-20 22:30:49 +02:00
|
|
|
private static <T extends Comparable<T>> BlockState findProperty(BlockState state, IProperty<T> prop, String key, String newValue) {
|
2018-11-12 00:32:35 +01:00
|
|
|
if (key.equals(prop.getName()))
|
|
|
|
for (T value : prop.getAllowedValues())
|
|
|
|
if (prop.getName(value).equals(newValue))
|
2020-01-21 21:04:44 +01:00
|
|
|
return state.with(prop, value);
|
2018-11-12 00:32:35 +01:00
|
|
|
return null;
|
|
|
|
}
|
2018-11-12 22:04:40 +01:00
|
|
|
|
|
|
|
public static <T> void registerCap(Class<T> type) {
|
|
|
|
CapabilityManager.INSTANCE.register(type, new Capability.IStorage<T>() {
|
|
|
|
@Override
|
2020-01-21 21:04:44 +01:00
|
|
|
public void readNBT(Capability<T> capability, T instance, Direction side, INBT nbt) {
|
|
|
|
|
2018-11-12 22:04:40 +01:00
|
|
|
}
|
|
|
|
|
2020-01-21 21:04:44 +01:00
|
|
|
@Nullable
|
2018-11-12 22:04:40 +01:00
|
|
|
@Override
|
2020-01-21 21:04:44 +01:00
|
|
|
public INBT writeNBT(Capability capability, Object instance, Direction side) {
|
|
|
|
return null;
|
2018-11-12 22:04:40 +01:00
|
|
|
}
|
|
|
|
}, () -> null);
|
|
|
|
}
|
2018-11-20 11:44:07 +01:00
|
|
|
|
2019-10-20 22:30:49 +02:00
|
|
|
public static void addAdvancement(PlayerEntity player, ResourceLocation advancement, String criterion) {
|
|
|
|
if (!(player instanceof ServerPlayerEntity))
|
2020-01-23 22:40:03 +01:00
|
|
|
return;
|
2019-10-20 22:30:49 +02:00
|
|
|
ServerPlayerEntity playerMp = (ServerPlayerEntity) player;
|
2020-01-23 22:40:03 +01:00
|
|
|
Advancement adv = playerMp.getServerWorld().getServer().getAdvancementManager().getAdvancement(advancement);
|
2018-12-20 21:43:19 +01:00
|
|
|
if (adv != null)
|
2020-01-23 22:40:03 +01:00
|
|
|
playerMp.getAdvancements().grantCriterion(adv, criterion);
|
2018-12-20 21:43:19 +01:00
|
|
|
}
|
2018-12-30 20:37:00 +01:00
|
|
|
|
|
|
|
public static int getIngredientAmount(Ingredient ingredient) {
|
|
|
|
int highestAmount = 0;
|
|
|
|
for (ItemStack stack : ingredient.getMatchingStacks())
|
|
|
|
if (stack.getCount() > highestAmount)
|
|
|
|
highestAmount = stack.getCount();
|
|
|
|
return highestAmount;
|
|
|
|
}
|
2019-01-27 13:57:34 +01:00
|
|
|
|
2019-10-20 22:30:49 +02:00
|
|
|
@OnlyIn(Dist.CLIENT)
|
2019-01-27 13:57:34 +01:00
|
|
|
public static void renderWeirdBox(double x, double y, double z, double width, double height, double depth) {
|
|
|
|
GL11.glVertex3d(x, y + height, z);
|
|
|
|
GL11.glVertex3d(x + width, y + height, z);
|
|
|
|
GL11.glVertex3d(x + width, y, z);
|
|
|
|
GL11.glVertex3d(x, y, z);
|
|
|
|
GL11.glVertex3d(x + width, y, z + depth);
|
|
|
|
GL11.glVertex3d(x + width, y, z);
|
|
|
|
GL11.glVertex3d(x + width, y + height, z);
|
|
|
|
GL11.glVertex3d(x + width, y + height, z + depth);
|
|
|
|
GL11.glVertex3d(x + width, y + height, z + depth);
|
|
|
|
GL11.glVertex3d(x, y + height, z + depth);
|
|
|
|
GL11.glVertex3d(x, y, z + depth);
|
|
|
|
GL11.glVertex3d(x + width, y, z + depth);
|
|
|
|
GL11.glVertex3d(x, y + height, z + depth);
|
|
|
|
GL11.glVertex3d(x, y + height, z);
|
|
|
|
GL11.glVertex3d(x, y, z);
|
|
|
|
GL11.glVertex3d(x, y, z + depth);
|
|
|
|
GL11.glVertex3d(x, y + height, z);
|
|
|
|
GL11.glVertex3d(x, y + height, z + depth);
|
|
|
|
GL11.glVertex3d(x + width, y + height, z + depth);
|
|
|
|
GL11.glVertex3d(x + width, y + height, z);
|
|
|
|
GL11.glVertex3d(x + width, y, z);
|
|
|
|
GL11.glVertex3d(x + width, y, z + depth);
|
|
|
|
GL11.glVertex3d(x, y, z + depth);
|
|
|
|
GL11.glVertex3d(x, y, z);
|
|
|
|
}
|
|
|
|
|
2019-10-20 22:30:49 +02:00
|
|
|
public static boolean isHoldingItem(PlayerEntity player, Item item) {
|
|
|
|
for (Hand hand : Hand.values()) {
|
2019-01-27 13:57:34 +01:00
|
|
|
ItemStack stack = player.getHeldItem(hand);
|
|
|
|
if (!stack.isEmpty() && stack.getItem() == item)
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
2019-02-17 22:51:05 +01:00
|
|
|
|
|
|
|
public static boolean isEmpty(IItemHandler handler) {
|
|
|
|
for (int i = 0; i < handler.getSlots(); i++)
|
|
|
|
if (!handler.getStackInSlot(i).isEmpty())
|
|
|
|
return false;
|
|
|
|
return true;
|
|
|
|
}
|
2019-02-21 12:27:54 +01:00
|
|
|
|
|
|
|
public static AxisAlignedBB aabb(Vec3d pos) {
|
|
|
|
return new AxisAlignedBB(pos.x, pos.y, pos.z, pos.x, pos.y, pos.z);
|
|
|
|
}
|
2020-01-22 16:03:39 +01:00
|
|
|
|
2020-01-22 01:32:26 +01:00
|
|
|
// This is how @ObjectHolder _SHOULD_ work...
|
|
|
|
public static <T extends IForgeRegistryEntry<T>> void populateObjectHolders(Class clazz, IForgeRegistry<T> registry) {
|
|
|
|
for (Field entry : clazz.getFields()) {
|
|
|
|
if (!Modifier.isStatic(entry.getModifiers()))
|
|
|
|
continue;
|
2020-01-23 19:20:47 +01:00
|
|
|
ResourceLocation location = new ResourceLocation(NaturesAura.MOD_ID, entry.getName().toLowerCase(Locale.ROOT));
|
|
|
|
if (!registry.containsKey(location)) {
|
|
|
|
NaturesAura.LOGGER.fatal("Couldn't find entry named " + location + " in registry " + registry.getRegistryName());
|
|
|
|
continue;
|
|
|
|
}
|
2020-01-22 01:32:26 +01:00
|
|
|
try {
|
2020-01-23 19:20:47 +01:00
|
|
|
entry.set(null, registry.getValue(location));
|
2020-01-22 01:32:26 +01:00
|
|
|
} catch (IllegalAccessException e) {
|
|
|
|
NaturesAura.LOGGER.error(e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-01-22 20:31:09 +01:00
|
|
|
|
2020-01-26 19:26:50 +01:00
|
|
|
public static ItemStack getEquippedItem(Predicate<ItemStack> predicate, PlayerEntity player) {
|
|
|
|
if (Compat.hasCompat("curios")) {
|
|
|
|
Optional<ItemStack> stack = CuriosAPI.getCurioEquipped(predicate, player).map(ImmutableTriple::getRight);
|
|
|
|
if (stack.isPresent())
|
|
|
|
return stack.get();
|
|
|
|
}
|
|
|
|
for (int i = 0; i < player.inventory.getSizeInventory(); i++) {
|
|
|
|
ItemStack slot = player.inventory.getStackInSlot(i);
|
|
|
|
if (!slot.isEmpty() && predicate.test(slot))
|
|
|
|
return slot;
|
|
|
|
}
|
|
|
|
return ItemStack.EMPTY;
|
|
|
|
}
|
2018-10-14 14:27:18 +02:00
|
|
|
}
|