fix: fix and introduce some storage monitor bugs

This commit is contained in:
LordMZTE 2022-12-12 21:23:30 +01:00
parent b8e0e5fca2
commit e3abf47a96
Signed by: LordMZTE
GPG key ID: B64802DC33A64FF6
4 changed files with 120 additions and 6 deletions

View file

@ -1,6 +1,6 @@
- we demultiblocked the transition plane - we demultiblocked the transition plane
- transition plane doesn't collect items - transition plane doesn't collect items
- legacy controller doesn't correctly render energy bar
- legacy blocks aren't colorable - legacy blocks aren't colorable
- storage monitor doesn't update when rotated
- storage monitor doesn't display if it's upgraded - storage monitor doesn't display if it's upgraded
- BlockLegacyDisplays don't rotate their faces correctly on the top and bottom
- storage monitors all show the same item

View file

@ -2,19 +2,30 @@ package appeng.block.legacy;
import java.util.EnumSet; import java.util.EnumSet;
import appeng.api.networking.security.PlayerSource;
import appeng.api.networking.storage.IStorageGrid;
import appeng.api.storage.data.IAEItemStack;
import appeng.block.AEBaseBlock; import appeng.block.AEBaseBlock;
import appeng.client.render.BaseBlockRender; import appeng.client.render.BaseBlockRender;
import appeng.client.render.blocks.RenderBlockStorageMonitor; import appeng.client.render.blocks.RenderBlockStorageMonitor;
import appeng.client.texture.ExtraBlockTextures;
import appeng.core.Api; import appeng.core.Api;
import appeng.core.features.AEFeature; import appeng.core.features.AEFeature;
import appeng.me.GridAccessException;
import appeng.tile.AEBaseTile; import appeng.tile.AEBaseTile;
import appeng.tile.legacy.TileStorageMonitor; import appeng.tile.legacy.TileStorageMonitor;
import appeng.util.Platform; import appeng.util.Platform;
import appeng.util.item.AEItemStack; import appeng.util.item.AEItemStack;
import net.minecraft.block.material.Material; import net.minecraft.block.material.Material;
import net.minecraft.entity.Entity;
import net.minecraft.entity.item.EntityItem;
import net.minecraft.entity.player.EntityPlayer; import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.entity.player.EntityPlayerMP;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
import net.minecraft.util.IIcon;
import net.minecraft.world.IBlockAccess;
import net.minecraft.world.World; import net.minecraft.world.World;
import net.minecraftforge.common.util.FakePlayer;
public class BlockStorageMonitor extends BlockLegacyDisplay { public class BlockStorageMonitor extends BlockLegacyDisplay {
public BlockStorageMonitor() { public BlockStorageMonitor() {
@ -49,6 +60,7 @@ public class BlockStorageMonitor extends BlockLegacyDisplay {
tile.markForUpdate(); tile.markForUpdate();
return true; return true;
} }
if (player.getHeldItem().getItem() if (player.getHeldItem().getItem()
== Api.INSTANCE.definitions() == Api.INSTANCE.definitions()
.materials() .materials()
@ -62,7 +74,9 @@ public class BlockStorageMonitor extends BlockLegacyDisplay {
tile.markForUpdate(); tile.markForUpdate();
} }
return true; return true;
} else if (side == tile.getForward().ordinal() && !tile.isLocked) { }
if (side == tile.getForward().ordinal() && !tile.isLocked) {
if (!w.isRemote) { if (!w.isRemote) {
tile.myItem = AEItemStack.create(new ItemStack( tile.myItem = AEItemStack.create(new ItemStack(
player.getHeldItem().getItem(), player.getHeldItem().getItem(),
@ -74,8 +88,107 @@ public class BlockStorageMonitor extends BlockLegacyDisplay {
} }
return true; return true;
} }
if (side == tile.getForward().ordinal() && tile.upgraded) {
try {
IStorageGrid storage
= tile.getProxy().getGrid().getCache(IStorageGrid.class);
IAEItemStack remaining = Api.INSTANCE.storage().poweredInsert(
tile.getProxy().getEnergy(),
storage.getItemInventory(),
AEItemStack.create(player.getHeldItem()),
new PlayerSource(player, tile)
);
player.inventory.setInventorySlotContents(
player.inventory.currentItem,
remaining == null ? null : remaining.getItemStack()
);
if (!(player instanceof FakePlayer)) {
((EntityPlayerMP) player)
.sendContainerToPlayer(player.inventoryContainer);
}
} catch (GridAccessException kek) {}
return true;
}
} else if (side == tile.getForward().ordinal() && tile.upgraded) {
if (player.isSneaking()) {
try {
IStorageGrid storage
= tile.getProxy().getGrid().getCache(IStorageGrid.class);
for (int i = 0; i < player.inventory.getSizeInventory(); i++) {
ItemStack it = player.inventory.getStackInSlot(i);
if (it == null || it.getItem() != tile.myItem.getItem())
continue;
IAEItemStack remaining = Api.INSTANCE.storage().poweredInsert(
tile.getProxy().getEnergy(),
storage.getItemInventory(),
AEItemStack.create(it),
new PlayerSource(player, tile)
);
player.inventory.setInventorySlotContents(
i, remaining == null ? null : remaining.getItemStack()
);
}
if (!(player instanceof FakePlayer)) {
((EntityPlayerMP) player)
.sendContainerToPlayer(player.inventoryContainer);
}
} catch (GridAccessException kek) {}
} else {
if (tile.myItem.getStackSize() == 0)
return true;
try {
IStorageGrid storage
= tile.getProxy().getGrid().getCache(IStorageGrid.class);
IAEItemStack request = tile.myItem.copy();
request.setStackSize(Math.min(
request.getStackSize(), request.getItemStack().getMaxStackSize()
));
IAEItemStack extracted = Api.INSTANCE.storage().poweredExtraction(
tile.getProxy().getEnergy(),
storage.getItemInventory(),
request,
new PlayerSource(player, tile)
);
if (extracted == null)
return true;
Entity itemEntity = new EntityItem(
tile.getWorldObj(),
tile.xCoord + tile.getForward().offsetX + 0.5,
tile.yCoord + tile.getForward().offsetY + 0.5,
tile.zCoord + tile.getForward().offsetZ + 0.5,
extracted.getItemStack()
);
tile.getWorldObj().spawnEntityInWorld(itemEntity);
} catch (GridAccessException kek) {}
}
return true;
} }
return super.onBlockActivated(w, x, y, z, player, side, hitX, hitY, hitZ); return super.onBlockActivated(w, x, y, z, player, side, hitX, hitY, hitZ);
} }
@Override
public IIcon getIcon(IBlockAccess w, int x, int y, int z, int s) {
TileStorageMonitor te = (TileStorageMonitor) w.getTileEntity(x, y, z);
if (te != null && te.upgraded && s == te.getForward().ordinal()) {
return ExtraBlockTextures.BlockStorageMonitorFrontMatrix.getIcon();
}
return super.getIcon(w, x, y, z, s);
}
} }

View file

@ -125,7 +125,9 @@ public enum ExtraBlockTextures {
Controller3("Controller3"), Controller3("Controller3"),
Controller4("Controller4"), Controller4("Controller4"),
Controller5("BlockLegacyControllerFront"), Controller5("BlockLegacyControllerFront"),
ControllerLinked("ControllerLinked"); ControllerLinked("ControllerLinked"),
BlockStorageMonitorFrontMatrix("BlockStorageMonitorFront_Matrix");
private final String name; private final String name;
private IIcon IIcon; private IIcon IIcon;

View file

@ -48,8 +48,7 @@ public class TileStorageMonitor extends TileLegacyDisplay implements IStackWatch
data.writeByte(flags); data.writeByte(flags);
if (this.myItem != null) if (this.myItem != null)
; this.myItem.writeToPacket(data);
this.myItem.writeToPacket(data);
} catch (IOException kek) { } catch (IOException kek) {
throw new RuntimeException(kek); throw new RuntimeException(kek);
} }