Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- @Mod.EventBusSubscriber(modid = Charms.CHARMS, bus = Mod.EventBusSubscriber.Bus.FORGE)
- public class CharmContainer extends Container {
- public final PlayerEntity playerIn;
- public final CharmContainerTE tileEntity;
- private final IWorldPosCallable canInteractWithCallable;
- public CharmContainer(final int windowId, final PlayerInventory playerInventory, PlayerEntity playerIn,
- final CharmContainerTE tileEntity) {
- super(ModContainerTypes.CHARM_CONTAINER.get(), windowId);
- this.playerIn = playerIn;
- this.tileEntity = tileEntity;
- this.canInteractWithCallable = IWorldPosCallable.of(tileEntity.getWorld(), tileEntity.getPos());
- // Main Inventory
- int startX = 8;
- int startY = 18;
- int slotSizePlus2 = 18;
- for (int row = 0; row < 4; ++row) {
- for (int column = 0; column < 9; ++column) {
- this.addSlot(new Slot(tileEntity, (row * 9) + column, startX + (column * slotSizePlus2),
- startY + (row * slotSizePlus2)));
- }
- }
- // Main Player Inventory
- int startPlayerInvY = startY * 5 + 12;
- for (int row = 0; row < 3; ++row) {
- for (int column = 0; column < 9; ++column) {
- this.addSlot(new Slot(playerInventory, 9 + (row * 9) + column, startX + (column * slotSizePlus2),
- startPlayerInvY + (row * slotSizePlus2)));
- }
- }
- // Hotbar
- int hotbarY = startPlayerInvY + (startPlayerInvY / 2) + 7;
- for (int column = 0; column < 9; ++column) {
- this.addSlot(new Slot(playerInventory, column, startX + (column * slotSizePlus2), hotbarY));
- }
- }
- private static CharmContainerTE getTileEntity(final PlayerInventory playerInventory,
- final PacketBuffer data) {
- Objects.requireNonNull(playerInventory, "playerInventory cannot be null");
- Objects.requireNonNull(data, "data cannot be null");
- final TileEntity tileAtPos = playerInventory.player.world.getTileEntity(data.readBlockPos());
- if (tileAtPos instanceof CharmContainerTE) {
- return (CharmContainerTE) tileAtPos;
- }
- throw new IllegalStateException("Tile entity is not correct! " + tileAtPos);
- }
- public CharmContainer(final int windowId, final PlayerInventory playerInventory, PlayerEntity playerIn, PacketBuffer data) {
- this(windowId, playerInventory, playerIn, getTileEntity(playerInventory, data));
- }
- @Override
- public void detectAndSendChanges() {
- if (this.tileEntity.getStackInSlot(1).getItem() == ItemList.haste_charm) {
- playerIn.addPotionEffect(new EffectInstance(Effects.HASTE, 10));
- }
- super.detectAndSendChanges();
- }
- @Override
- public boolean canInteractWith(PlayerEntity playerIn) {
- return isWithinUsableDistance(canInteractWithCallable, playerIn, BlockList.charm_container);
- }
- @Override
- public ItemStack transferStackInSlot(PlayerEntity playerIn, int index) {
- ItemStack itemstack = ItemStack.EMPTY;
- Slot slot = this.inventorySlots.get(index);
- if (slot != null && slot.getHasStack()) {
- ItemStack itemstack1 = slot.getStack();
- itemstack = itemstack1.copy();
- if (index < 36) {
- if (!this.mergeItemStack(itemstack1, 36, this.inventorySlots.size(), true)) {
- return ItemStack.EMPTY;
- }
- } else if (!this.mergeItemStack(itemstack1, 0, 36, false)) {
- return ItemStack.EMPTY;
- }
- if (itemstack1.isEmpty()) {
- slot.putStack(ItemStack.EMPTY);
- } else {
- slot.onSlotChanged();
- }
- }
- return itemstack;
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement