mirror of
https://github.com/HbmMods/Hbm-s-Nuclear-Tech-GIT.git
synced 2026-01-25 10:32:49 +00:00
225 lines
5.9 KiB
Java
225 lines
5.9 KiB
Java
package com.hbm.blocks.network;
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.List;
|
|
|
|
import com.hbm.blocks.ILookOverlay;
|
|
import com.hbm.blocks.ITooltipProvider;
|
|
import com.hbm.tileentity.TileEntityLoadedBase;
|
|
import com.hbm.util.BobMathUtil;
|
|
import com.hbm.util.I18nUtil;
|
|
|
|
import api.hbm.block.IToolable;
|
|
import api.hbm.energy.IEnergyUser;
|
|
import cpw.mods.fml.client.registry.RenderingRegistry;
|
|
import cpw.mods.fml.relauncher.Side;
|
|
import cpw.mods.fml.relauncher.SideOnly;
|
|
import net.minecraft.block.BlockContainer;
|
|
import net.minecraft.block.BlockPistonBase;
|
|
import net.minecraft.block.material.Material;
|
|
import net.minecraft.entity.EntityLivingBase;
|
|
import net.minecraft.entity.player.EntityPlayer;
|
|
import net.minecraft.item.ItemStack;
|
|
import net.minecraft.nbt.NBTTagCompound;
|
|
import net.minecraft.network.NetworkManager;
|
|
import net.minecraft.network.Packet;
|
|
import net.minecraft.network.play.server.S35PacketUpdateTileEntity;
|
|
import net.minecraft.tileentity.TileEntity;
|
|
import net.minecraft.util.EnumChatFormatting;
|
|
import net.minecraft.world.IBlockAccess;
|
|
import net.minecraft.world.World;
|
|
import net.minecraftforge.client.event.RenderGameOverlayEvent.Pre;
|
|
import net.minecraftforge.common.util.ForgeDirection;
|
|
|
|
public class CableDiode extends BlockContainer implements ILookOverlay, IToolable, ITooltipProvider {
|
|
|
|
public CableDiode(Material mat) {
|
|
super(mat);
|
|
}
|
|
|
|
public static int renderID = RenderingRegistry.getNextAvailableRenderId();
|
|
|
|
@Override
|
|
public int getRenderType() {
|
|
return renderID;
|
|
}
|
|
|
|
@Override
|
|
public boolean isOpaqueCube() {
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
public boolean renderAsNormalBlock() {
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
@SideOnly(Side.CLIENT)
|
|
public boolean shouldSideBeRendered(IBlockAccess p_149646_1_, int p_149646_2_, int p_149646_3_, int p_149646_4_, int p_149646_5_) {
|
|
return true;
|
|
}
|
|
|
|
public void onBlockPlacedBy(World world, int x, int y, int z, EntityLivingBase player, ItemStack stack) {
|
|
int l = BlockPistonBase.determineOrientation(world, x, y, z, player);
|
|
world.setBlockMetadataWithNotify(x, y, z, l, 2);
|
|
}
|
|
|
|
@Override
|
|
public boolean onScrew(World world, EntityPlayer player, int x, int y, int z, int side, float fX, float fY, float fZ, ToolType tool) {
|
|
|
|
TileEntityDiode te = (TileEntityDiode)world.getTileEntity(x, y, z);
|
|
|
|
if(world.isRemote)
|
|
return true;
|
|
|
|
if(tool == ToolType.SCREWDRIVER) {
|
|
if(te.level < 11)
|
|
te.level++;
|
|
te.markDirty();
|
|
world.markBlockForUpdate(x, y, z);
|
|
return true;
|
|
}
|
|
|
|
if(tool == ToolType.HAND_DRILL) {
|
|
if(te.level > 1)
|
|
te.level--;
|
|
te.markDirty();
|
|
world.markBlockForUpdate(x, y, z);
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
public void addInformation(ItemStack stack, EntityPlayer player, List list, boolean ext) {
|
|
list.add(EnumChatFormatting.GOLD + "Limits throughput and restricts flow direction");
|
|
list.add(EnumChatFormatting.YELLOW + "Use screwdriver to increase throughput");
|
|
list.add(EnumChatFormatting.YELLOW + "Use hand drill to decrease throughput");
|
|
}
|
|
|
|
@Override
|
|
public void printHook(Pre event, World world, int x, int y, int z) {
|
|
|
|
TileEntity te = world.getTileEntity(x, y, z);
|
|
|
|
if(!(te instanceof TileEntityDiode))
|
|
return;
|
|
|
|
TileEntityDiode diode = (TileEntityDiode) te;
|
|
|
|
List<String> text = new ArrayList();
|
|
text.add("Max.: " + BobMathUtil.getShortNumber(diode.getMaxPower()) + "HE/t");
|
|
|
|
ILookOverlay.printGeneric(event, I18nUtil.resolveKey(getUnlocalizedName() + ".name"), 0xffff00, 0x404000, text);
|
|
}
|
|
|
|
@Override
|
|
public TileEntity createNewTileEntity(World world, int meta) {
|
|
return new TileEntityDiode();
|
|
}
|
|
|
|
public static class TileEntityDiode extends TileEntityLoadedBase implements IEnergyUser {
|
|
|
|
@Override
|
|
public void readFromNBT(NBTTagCompound nbt) {
|
|
super.readFromNBT(nbt);
|
|
level = nbt.getInteger("level");
|
|
}
|
|
|
|
@Override
|
|
public void writeToNBT(NBTTagCompound nbt) {
|
|
super.writeToNBT(nbt);
|
|
nbt.setInteger("level", level);
|
|
}
|
|
|
|
@Override
|
|
public Packet getDescriptionPacket() {
|
|
NBTTagCompound nbt = new NBTTagCompound();
|
|
this.writeToNBT(nbt);
|
|
return new S35PacketUpdateTileEntity(this.xCoord, this.yCoord, this.zCoord, 0, nbt);
|
|
}
|
|
|
|
@Override
|
|
public void onDataPacket(NetworkManager net, S35PacketUpdateTileEntity pkt) {
|
|
this.readFromNBT(pkt.func_148857_g());
|
|
}
|
|
|
|
int level = 1;
|
|
|
|
private ForgeDirection getDir() {
|
|
return ForgeDirection.getOrientation(this.getBlockMetadata()).getOpposite();
|
|
}
|
|
|
|
@Override
|
|
public void updateEntity() {
|
|
|
|
if(!worldObj.isRemote) {
|
|
for(ForgeDirection dir : ForgeDirection.VALID_DIRECTIONS) {
|
|
|
|
if(dir == getDir())
|
|
continue;
|
|
|
|
this.trySubscribe(worldObj, xCoord + dir.offsetX, yCoord + dir.offsetY, zCoord + dir.offsetZ, dir);
|
|
}
|
|
}
|
|
}
|
|
|
|
private boolean recursionBrake = false;
|
|
private long subBuffer;
|
|
private long contingent = 0;
|
|
private long lastTransfer = 0;
|
|
|
|
@Override
|
|
public long transferPower(long power) {
|
|
|
|
if(recursionBrake)
|
|
return power;
|
|
|
|
if(lastTransfer != worldObj.getTotalWorldTime()) {
|
|
lastTransfer = worldObj.getTotalWorldTime();
|
|
contingent = getMaxPower();
|
|
}
|
|
|
|
if(contingent <= 0)
|
|
return power;
|
|
|
|
//this part turns "maxPower" from a glorified transfer weight into an actual transfer cap
|
|
long overShoot = Math.max(0, power - contingent);
|
|
power = Math.min(power, contingent);
|
|
|
|
recursionBrake = true;
|
|
this.subBuffer = power;
|
|
|
|
ForgeDirection dir = getDir();
|
|
this.sendPower(worldObj, xCoord + dir.offsetX, yCoord + dir.offsetY, zCoord + dir.offsetZ, dir);
|
|
long ret = this.subBuffer;
|
|
|
|
long sent = power - ret;
|
|
contingent -= sent;
|
|
|
|
this.subBuffer = 0;
|
|
recursionBrake = false;
|
|
|
|
return ret + overShoot;
|
|
}
|
|
|
|
|
|
@Override
|
|
public long getMaxPower() {
|
|
return (long) Math.pow(10, level);
|
|
}
|
|
|
|
@Override
|
|
public long getPower() {
|
|
return subBuffer;
|
|
}
|
|
|
|
@Override
|
|
public void setPower(long power) {
|
|
this.subBuffer = power;
|
|
}
|
|
}
|
|
}
|