Applied-Energistics-2-tiler.../src/main/java/appeng/fmp/CableBusPart.java

698 lines
16 KiB
Java
Raw Normal View History

2014-11-14 12:02:52 +01:00
/*
* This file is part of Applied Energistics 2.
* Copyright (c) 2013 - 2015, AlgorithmX2, All rights reserved.
2014-11-14 12:02:52 +01:00
*
* Applied Energistics 2 is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Applied Energistics 2 is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with Applied Energistics 2. If not, see <http://www.gnu.org/licenses/lgpl>.
*/
2014-09-24 02:26:27 +02:00
package appeng.fmp;
2014-09-24 02:26:27 +02:00
import java.io.IOException;
import java.util.ArrayList;
import java.util.EnumSet;
import java.util.LinkedList;
import java.util.List;
import java.util.Set;
2014-12-29 21:59:05 +01:00
import io.netty.buffer.ByteBuf;
import io.netty.buffer.Unpooled;
2014-09-24 02:26:27 +02:00
import net.minecraft.entity.Entity;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.item.ItemStack;
import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.AxisAlignedBB;
import net.minecraft.util.MovingObjectPosition;
import net.minecraft.util.Vec3;
2014-12-29 21:59:05 +01:00
import codechicken.lib.data.MCDataInput;
import codechicken.lib.data.MCDataOutput;
import codechicken.lib.raytracer.IndexedCuboid6;
import codechicken.lib.vec.Cuboid6;
import codechicken.lib.vec.Vector3;
import codechicken.multipart.IMaskedRedstonePart;
2014-12-29 21:59:05 +01:00
import codechicken.multipart.JCuboidPart;
import codechicken.multipart.JNormalOcclusion;
import codechicken.multipart.NormalOcclusionTest;
import codechicken.multipart.NormallyOccludedPart;
import codechicken.multipart.TMultiPart;
import codechicken.multipart.scalatraits.TIInventoryTile;
2014-09-24 02:26:27 +02:00
import appeng.api.implementations.parts.IPartCable;
import appeng.api.networking.IGridNode;
import appeng.api.parts.IFacadeContainer;
import appeng.api.parts.IFacadePart;
import appeng.api.parts.IPart;
import appeng.api.parts.IPartCollisionHelper;
import appeng.api.parts.IPartItem;
import appeng.api.parts.LayerFlags;
import appeng.api.parts.PartItemStack;
import appeng.api.parts.SelectedPart;
import appeng.api.util.AECableType;
import appeng.api.util.AEColor;
import appeng.api.util.DimensionalCoord;
2015-06-16 02:44:59 +02:00
import appeng.api.util.ForgeDirection;
2014-09-24 02:26:27 +02:00
import appeng.client.render.BusRenderHelper;
import appeng.client.render.BusRenderer;
import appeng.core.AEConfig;
import appeng.core.AELog;
import appeng.core.features.AEFeature;
import appeng.helpers.AEMultiTile;
import appeng.parts.BusCollisionHelper;
import appeng.parts.CableBusContainer;
import appeng.parts.PartPlacement;
import appeng.tile.networking.TileCableBus;
import appeng.util.Platform;
2014-09-24 02:26:27 +02:00
/**
* Implementing these might help improve visuals for hollow covers
2015-02-03 12:04:13 +01:00
*
2014-09-24 02:26:27 +02:00
* TSlottedPart,ISidedHollowConnect
*/
public class CableBusPart extends JCuboidPart implements JNormalOcclusion, IMaskedRedstonePart, AEMultiTile
2014-09-24 02:26:27 +02:00
{
public static final ThreadLocal<Boolean> DISABLE_FACADE_OCCLUSION = new ThreadLocal<Boolean>();
private static final double SHORTER = 6.0 / 16.0;
private static final double LONGER = 10.0 / 16.0;
private static final double MIN_DIRECTION = 0;
private static final double MAX_DIRECTION = 1.0;
private static final Cuboid6[] SIDE_TESTS = {
2014-09-24 02:26:27 +02:00
// DOWN(0, -1, 0),
new Cuboid6( SHORTER, MIN_DIRECTION, SHORTER, LONGER, SHORTER, LONGER ),
2014-09-24 02:26:27 +02:00
// UP(0, 1, 0),
new Cuboid6( SHORTER, LONGER, SHORTER, LONGER, MAX_DIRECTION, LONGER ),
2014-09-24 02:26:27 +02:00
// NORTH(0, 0, -1),
new Cuboid6( SHORTER, SHORTER, MIN_DIRECTION, LONGER, LONGER, SHORTER ),
2014-09-24 02:26:27 +02:00
// SOUTH(0, 0, 1),
new Cuboid6( SHORTER, SHORTER, LONGER, LONGER, LONGER, MAX_DIRECTION ),
2014-09-24 02:26:27 +02:00
// WEST(-1, 0, 0),
new Cuboid6( MIN_DIRECTION, SHORTER, SHORTER, SHORTER, LONGER, LONGER ),
2014-09-24 02:26:27 +02:00
// EAST(1, 0, 0),
new Cuboid6( LONGER, SHORTER, SHORTER, MAX_DIRECTION, LONGER, LONGER ),
2014-09-24 02:26:27 +02:00
};
/**
* Mask for {@link IMaskedRedstonePart#getConnectionMask(int)}
*
* the bits are derived from the rotation, where 4 is the center
*/
private static final int CONNECTION_MASK = 0x000010;
2014-09-24 02:26:27 +02:00
public CableBusContainer cb = new CableBusContainer( this );
boolean canUpdate = false;
2014-09-24 02:26:27 +02:00
@Override
public boolean recolourBlock( ForgeDirection side, AEColor colour, EntityPlayer who )
2014-09-24 02:26:27 +02:00
{
return this.cb.recolourBlock( side, colour, who );
2014-09-24 02:26:27 +02:00
}
@Override
public Cuboid6 getBounds()
2014-09-24 02:26:27 +02:00
{
AxisAlignedBB b = null;
for( AxisAlignedBB bx : this.cb.getSelectedBoundingBoxesFromPool( false, true, null, true ) )
{
if( b == null )
2015-04-29 02:30:53 +02:00
{
b = bx;
2015-04-29 02:30:53 +02:00
}
else
{
double minX = Math.min( b.minX, bx.minX );
double minY = Math.min( b.minY, bx.minY );
double minZ = Math.min( b.minZ, bx.minZ );
double maxX = Math.max( b.maxX, bx.maxX );
double maxY = Math.max( b.maxY, bx.maxY );
double maxZ = Math.max( b.maxZ, bx.maxZ );
b.setBounds( minX, minY, minZ, maxX, maxY, maxZ );
}
}
if( b == null )
2015-04-29 02:30:53 +02:00
{
return new Cuboid6( 0.0, 0.0, 0.0, 1.0, 1.0, 1.0 );
2015-04-29 02:30:53 +02:00
}
return new Cuboid6( b.minX, b.minY, b.minZ, b.maxX, b.maxY, b.maxZ );
2014-09-24 02:26:27 +02:00
}
@Override
public String getType()
2014-09-24 02:26:27 +02:00
{
return PartRegistry.CableBusPart.getName();
2014-09-24 02:26:27 +02:00
}
@Override
public int getLightValue()
2014-09-24 02:26:27 +02:00
{
return this.cb.getLightValue();
2014-09-24 02:26:27 +02:00
}
@Override
public void onWorldJoin()
2014-09-24 02:26:27 +02:00
{
this.canUpdate = true;
this.cb.updateConnections();
this.cb.addToWorld();
2014-09-24 02:26:27 +02:00
}
@Override
public boolean occlusionTest( TMultiPart part )
2014-09-24 02:26:27 +02:00
{
return NormalOcclusionTest.apply( this, part );
2014-09-24 02:26:27 +02:00
}
@Override
public boolean renderStatic( Vector3 pos, int pass )
2014-09-24 02:26:27 +02:00
{
if( pass == 0 || ( pass == 1 && AEConfig.instance.isFeatureEnabled( AEFeature.AlphaPass ) ) )
{
BusRenderHelper.INSTANCE.setPass( pass );
BusRenderer.INSTANCE.renderer.renderAllFaces = true;
BusRenderer.INSTANCE.renderer.blockAccess = this.world();
BusRenderer.INSTANCE.renderer.overrideBlockTexture = null;
this.cb.renderStatic( pos.x, pos.y, pos.z );
return BusRenderHelper.INSTANCE.getItemsRendered() > 0;
}
return false;
2014-09-24 02:26:27 +02:00
}
@Override
public void renderDynamic( Vector3 pos, float frame, int pass )
2014-09-24 02:26:27 +02:00
{
if( pass == 0 || ( pass == 1 && AEConfig.instance.isFeatureEnabled( AEFeature.AlphaPass ) ) )
2014-09-24 02:26:27 +02:00
{
BusRenderHelper.INSTANCE.setPass( pass );
this.cb.renderDynamic( pos.x, pos.y, pos.z );
2014-09-24 02:26:27 +02:00
}
}
@Override
public void onPartChanged( TMultiPart part )
2014-09-24 02:26:27 +02:00
{
this.cb.updateConnections();
2014-09-24 02:26:27 +02:00
}
@Override
public void onEntityCollision( Entity entity )
2014-09-24 02:26:27 +02:00
{
this.cb.onEntityCollision( entity );
}
2014-09-24 02:26:27 +02:00
@Override
public boolean activate( EntityPlayer player, MovingObjectPosition hit, ItemStack item )
{
return this.cb.activate( player, hit.hitVec.addVector( -hit.blockX, -hit.blockY, -hit.blockZ ) );
}
2014-09-24 02:26:27 +02:00
@Override
public void load( NBTTagCompound tag )
{
this.cb.readFromNBT( tag );
}
2014-09-24 02:26:27 +02:00
@Override
public void onWorldSeparate()
{
this.canUpdate = false;
this.cb.removeFromWorld();
2014-09-24 02:26:27 +02:00
}
@Override
public void save( NBTTagCompound tag )
2014-09-24 02:26:27 +02:00
{
this.cb.writeToNBT( tag );
2014-09-24 02:26:27 +02:00
}
@Override
public void writeDesc( MCDataOutput packet )
2014-09-24 02:26:27 +02:00
{
ByteBuf stream = Unpooled.buffer();
try
{
this.cb.writeToStream( stream );
packet.writeInt( stream.readableBytes() );
stream.capacity( stream.readableBytes() );
packet.writeByteArray( stream.array() );
}
catch( IOException e )
{
AELog.error( e );
}
2014-09-24 02:26:27 +02:00
}
@Override
public ItemStack pickItem( MovingObjectPosition hit )
2014-09-24 02:26:27 +02:00
{
Vec3 v3 = hit.hitVec.addVector( -hit.blockX, -hit.blockY, -hit.blockZ );
2014-12-29 15:13:47 +01:00
SelectedPart sp = this.cb.selectPart( v3 );
if( sp != null )
2014-09-24 02:26:27 +02:00
{
if( sp.part != null )
2015-04-29 02:30:53 +02:00
{
2014-09-24 02:26:27 +02:00
return sp.part.getItemStack( PartItemStack.Break );
2015-04-29 02:30:53 +02:00
}
if( sp.facade != null )
2015-04-29 02:30:53 +02:00
{
2014-09-24 02:26:27 +02:00
return sp.facade.getItemStack();
2015-04-29 02:30:53 +02:00
}
2014-09-24 02:26:27 +02:00
}
return null;
}
@Override
public Iterable<ItemStack> getDrops()
{
2014-12-29 15:13:47 +01:00
return this.cb.getDrops( new ArrayList() );
2014-09-24 02:26:27 +02:00
}
@Override
public void onNeighborChanged()
2014-09-24 02:26:27 +02:00
{
this.cb.onNeighborChanged();
2014-09-24 02:26:27 +02:00
}
@Override
public boolean doesTick()
2014-09-24 02:26:27 +02:00
{
return false;
2014-09-24 02:26:27 +02:00
}
@Override
public void invalidateConvertedTile()
2014-09-24 02:26:27 +02:00
{
this.cb.setHost( this );
}
@Override
public void readDesc( MCDataInput packet )
{
int len = packet.readInt();
byte[] data = packet.readByteArray( len );
try
{
if( len > 0 )
{
ByteBuf byteBuffer = Unpooled.wrappedBuffer( data );
this.cb.readFromStream( byteBuffer );
}
}
catch( IOException e )
{
AELog.error( e );
}
2014-09-28 00:50:06 +02:00
}
2014-09-24 02:26:27 +02:00
@Override
public boolean canConnectRedstone( int side )
2014-09-24 02:26:27 +02:00
{
2014-12-29 15:13:47 +01:00
return this.cb.canConnectRedstone( EnumSet.of( ForgeDirection.getOrientation( side ) ) );
2014-09-24 02:26:27 +02:00
}
@Override
public int weakPowerLevel( int side )
{
return this.cb.isProvidingWeakPower( ForgeDirection.getOrientation( side ) );
}
@Override
public int strongPowerLevel( int side )
2014-09-24 02:26:27 +02:00
{
2014-12-29 15:13:47 +01:00
return this.cb.isProvidingStrongPower( ForgeDirection.getOrientation( side ) );
2014-09-24 02:26:27 +02:00
}
public void convertFromTile( TileEntity blockTileEntity )
{
TileCableBus tcb = (TileCableBus) blockTileEntity;
this.cb = tcb.cb;
}
2014-09-24 02:26:27 +02:00
@Override
public Iterable<Cuboid6> getOcclusionBoxes()
2014-09-24 02:26:27 +02:00
{
LinkedList<Cuboid6> l = new LinkedList<Cuboid6>();
for( AxisAlignedBB b : this.cb.getSelectedBoundingBoxesFromPool( true, DISABLE_FACADE_OCCLUSION.get() == null, null, true ) )
{
l.add( new Cuboid6( b.minX, b.minY, b.minZ, b.maxX, b.maxY, b.maxZ ) );
}
return l;
2014-09-24 02:26:27 +02:00
}
@Override
public IGridNode getGridNode( ForgeDirection dir )
2014-09-24 02:26:27 +02:00
{
return this.cb.getGridNode( dir );
2014-09-24 02:26:27 +02:00
}
@Override
public AECableType getCableConnectionType( ForgeDirection dir )
2014-09-24 02:26:27 +02:00
{
return this.cb.getCableConnectionType( dir );
2014-09-24 02:26:27 +02:00
}
@Override
public void securityBreak()
2014-09-24 02:26:27 +02:00
{
this.cb.securityBreak();
}
// @Override
public int getHollowSize( int side )
{
IPartCable cable = (IPartCable) this.getPart( ForgeDirection.UNKNOWN );
ForgeDirection dir = ForgeDirection.getOrientation( side );
if( cable != null && cable.isConnected( dir ) )
2014-09-24 02:26:27 +02:00
{
List<AxisAlignedBB> boxes = new ArrayList<AxisAlignedBB>();
BusCollisionHelper bch = new BusCollisionHelper( boxes, ForgeDirection.EAST, ForgeDirection.UP, ForgeDirection.SOUTH, null, true );
for( ForgeDirection whichSide : ForgeDirection.values() )
{
IPart fPart = this.getPart( whichSide );
if( fPart != null )
2015-04-29 02:30:53 +02:00
{
fPart.getBoxes( bch );
2015-04-29 02:30:53 +02:00
}
}
AxisAlignedBB b = null;
AxisAlignedBB pb = Platform.getPrimaryBox( dir, 2 );
for( AxisAlignedBB bb : boxes )
{
if( bb.intersectsWith( pb ) )
{
if( b == null )
2015-04-29 02:30:53 +02:00
{
b = bb;
2015-04-29 02:30:53 +02:00
}
else
{
b.maxX = Math.max( b.maxX, bb.maxX );
b.maxY = Math.max( b.maxY, bb.maxY );
b.maxZ = Math.max( b.maxZ, bb.maxZ );
b.minX = Math.min( b.minX, bb.minX );
b.minY = Math.min( b.minY, bb.minY );
b.minZ = Math.min( b.minZ, bb.minZ );
}
}
}
if( b == null )
2015-04-29 02:30:53 +02:00
{
return 0;
2015-04-29 02:30:53 +02:00
}
switch( dir )
{
case WEST:
case EAST:
return this.getSize( b.minZ, b.maxZ, b.minY, b.maxY );
case DOWN:
case NORTH:
return this.getSize( b.minX, b.maxX, b.minZ, b.maxZ );
case SOUTH:
case UP:
return this.getSize( b.minX, b.maxX, b.minY, b.maxY );
default:
}
2014-09-24 02:26:27 +02:00
}
return 12;
2014-09-24 02:26:27 +02:00
}
int getSize( double a, double b, double c, double d )
2014-09-24 02:26:27 +02:00
{
double r = Math.abs( a - 0.5 );
r = Math.max( Math.abs( b - 0.5 ), r );
r = Math.max( Math.abs( c - 0.5 ), r );
return ( 8 * (int) Math.max( Math.abs( d - 0.5 ), r ) );
}
// @Override
public int getSlotMask()
{
int mask = 0;
for( ForgeDirection side : ForgeDirection.values() )
2014-09-24 02:26:27 +02:00
{
if( this.getPart( side ) != null )
2015-04-29 02:30:53 +02:00
{
mask |= 1 << side.ordinal();
2015-04-29 02:30:53 +02:00
}
else if( side != ForgeDirection.UNKNOWN && this.getFacadeContainer().getFacade( side ) != null )
2015-04-29 02:30:53 +02:00
{
mask |= 1 << side.ordinal();
2015-04-29 02:30:53 +02:00
}
2014-09-24 02:26:27 +02:00
}
return mask;
2014-09-24 02:26:27 +02:00
}
@Override
public IFacadeContainer getFacadeContainer()
2014-09-24 02:26:27 +02:00
{
return this.cb.getFacadeContainer();
2014-09-24 02:26:27 +02:00
}
@Override
public boolean canAddPart( ItemStack is, ForgeDirection side )
2014-09-24 02:26:27 +02:00
{
IFacadePart fp = PartPlacement.isFacade( is, side );
if( fp != null )
2014-09-24 02:26:27 +02:00
{
if( !( side == null || side == ForgeDirection.UNKNOWN || this.tile() == null ) )
2014-09-24 02:26:27 +02:00
{
2014-09-28 22:20:14 +02:00
List<AxisAlignedBB> boxes = new ArrayList<AxisAlignedBB>();
2014-09-24 02:26:27 +02:00
IPartCollisionHelper bch = new BusCollisionHelper( boxes, side, null, true );
fp.getBoxes( bch, null );
for( AxisAlignedBB bb : boxes )
2014-09-24 02:26:27 +02:00
{
2015-01-01 22:13:10 +01:00
DISABLE_FACADE_OCCLUSION.set( true );
2014-12-29 15:13:47 +01:00
boolean canAdd = this.tile().canAddPart( new NormallyOccludedPart( new Cuboid6( bb ) ) );
2015-01-01 22:13:10 +01:00
DISABLE_FACADE_OCCLUSION.remove();
if( !canAdd )
2014-09-24 02:26:27 +02:00
{
return false;
}
}
}
return true;
}
if( is.getItem() instanceof IPartItem )
2014-09-24 02:26:27 +02:00
{
IPartItem bi = (IPartItem) is.getItem();
is = is.copy();
is.stackSize = 1;
final IPart bp = bi.createPartFromItemStack( is );
if( !( side == null || side == ForgeDirection.UNKNOWN || this.tile() == null ) )
2014-09-24 02:26:27 +02:00
{
2014-09-28 22:20:14 +02:00
List<AxisAlignedBB> boxes = new ArrayList<AxisAlignedBB>();
2014-09-24 02:26:27 +02:00
IPartCollisionHelper bch = new BusCollisionHelper( boxes, side, null, true );
if( bp != null )
{
bp.getBoxes( bch );
}
for( AxisAlignedBB bb : boxes )
2014-09-24 02:26:27 +02:00
{
if( !this.tile().canAddPart( new NormallyOccludedPart( new Cuboid6( bb ) ) ) )
2014-09-24 02:26:27 +02:00
{
return false;
}
}
}
}
2014-12-29 15:13:47 +01:00
return this.cb.canAddPart( is, side );
2014-09-24 02:26:27 +02:00
}
@Override
public ForgeDirection addPart( ItemStack is, ForgeDirection side, EntityPlayer owner )
2014-09-24 02:26:27 +02:00
{
2014-12-29 15:13:47 +01:00
return this.cb.addPart( is, side, owner );
2014-09-24 02:26:27 +02:00
}
@Override
public IPart getPart( ForgeDirection side )
2014-09-24 02:26:27 +02:00
{
2014-12-29 15:13:47 +01:00
return this.cb.getPart( side );
2014-09-24 02:26:27 +02:00
}
@Override
public void removePart( ForgeDirection side, boolean suppressUpdate )
2014-09-24 02:26:27 +02:00
{
2014-12-29 15:13:47 +01:00
this.cb.removePart( side, suppressUpdate );
2014-09-24 02:26:27 +02:00
}
@Override
public void markForUpdate()
{
if( Platform.isServer() && this.canUpdate )
2015-04-29 02:30:53 +02:00
{
2014-12-29 15:13:47 +01:00
this.sendDescUpdate();
2015-04-29 02:30:53 +02:00
}
2014-09-24 02:26:27 +02:00
}
@Override
public DimensionalCoord getLocation()
{
2014-10-01 11:39:58 +02:00
return new DimensionalCoord( this.tile() );
2014-09-24 02:26:27 +02:00
}
@Override
public AEColor getColor()
2014-09-24 02:26:27 +02:00
{
return this.cb.getColor();
2014-09-24 02:26:27 +02:00
}
@Override
public void clearContainer()
2014-09-24 02:26:27 +02:00
{
this.cb = new CableBusContainer( this );
2014-09-24 02:26:27 +02:00
}
@Override
public boolean isBlocked( ForgeDirection side )
2014-09-24 02:26:27 +02:00
{
if( side == null || side == ForgeDirection.UNKNOWN || this.tile() == null )
2015-04-29 02:30:53 +02:00
{
2014-09-24 02:26:27 +02:00
return false;
2015-04-29 02:30:53 +02:00
}
2014-09-24 02:26:27 +02:00
2015-01-01 22:13:10 +01:00
DISABLE_FACADE_OCCLUSION.set( true );
final int ordinal = side.ordinal();
final Cuboid6 sideTest = SIDE_TESTS[ordinal];
final NormallyOccludedPart occludedPart = new NormallyOccludedPart( sideTest );
boolean blocked = !this.tile().canAddPart( occludedPart );
2015-01-01 22:13:10 +01:00
DISABLE_FACADE_OCCLUSION.remove();
2014-09-24 02:26:27 +02:00
return blocked;
}
@Override
public SelectedPart selectPart( Vec3 pos )
2014-09-24 02:26:27 +02:00
{
2014-12-29 15:13:47 +01:00
return this.cb.selectPart( pos );
2014-09-24 02:26:27 +02:00
}
@Override
public void markForSave()
{
// mark the chunk for save...
2014-10-01 11:39:58 +02:00
TileEntity te = this.tile();
2015-06-16 02:44:59 +02:00
if( te != null && te.getWorld() != null )
2015-04-29 02:30:53 +02:00
{
2015-06-16 02:44:59 +02:00
te.getWorld().getChunkFromBlockCoords( this.x(), this.z() ).isModified = true;
2015-04-29 02:30:53 +02:00
}
2014-09-24 02:26:27 +02:00
}
@Override
public void partChanged()
2014-09-24 02:26:27 +02:00
{
if( this.isInWorld() )
2015-04-29 02:30:53 +02:00
{
this.notifyNeighbors();
2015-04-29 02:30:53 +02:00
}
2014-09-24 02:26:27 +02:00
}
@Override
public boolean hasRedstone( ForgeDirection side )
2014-09-24 02:26:27 +02:00
{
return this.cb.hasRedstone( side );
2014-09-24 02:26:27 +02:00
}
@Override
public boolean isEmpty()
{
2014-12-29 15:13:47 +01:00
return this.cb.isEmpty();
2014-09-24 02:26:27 +02:00
}
@Override
public Set<LayerFlags> getLayerFlags()
{
return this.cb.getLayerFlags();
}
2014-09-24 02:26:27 +02:00
@Override
public void cleanup()
{
2014-12-29 15:13:47 +01:00
this.tile().remPart( this );
2014-09-24 02:26:27 +02:00
}
@Override
public void notifyNeighbors()
{
if( this.tile() instanceof TIInventoryTile )
2015-04-29 02:30:53 +02:00
{
( (TIInventoryTile) this.tile() ).rebuildSlotMap();
2015-04-29 02:30:53 +02:00
}
2014-09-24 02:26:27 +02:00
if( this.world() != null && this.world().blockExists( this.x(), this.y(), this.z() ) && !CableBusContainer.isLoading() )
2015-04-29 02:30:53 +02:00
{
Platform.notifyBlocksOfNeighbors( this.world(), this.x(), this.y(), this.z() );
2015-04-29 02:30:53 +02:00
}
2014-09-24 02:26:27 +02:00
}
@Override
public boolean isInWorld()
2014-09-24 02:26:27 +02:00
{
return this.cb.isInWorld();
2014-09-24 02:26:27 +02:00
}
@Override
public Iterable<Cuboid6> getCollisionBoxes()
{
LinkedList<Cuboid6> l = new LinkedList<Cuboid6>();
for( AxisAlignedBB b : this.cb.getSelectedBoundingBoxesFromPool( false, true, null, true ) )
{
l.add( new Cuboid6( b.minX, b.minY, b.minZ, b.maxX, b.maxY, b.maxZ ) );
}
return l;
}
2014-09-24 02:26:27 +02:00
@Override
public Iterable<IndexedCuboid6> getSubParts()
{
LinkedList<IndexedCuboid6> l = new LinkedList<IndexedCuboid6>();
for( Cuboid6 c : this.getCollisionBoxes() )
{
l.add( new IndexedCuboid6( 0, c ) );
}
return l;
}
2014-09-24 02:26:27 +02:00
@Override
public int getConnectionMask( int side )
{
return CONNECTION_MASK;
}
2014-09-24 02:26:27 +02:00
}