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

220 lines
7.6 KiB
Java
Raw Normal View History

2015-08-29 14:33:25 +02:00
/*
2016-05-16 22:52:27 +02:00
* This file ("TileEntityPhantomface.java") is part of the Actually Additions mod for Minecraft.
2015-08-29 14:33:25 +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-08-29 14:33:25 +02:00
* View the source code at https://github.com/Ellpeck/ActuallyAdditions
*
2017-01-01 16:23:26 +01:00
* © 2015-2017 Ellpeck
2015-08-29 14:33:25 +02:00
*/
2016-01-05 04:47:35 +01:00
package de.ellpeck.actuallyadditions.mod.tile;
2015-05-20 22:39:43 +02:00
2016-01-05 04:47:35 +01:00
import de.ellpeck.actuallyadditions.api.tile.IPhantomTile;
import de.ellpeck.actuallyadditions.mod.blocks.BlockPhantom;
import de.ellpeck.actuallyadditions.mod.blocks.InitBlocks;
import net.minecraft.block.Block;
import net.minecraft.block.state.IBlockState;
2015-05-20 22:39:43 +02:00
import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.EnumFacing;
import net.minecraft.util.EnumParticleTypes;
2016-03-18 23:47:22 +01:00
import net.minecraft.util.math.BlockPos;
2015-05-20 22:39:43 +02:00
import net.minecraft.world.World;
2016-06-05 02:16:52 +02:00
import net.minecraftforge.common.capabilities.Capability;
2016-01-07 18:20:59 +01:00
import net.minecraftforge.fml.relauncher.Side;
import net.minecraftforge.fml.relauncher.SideOnly;
2015-05-20 22:39:43 +02:00
public abstract class TileEntityPhantomface extends TileEntityInventoryBase implements IPhantomTile{
2015-05-20 22:39:43 +02:00
2015-12-01 19:48:09 +01:00
public static final int RANGE = 16;
2016-01-08 13:31:58 +01:00
public BlockPos boundPosition;
public BlockPhantom.Type type;
public int range;
private int rangeBefore;
2016-01-08 13:31:58 +01:00
private BlockPos boundPosBefore;
private Block boundBlockBefore;
private int lastStrength;
2015-05-27 21:57:53 +02:00
public TileEntityPhantomface(String name){
super(0, name);
2015-05-20 22:39:43 +02:00
}
2016-02-01 20:39:11 +01:00
public static int upgradeRange(int defaultRange, World world, BlockPos pos){
int newRange = defaultRange;
for(int i = 0; i < 3; i++){
2016-07-04 20:15:41 +02:00
Block block = world.getBlockState(pos.up(1+i)).getBlock();
2016-02-01 20:39:11 +01:00
if(block == InitBlocks.blockPhantomBooster){
newRange = newRange*2;
}
else{
break;
}
}
return newRange;
}
@Override
public void writeSyncableNBT(NBTTagCompound compound, NBTType type){
super.writeSyncableNBT(compound, type);
if(type != NBTType.SAVE_BLOCK){
compound.setInteger("Range", this.range);
if(this.boundPosition != null){
compound.setInteger("XCoordOfTileStored", this.boundPosition.getX());
compound.setInteger("YCoordOfTileStored", this.boundPosition.getY());
compound.setInteger("ZCoordOfTileStored", this.boundPosition.getZ());
}
}
}
@Override
public void readSyncableNBT(NBTTagCompound compound, NBTType type){
super.readSyncableNBT(compound, type);
if(type != NBTType.SAVE_BLOCK){
int x = compound.getInteger("XCoordOfTileStored");
int y = compound.getInteger("YCoordOfTileStored");
int z = compound.getInteger("ZCoordOfTileStored");
this.range = compound.getInteger("Range");
if(!(x == 0 && y == 0 && z == 0)){
this.boundPosition = new BlockPos(x, y, z);
this.markDirty();
}
}
}
2015-05-27 21:57:53 +02:00
@Override
public void updateEntity(){
super.updateEntity();
2016-11-26 21:32:27 +01:00
if(!this.world.isRemote){
this.range = upgradeRange(RANGE, this.world, this.getPos());
2015-05-27 21:57:53 +02:00
if(!this.hasBoundPosition()){
this.boundPosition = null;
2015-05-27 21:57:53 +02:00
}
if(this.doesNeedUpdateSend()){
this.onUpdateSent();
}
int strength = this.getComparatorStrength();
if(this.lastStrength != strength){
this.lastStrength = strength;
this.markDirty();
}
2015-05-27 21:57:53 +02:00
}
2015-10-26 22:47:26 +01:00
else{
if(this.boundPosition != null){
2015-10-27 23:09:23 +01:00
this.renderParticles();
2015-10-26 22:47:26 +01:00
}
}
2015-05-27 21:57:53 +02:00
}
protected boolean doesNeedUpdateSend(){
2016-11-26 21:32:27 +01:00
return this.boundPosition != this.boundPosBefore || (this.boundPosition != null && this.world.getBlockState(this.boundPosition).getBlock() != this.boundBlockBefore) || this.rangeBefore != this.range;
}
protected void onUpdateSent(){
this.rangeBefore = this.range;
this.boundPosBefore = this.boundPosition;
2016-11-26 21:32:27 +01:00
this.boundBlockBefore = this.boundPosition == null ? null : this.world.getBlockState(this.boundPosition).getBlock();
if(this.boundPosition != null){
2016-11-26 21:32:27 +01:00
this.world.notifyNeighborsOfStateChange(this.pos, this.world.getBlockState(this.boundPosition).getBlock(), false);
}
this.sendUpdate();
this.markDirty();
}
@Override
public boolean hasBoundPosition(){
if(this.boundPosition != null){
2016-11-26 21:32:27 +01:00
if(this.world.getTileEntity(this.boundPosition) instanceof IPhantomTile || (this.getPos().getX() == this.boundPosition.getX() && this.getPos().getY() == this.boundPosition.getY() && this.getPos().getZ() == this.boundPosition.getZ())){
this.boundPosition = null;
return false;
}
return true;
}
return false;
}
2015-10-28 14:46:04 +01:00
@SideOnly(Side.CLIENT)
public void renderParticles(){
2016-11-26 21:32:27 +01:00
if(this.world.rand.nextInt(2) == 0){
double d1 = (double)((float)this.boundPosition.getY()+this.world.rand.nextFloat());
int i1 = this.world.rand.nextInt(2)*2-1;
int j1 = this.world.rand.nextInt(2)*2-1;
double d4 = ((double)this.world.rand.nextFloat()-0.5D)*0.125D;
2015-10-28 14:46:04 +01:00
double d2 = (double)this.boundPosition.getZ()+0.5D+0.25D*(double)j1;
2016-11-26 21:32:27 +01:00
double d5 = (double)(this.world.rand.nextFloat()*1.0F*(float)j1);
2015-10-28 14:46:04 +01:00
double d0 = (double)this.boundPosition.getX()+0.5D+0.25D*(double)i1;
2016-11-26 21:32:27 +01:00
double d3 = (double)(this.world.rand.nextFloat()*1.0F*(float)i1);
this.world.spawnParticle(EnumParticleTypes.PORTAL, d0, d1, d2, d3, d4, d5);
2015-10-28 14:46:04 +01:00
}
}
@Override
public boolean isBoundThingInRange(){
2016-07-04 20:15:41 +02:00
return this.hasBoundPosition() && this.boundPosition.distanceSq(this.getPos()) <= this.range*this.range;
}
@Override
2016-01-08 13:31:58 +01:00
public BlockPos getBoundPosition(){
return this.boundPosition;
}
2015-10-03 10:16:18 +02:00
@Override
2016-01-08 13:31:58 +01:00
public void setBoundPosition(BlockPos pos){
2016-07-04 20:15:41 +02:00
this.boundPosition = pos;
2015-10-03 10:16:18 +02:00
}
@Override
public int getGuiID(){
return -1;
}
@Override
public int getRange(){
return this.range;
}
protected abstract boolean isCapabilitySupported(Capability<?> capability);
2016-06-05 02:16:52 +02:00
@Override
public boolean hasCapability(Capability<?> capability, EnumFacing facing){
if(this.isBoundThingInRange() && this.isCapabilitySupported(capability)){
2016-11-26 21:32:27 +01:00
TileEntity tile = this.world.getTileEntity(this.getBoundPosition());
if(tile != null){
return tile.hasCapability(capability, facing);
}
}
return super.hasCapability(capability, facing);
2016-06-05 02:16:52 +02:00
}
@Override
public <T> T getCapability(Capability<T> capability, EnumFacing facing){
if(this.isBoundThingInRange() && this.isCapabilitySupported(capability)){
2016-11-26 21:32:27 +01:00
TileEntity tile = this.world.getTileEntity(this.getBoundPosition());
if(tile != null){
return tile.getCapability(capability, facing);
}
}
return super.getCapability(capability, facing);
2016-06-05 02:16:52 +02:00
}
@Override
public int getComparatorStrength(){
if(this.isBoundThingInRange()){
BlockPos pos = this.getBoundPosition();
IBlockState state = this.world.getBlockState(pos);
Block block = state.getBlock();
if(block.hasComparatorInputOverride(state)){
return block.getComparatorInputOverride(state, this.world, pos);
}
}
return 0;
}
2015-05-20 22:39:43 +02:00
}