ActuallyAdditions/src/main/java/de/ellpeck/actuallyadditions/mod/tile/TileEntityRangedCollector.java

129 lines
4.8 KiB
Java
Raw Normal View History

2015-10-10 02:51:06 +02:00
/*
2016-05-16 22:52:27 +02:00
* This file ("TileEntityRangedCollector.java") is part of the Actually Additions mod for Minecraft.
2015-10-10 02:51:06 +02:00
* It is created and owned by Ellpeck and distributed
* under the Actually Additions License to be found at
2016-05-16 22:52:27 +02:00
* http://ellpeck.de/actaddlicense
2015-10-10 02:51:06 +02:00
* View the source code at https://github.com/Ellpeck/ActuallyAdditions
*
2017-01-01 16:23:26 +01:00
* © 2015-2017 Ellpeck
2015-10-10 02:51:06 +02:00
*/
2016-01-05 04:47:35 +01:00
package de.ellpeck.actuallyadditions.mod.tile;
2015-10-10 02:51:06 +02:00
2021-11-13 18:02:42 +01:00
import de.ellpeck.actuallyadditions.mod.blocks.ActuallyBlocks;
import de.ellpeck.actuallyadditions.mod.inventory.ContainerRangedCollector;
2016-01-05 04:47:35 +01:00
import de.ellpeck.actuallyadditions.mod.network.gui.IButtonReactor;
2018-08-10 05:04:07 +02:00
import de.ellpeck.actuallyadditions.mod.util.ItemStackHandlerAA.IAcceptor;
import de.ellpeck.actuallyadditions.mod.util.StackUtil;
2024-03-02 21:23:08 +01:00
import net.minecraft.core.BlockPos;
import net.minecraft.core.particles.ParticleTypes;
import net.minecraft.nbt.CompoundTag;
import net.minecraft.network.chat.Component;
import net.minecraft.server.level.ServerLevel;
import net.minecraft.world.MenuProvider;
import net.minecraft.world.entity.item.ItemEntity;
import net.minecraft.world.entity.player.Inventory;
import net.minecraft.world.entity.player.Player;
import net.minecraft.world.inventory.AbstractContainerMenu;
import net.minecraft.world.item.ItemStack;
import net.minecraft.world.level.Level;
import net.minecraft.world.level.block.entity.BlockEntity;
import net.minecraft.world.level.block.state.BlockState;
import net.minecraft.world.phys.AABB;
2015-10-10 02:51:06 +02:00
2024-03-10 23:10:39 +01:00
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
2021-02-26 22:15:48 +01:00
import java.util.ArrayList;
import java.util.List;
2024-03-02 21:23:08 +01:00
public class TileEntityRangedCollector extends TileEntityInventoryBase implements IButtonReactor, MenuProvider {
2015-10-10 02:51:06 +02:00
2015-12-01 19:48:09 +01:00
public static final int RANGE = 6;
2024-03-05 23:23:49 +01:00
public FilterSettings filter = new FilterSettings(12, true, false);
2015-10-10 02:51:06 +02:00
2024-03-02 21:23:08 +01:00
public TileEntityRangedCollector(BlockPos pos, BlockState state) {
super(ActuallyBlocks.RANGED_COLLECTOR.getTileEntityType(), pos, state, 6);
2015-10-10 02:51:06 +02:00
}
2016-02-01 17:49:55 +01:00
@Override
2024-03-02 21:23:08 +01:00
public void writeSyncableNBT(CompoundTag compound, NBTType type) {
super.writeSyncableNBT(compound, type);
this.filter.writeToNBT(compound, "Filter");
2016-02-01 17:49:55 +01:00
}
@Override
2024-03-02 21:23:08 +01:00
public void readSyncableNBT(CompoundTag compound, NBTType type) {
super.readSyncableNBT(compound, type);
this.filter.readFromNBT(compound, "Filter");
2016-02-01 17:49:55 +01:00
}
2015-10-10 02:51:06 +02:00
@Override
public boolean isRedstoneToggle() {
return true;
}
@Override
public void activateOnPulse() {
2024-03-02 21:23:08 +01:00
List<ItemEntity> items = this.level.getEntitiesOfClass(ItemEntity.class, new AABB(this.worldPosition.getX() - RANGE, this.worldPosition.getY() - RANGE, this.worldPosition.getZ() - RANGE, this.worldPosition.getX() + RANGE, this.worldPosition.getY() + RANGE, this.worldPosition.getZ() + RANGE));
if (!items.isEmpty()) {
2021-02-27 16:33:00 +01:00
for (ItemEntity item : items) {
2023-03-16 00:17:57 +01:00
if (item.isAlive() && !item.hasPickUpDelay() && !item.getItem().isEmpty()) {
ItemStack toAdd = item.getItem().copy();
if (this.filter.check(toAdd)) {
2019-02-27 19:53:05 +01:00
ArrayList<ItemStack> checkList = new ArrayList<>();
checkList.add(toAdd);
2019-02-27 19:53:05 +01:00
if (StackUtil.canAddAll(this.inv, checkList, false)) {
StackUtil.addAll(this.inv, checkList, false);
2024-03-02 21:23:08 +01:00
((ServerLevel) this.level).sendParticles(ParticleTypes.CLOUD, item.getX(), item.getY() + 0.45F, item.getZ(), 5, 0, 0, 0, 0.03D);
item.discard();
2015-10-10 02:51:06 +02:00
}
}
}
}
}
}
2024-03-02 21:23:08 +01:00
public static <T extends BlockEntity> void clientTick(Level level, BlockPos pos, BlockState state, T t) {
if (t instanceof TileEntityRangedCollector tile) {
tile.clientTick();
}
}
public static <T extends BlockEntity> void serverTick(Level level, BlockPos pos, BlockState state, T t) {
if (t instanceof TileEntityRangedCollector tile) {
tile.serverTick();
if (!tile.isRedstonePowered && !tile.isPulseMode) {
tile.activateOnPulse();
}
2015-10-10 02:51:06 +02:00
2024-03-02 21:23:08 +01:00
if (tile.filter.needsUpdateSend() && tile.sendUpdateWithInterval()) {
tile.filter.updateLasts();
2015-10-10 02:51:06 +02:00
}
}
}
@Override
2018-08-10 05:04:07 +02:00
public IAcceptor getAcceptor() {
return (slot, stack, automation) -> !automation;
2015-10-10 02:51:06 +02:00
}
@Override
2024-03-02 21:23:08 +01:00
public void onButtonPressed(int buttonID, Player player) {
2024-03-10 23:10:39 +01:00
this.filter.onButtonPressed(buttonID);
}
@Override
2024-03-02 21:23:08 +01:00
public Component getDisplayName() {
2024-03-10 23:10:39 +01:00
return Component.translatable("container.actuallyadditions.rangedCollector");
}
@Nullable
@Override
2024-03-10 23:10:39 +01:00
public AbstractContainerMenu createMenu(int windowId, @Nonnull Inventory playerInventory, @Nonnull Player player) {
return new ContainerRangedCollector(windowId, playerInventory, this);
}
2015-10-10 02:51:06 +02:00
}