2013-12-27 23:59:59 +01:00
|
|
|
package appeng.block.networking;
|
|
|
|
|
|
|
|
import java.util.EnumSet;
|
|
|
|
import java.util.List;
|
|
|
|
import java.util.Random;
|
|
|
|
|
2014-01-29 04:10:23 +01:00
|
|
|
import net.minecraft.block.Block;
|
2013-12-27 23:59:59 +01:00
|
|
|
import net.minecraft.block.material.Material;
|
|
|
|
import net.minecraft.client.renderer.texture.IconRegister;
|
|
|
|
import net.minecraft.creativetab.CreativeTabs;
|
|
|
|
import net.minecraft.entity.Entity;
|
2013-12-28 21:54:05 +01:00
|
|
|
import net.minecraft.entity.EntityLivingBase;
|
2013-12-27 23:59:59 +01:00
|
|
|
import net.minecraft.entity.player.EntityPlayer;
|
|
|
|
import net.minecraft.item.ItemStack;
|
|
|
|
import net.minecraft.tileentity.TileEntity;
|
|
|
|
import net.minecraft.util.Icon;
|
|
|
|
import net.minecraft.util.MovingObjectPosition;
|
|
|
|
import net.minecraft.util.Vec3;
|
|
|
|
import net.minecraft.world.IBlockAccess;
|
|
|
|
import net.minecraft.world.World;
|
|
|
|
import net.minecraftforge.common.ForgeDirection;
|
2014-01-20 17:41:37 +01:00
|
|
|
import appeng.api.parts.PartItemStack;
|
2013-12-27 23:59:59 +01:00
|
|
|
import appeng.api.parts.SelectedPart;
|
|
|
|
import appeng.block.AEBaseBlock;
|
|
|
|
import appeng.client.render.BaseBlockRender;
|
|
|
|
import appeng.client.render.blocks.RendererCableBus;
|
|
|
|
import appeng.client.texture.CableBusTextures;
|
|
|
|
import appeng.core.Api;
|
|
|
|
import appeng.core.AppEng;
|
2014-01-20 17:41:37 +01:00
|
|
|
import appeng.core.CommonHelper;
|
2013-12-27 23:59:59 +01:00
|
|
|
import appeng.core.features.AEFeature;
|
|
|
|
import appeng.integration.abstraction.IFMP;
|
2014-01-20 17:41:37 +01:00
|
|
|
import appeng.parts.ICableBusContainer;
|
|
|
|
import appeng.parts.NullCableBusContainer;
|
2013-12-27 23:59:59 +01:00
|
|
|
import appeng.tile.AEBaseTile;
|
|
|
|
import appeng.tile.networking.TileCableBus;
|
2014-01-28 20:27:22 +01:00
|
|
|
import appeng.util.Platform;
|
2013-12-27 23:59:59 +01:00
|
|
|
|
|
|
|
public class BlockCableBus extends AEBaseBlock
|
|
|
|
{
|
|
|
|
|
2014-01-20 17:41:37 +01:00
|
|
|
static private ICableBusContainer nullCB = new NullCableBusContainer();
|
|
|
|
|
2013-12-27 23:59:59 +01:00
|
|
|
public BlockCableBus() {
|
|
|
|
super( BlockCableBus.class, Material.glass );
|
|
|
|
setfeature( EnumSet.of( AEFeature.Core ) );
|
|
|
|
setLightOpacity( 0 );
|
|
|
|
isFullSize = isOpaque = false;
|
|
|
|
}
|
|
|
|
|
2013-12-28 21:54:05 +01:00
|
|
|
@Override
|
|
|
|
public boolean isLadder(World world, int x, int y, int z, EntityLivingBase entity)
|
|
|
|
{
|
2014-01-20 17:41:37 +01:00
|
|
|
return cb( world, x, y, z ).isLadder( entity );
|
2013-12-28 21:54:05 +01:00
|
|
|
}
|
|
|
|
|
2013-12-27 23:59:59 +01:00
|
|
|
@Override
|
|
|
|
public boolean recolourBlock(World world, int x, int y, int z, ForgeDirection side, int colour)
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
return cb( world, x, y, z ).recolourBlock( side, colour );
|
|
|
|
}
|
|
|
|
catch (Throwable t)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void randomDisplayTick(World world, int x, int y, int z, Random r)
|
|
|
|
{
|
2014-01-20 17:41:37 +01:00
|
|
|
cb( world, x, y, z ).randomDisplayTick( world, x, y, z, r );
|
2013-12-27 23:59:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public int getLightValue(IBlockAccess world, int x, int y, int z)
|
|
|
|
{
|
2014-01-29 04:10:23 +01:00
|
|
|
Block block = blocksList[world.getBlockId( x, y, z )];
|
|
|
|
if ( block != null && block != this )
|
|
|
|
{
|
|
|
|
return block.getLightValue( world, x, y, z );
|
|
|
|
}
|
|
|
|
if ( block == null )
|
|
|
|
return 0;
|
2014-01-20 17:41:37 +01:00
|
|
|
return cb( world, x, y, z ).getLightValue();
|
2013-12-27 23:59:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public ItemStack getPickBlock(MovingObjectPosition target, World world, int x, int y, int z)
|
|
|
|
{
|
|
|
|
Vec3 v3 = target.hitVec.addVector( -x, -y, -z );
|
|
|
|
SelectedPart sp = cb( world, x, y, z ).selectPart( v3 );
|
2014-01-20 17:41:37 +01:00
|
|
|
|
|
|
|
if ( sp.part != null )
|
|
|
|
return sp.part.getItemStack( PartItemStack.Break );
|
|
|
|
else if ( sp.facade != null )
|
|
|
|
return sp.facade.getItemStack();
|
|
|
|
|
2013-12-27 23:59:59 +01:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean isBlockReplaceable(World world, int x, int y, int z)
|
|
|
|
{
|
|
|
|
return cb( world, x, y, z ).isEmpty();
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean removeBlockByPlayer(World world, EntityPlayer player, int x, int y, int z)
|
|
|
|
{
|
|
|
|
if ( player.capabilities.isCreativeMode )
|
|
|
|
{
|
|
|
|
AEBaseTile tile = getTileEntity( world, x, y, z );
|
|
|
|
if ( tile != null )
|
|
|
|
tile.dropItems = false;
|
|
|
|
// maybe ray trace?
|
|
|
|
}
|
|
|
|
return super.removeBlockByPlayer( world, player, x, y, z );
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public Icon getBlockTexture(IBlockAccess w, int x, int y, int z, int s)
|
|
|
|
{
|
|
|
|
return getIcon( s, 0 );
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public Icon getIcon(int direction, int metadata)
|
|
|
|
{
|
|
|
|
Icon i = super.getIcon( direction, metadata );
|
|
|
|
if ( i != null )
|
|
|
|
return i;
|
|
|
|
|
2014-01-20 17:41:37 +01:00
|
|
|
return CableBusTextures.getMissing();
|
2013-12-27 23:59:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected Class<? extends BaseBlockRender> getRenderer()
|
|
|
|
{
|
|
|
|
return RendererCableBus.class;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void registerIcons(IconRegister iconRegistry)
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean canProvidePower()
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean isBlockSolidOnSide(World w, int x, int y, int z, ForgeDirection side)
|
|
|
|
{
|
|
|
|
return cb( w, x, y, z ).isSolidOnSide( side );
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onNeighborBlockChange(World w, int x, int y, int z, int meh)
|
|
|
|
{
|
|
|
|
cb( w, x, y, z ).onNeighborChanged();
|
|
|
|
}
|
|
|
|
|
2014-01-01 07:30:52 +01:00
|
|
|
@Override
|
|
|
|
public int idDropped(int i, Random r, int k)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2013-12-27 23:59:59 +01:00
|
|
|
@Override
|
|
|
|
public boolean onActivated(World w, int x, int y, int z, EntityPlayer player, int side, float hitX, float hitY, float hitZ)
|
|
|
|
{
|
|
|
|
return cb( w, x, y, z ).activate( player, w.getWorldVec3Pool().getVecFromPool( hitX, hitY, hitZ ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onEntityCollidedWithBlock(World w, int x, int y, int z, Entity e)
|
|
|
|
{
|
|
|
|
cb( w, x, y, z ).onEntityCollision( e );
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean canConnectRedstone(IBlockAccess w, int x, int y, int z, int side)
|
|
|
|
{
|
2014-01-06 07:54:51 +01:00
|
|
|
switch (side)
|
|
|
|
{
|
|
|
|
case -1:
|
|
|
|
case 4:
|
|
|
|
return cb( w, x, y, z ).canConnectRedstone( EnumSet.of( ForgeDirection.UP, ForgeDirection.DOWN ) );
|
|
|
|
case 0:
|
|
|
|
return cb( w, x, y, z ).canConnectRedstone( EnumSet.of( ForgeDirection.NORTH ) );
|
|
|
|
case 1:
|
|
|
|
return cb( w, x, y, z ).canConnectRedstone( EnumSet.of( ForgeDirection.EAST ) );
|
|
|
|
case 2:
|
|
|
|
return cb( w, x, y, z ).canConnectRedstone( EnumSet.of( ForgeDirection.SOUTH ) );
|
|
|
|
case 3:
|
|
|
|
return cb( w, x, y, z ).canConnectRedstone( EnumSet.of( ForgeDirection.WEST ) );
|
|
|
|
}
|
|
|
|
return false;
|
2013-12-27 23:59:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public int isProvidingWeakPower(IBlockAccess w, int x, int y, int z, int side)
|
|
|
|
{
|
2014-01-06 07:54:51 +01:00
|
|
|
return cb( w, x, y, z ).isProvidingWeakPower( ForgeDirection.getOrientation( side ).getOpposite() );
|
2013-12-27 23:59:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public int isProvidingStrongPower(IBlockAccess w, int x, int y, int z, int side)
|
|
|
|
{
|
2014-01-06 07:54:51 +01:00
|
|
|
return cb( w, x, y, z ).isProvidingStrongPower( ForgeDirection.getOrientation( side ).getOpposite() );
|
2013-12-27 23:59:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void getSubBlocks(int par1, CreativeTabs par2CreativeTabs, List par3List)
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public void setupTile()
|
|
|
|
{
|
|
|
|
setTileEntiy( Api.instance.partHelper.getCombinedInstance( TileCableBus.class.getName() ) );
|
2014-01-28 20:27:22 +01:00
|
|
|
if ( Platform.isClient() )
|
|
|
|
CommonHelper.proxy.bindTileEntitySpecialRenderer( getTileEntityClass(), this );
|
2014-01-20 17:41:37 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
private ICableBusContainer cb(IBlockAccess w, int x, int y, int z)
|
|
|
|
{
|
|
|
|
TileEntity te = w.getBlockTileEntity( x, y, z );
|
|
|
|
if ( te instanceof TileCableBus )
|
|
|
|
return ((TileCableBus) te).cb;
|
|
|
|
|
|
|
|
if ( AppEng.instance.isIntegrationEnabled( "FMP" ) )
|
|
|
|
return ((IFMP) AppEng.instance.getIntegration( "FMP" )).getCableContainer( te );
|
|
|
|
|
|
|
|
return nullCB;
|
2013-12-27 23:59:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|