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
|
|
|
|
*
|
2016-05-16 22:54:42 +02:00
|
|
|
* © 2015-2016 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;
|
2015-06-12 19:12:06 +02:00
|
|
|
import net.minecraft.block.Block;
|
2015-05-20 22:39:43 +02:00
|
|
|
import net.minecraft.nbt.NBTTagCompound;
|
2016-07-05 08:26:11 +02:00
|
|
|
import net.minecraft.tileentity.TileEntity;
|
2016-01-07 19:47:53 +01:00
|
|
|
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
|
|
|
|
2015-08-10 10:37:44 +02:00
|
|
|
public 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;
|
2015-08-10 22:55:34 +02:00
|
|
|
public BlockPhantom.Type type;
|
2015-06-12 19:12:06 +02:00
|
|
|
public int range;
|
2015-07-07 16:22:37 +02:00
|
|
|
private int rangeBefore;
|
2016-01-08 13:31:58 +01:00
|
|
|
private BlockPos boundPosBefore;
|
2015-07-07 16:22:37 +02:00
|
|
|
private Block boundBlockBefore;
|
|
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
2016-02-01 20:32:49 +01:00
|
|
|
@Override
|
2016-07-02 15:01:46 +02:00
|
|
|
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());
|
|
|
|
}
|
2016-02-01 20:32:49 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2016-07-02 15:01:46 +02:00
|
|
|
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();
|
|
|
|
}
|
2016-02-01 20:32:49 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-05-27 21:57:53 +02:00
|
|
|
@Override
|
|
|
|
public void updateEntity(){
|
2015-11-18 23:11:24 +01:00
|
|
|
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
|
|
|
|
2015-08-10 10:37:44 +02:00
|
|
|
if(!this.hasBoundPosition()){
|
2015-06-12 19:12:06 +02:00
|
|
|
this.boundPosition = null;
|
2015-05-27 21:57:53 +02:00
|
|
|
}
|
2015-07-07 16:22:37 +02:00
|
|
|
|
2016-05-05 17:50:18 +02:00
|
|
|
if(this.doesNeedUpdateSend()){
|
|
|
|
this.onUpdateSent();
|
2015-07-07 16:22:37 +02:00
|
|
|
}
|
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
|
|
|
}
|
|
|
|
|
2016-05-05 17:50:18 +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;
|
2016-05-05 17:50:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
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();
|
2016-05-05 17:50:18 +02:00
|
|
|
|
2016-07-06 21:56:15 +02:00
|
|
|
if(this.boundPosition != null){
|
2016-11-26 21:32:27 +01:00
|
|
|
this.world.notifyNeighborsOfStateChange(this.pos, this.world.getBlockState(this.boundPosition).getBlock(), false);
|
2016-07-06 21:56:15 +02:00
|
|
|
}
|
2016-05-05 17:50:18 +02:00
|
|
|
|
|
|
|
this.sendUpdate();
|
|
|
|
this.markDirty();
|
|
|
|
}
|
|
|
|
|
2015-08-10 10:37:44 +02:00
|
|
|
@Override
|
|
|
|
public boolean hasBoundPosition(){
|
2015-12-23 01:43:49 +01:00
|
|
|
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())){
|
2015-08-10 10:37:44 +02:00
|
|
|
this.boundPosition = null;
|
|
|
|
return false;
|
|
|
|
}
|
2015-12-23 01:43:49 +01:00
|
|
|
return true;
|
2015-08-10 10:37:44 +02:00
|
|
|
}
|
|
|
|
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
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-08-10 10:37:44 +02: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;
|
2015-08-10 10:37:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2016-01-08 13:31:58 +01:00
|
|
|
public BlockPos getBoundPosition(){
|
2015-08-10 10:37:44 +02:00
|
|
|
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
|
|
|
}
|
|
|
|
|
2015-08-10 10:37:44 +02:00
|
|
|
@Override
|
|
|
|
public int getGuiID(){
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public int getRange(){
|
|
|
|
return this.range;
|
|
|
|
}
|
|
|
|
|
2016-06-05 02:16:52 +02:00
|
|
|
@Override
|
|
|
|
public boolean hasCapability(Capability<?> capability, EnumFacing facing){
|
2016-07-05 08:26:11 +02:00
|
|
|
if(this.isBoundThingInRange()){
|
2016-11-26 21:32:27 +01:00
|
|
|
TileEntity tile = this.world.getTileEntity(this.getBoundPosition());
|
2016-07-05 08:26:11 +02:00
|
|
|
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){
|
2016-07-05 08:26:11 +02:00
|
|
|
if(this.isBoundThingInRange()){
|
2016-11-26 21:32:27 +01:00
|
|
|
TileEntity tile = this.world.getTileEntity(this.getBoundPosition());
|
2016-07-05 08:26:11 +02:00
|
|
|
if(tile != null){
|
|
|
|
return tile.getCapability(capability, facing);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return super.getCapability(capability, facing);
|
2016-06-05 02:16:52 +02:00
|
|
|
}
|
2015-05-20 22:39:43 +02:00
|
|
|
}
|