mirror of
https://github.com/HbmMods/Hbm-s-Nuclear-Tech-GIT.git
synced 2026-01-25 10:32:49 +00:00
140 lines
3.8 KiB
Java
140 lines
3.8 KiB
Java
package com.hbm.blocks.machine;
|
|
|
|
import com.hbm.saveddata.RadiationSavedData;
|
|
|
|
import net.minecraft.block.BlockContainer;
|
|
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.tileentity.TileEntity;
|
|
import net.minecraft.util.AxisAlignedBB;
|
|
import net.minecraft.util.ChatComponentText;
|
|
import net.minecraft.util.MathHelper;
|
|
import net.minecraft.world.IBlockAccess;
|
|
import net.minecraft.world.World;
|
|
import net.minecraft.world.chunk.Chunk;
|
|
|
|
public class GeigerCounter extends BlockContainer {
|
|
|
|
public GeigerCounter(Material p_i45386_1_) {
|
|
super(p_i45386_1_);
|
|
}
|
|
|
|
@Override
|
|
public TileEntity createNewTileEntity(World p_149915_1_, int p_149915_2_) {
|
|
return new TileEntityGeiger();
|
|
}
|
|
|
|
@Override
|
|
public int getRenderType(){
|
|
return -1;
|
|
}
|
|
|
|
@Override
|
|
public boolean isOpaqueCube() {
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
public boolean renderAsNormalBlock() {
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
public void onBlockPlacedBy(World world, int x, int y, int z, EntityLivingBase player, ItemStack itemStack) {
|
|
int i = MathHelper.floor_double(player.rotationYaw * 4.0F / 360.0F + 0.5D) & 3;
|
|
|
|
if(i == 0)
|
|
{
|
|
world.setBlockMetadataWithNotify(x, y, z, 3, 2);
|
|
}
|
|
if(i == 1)
|
|
{
|
|
world.setBlockMetadataWithNotify(x, y, z, 4, 2);
|
|
}
|
|
if(i == 2)
|
|
{
|
|
world.setBlockMetadataWithNotify(x, y, z, 2, 2);
|
|
}
|
|
if(i == 3)
|
|
{
|
|
world.setBlockMetadataWithNotify(x, y, z, 5, 2);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void setBlockBoundsBasedOnState(IBlockAccess p_149719_1_, int p_149719_2_, int p_149719_3_, int p_149719_4_)
|
|
{
|
|
int te = p_149719_1_.getBlockMetadata(p_149719_2_, p_149719_3_, p_149719_4_);
|
|
float f = 0.0625F;
|
|
|
|
this.setBlockBounds(0.0F, 0.0F, 2*f, 1.0F, 1.0F, 14*f);
|
|
switch(te)
|
|
{
|
|
case 4:
|
|
this.setBlockBounds(2*f, 0.0F, 1*f, 14*f, 9*f, 15*f);
|
|
break;
|
|
case 2:
|
|
this.setBlockBounds(1*f, 0.0F, 2*f, 15*f, 9*f, 14*f);
|
|
break;
|
|
case 5:
|
|
this.setBlockBounds(2*f, 0.0F, 1*f, 14*f, 9*f, 15*f);
|
|
break;
|
|
case 3:
|
|
this.setBlockBounds(1*f, 0.0F, 2*f, 15*f, 9*f, 14*f);
|
|
break;
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public AxisAlignedBB getCollisionBoundingBoxFromPool(World world, int x, int y, int z) {
|
|
|
|
int te = world.getBlockMetadata(x, y, z);
|
|
float f = 0.0625F;
|
|
|
|
this.setBlockBounds(0.0F, 0.0F, 2*f, 1.0F, 1.0F, 14*f);
|
|
switch(te)
|
|
{
|
|
case 4:
|
|
this.setBlockBounds(2*f, 0.0F, 1*f, 14*f, 9*f, 15*f);
|
|
break;
|
|
case 2:
|
|
this.setBlockBounds(1*f, 0.0F, 2*f, 15*f, 9*f, 14*f);
|
|
break;
|
|
case 5:
|
|
this.setBlockBounds(2*f, 0.0F, 1*f, 14*f, 9*f, 15*f);
|
|
break;
|
|
case 3:
|
|
this.setBlockBounds(1*f, 0.0F, 2*f, 15*f, 9*f, 14*f);
|
|
break;
|
|
}
|
|
|
|
return AxisAlignedBB.getBoundingBox(x + this.minX, y + this.minY, z + this.minZ, x + this.maxX, y + this.maxY, z + this.maxZ);
|
|
}
|
|
|
|
@Override
|
|
public boolean onBlockActivated(World world, int x, int y, int z, EntityPlayer player, int side, float hitX, float hitY, float hitZ) {
|
|
|
|
if(world.isRemote)
|
|
{
|
|
return true;
|
|
} else if(!player.isSneaking())
|
|
{
|
|
world.playSoundAtEntity(player, "hbm:item.techBoop", 1.0F, 1.0F);
|
|
|
|
double eRad = ((int)(player.getEntityData().getFloat("hfr_radiation") * 10)) / 10D;
|
|
|
|
RadiationSavedData data = RadiationSavedData.getData(player.worldObj);
|
|
Chunk chunk = world.getChunkFromBlockCoords((int)player.posX, (int)player.posZ);
|
|
double rads = ((int)(data.getRadNumFromCoord(chunk.xPosition, chunk.zPosition) * 10)) / 10D;
|
|
|
|
player.addChatMessage(new ChatComponentText("Current chunk radiation: " + rads + " RAD/s"));
|
|
player.addChatMessage(new ChatComponentText("Player contamination: " + eRad + " RAD"));
|
|
return true;
|
|
} else {
|
|
return false;
|
|
}
|
|
}
|
|
}
|