All terminals can now have their texture rotated based on placement ( and some with the wrench )

This commit is contained in:
AlgorithmX2 2014-07-19 16:01:24 -05:00
parent 3a10671bd6
commit 642a7f162f
4 changed files with 100 additions and 38 deletions

View file

@ -20,14 +20,17 @@ public class PartInterfaceTerminal extends PartMonitor
@Override @Override
public boolean onPartActivate(EntityPlayer player, Vec3 pos) public boolean onPartActivate(EntityPlayer player, Vec3 pos)
{ {
if ( !player.isSneaking() ) if ( !super.onPartActivate( player, pos ) )
{ {
if ( Platform.isClient() ) if ( !player.isSneaking() )
{
if ( Platform.isClient() )
return true;
Platform.openGUI( player, getHost().getTile(), side, GuiBridge.GUI_INTERFACE_TERMINAL );
return true; return true;
}
Platform.openGUI( player, getHost().getTile(), side, GuiBridge.GUI_INTERFACE_TERMINAL );
return true;
} }
return false; return false;

View file

@ -6,8 +6,12 @@ import java.io.IOException;
import net.minecraft.client.renderer.RenderBlocks; import net.minecraft.client.renderer.RenderBlocks;
import net.minecraft.client.renderer.Tessellator; import net.minecraft.client.renderer.Tessellator;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.tileentity.TileEntity; import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.MathHelper;
import net.minecraft.util.Vec3;
import net.minecraftforge.common.util.ForgeDirection; import net.minecraftforge.common.util.ForgeDirection;
import appeng.api.implementations.IPowerChannelState; import appeng.api.implementations.IPowerChannelState;
import appeng.api.implementations.parts.IPartMonitor; import appeng.api.implementations.parts.IPartMonitor;
@ -34,12 +38,76 @@ public class PartMonitor extends AEBasePart implements IPartMonitor, IPowerChann
boolean notLightSource = !this.getClass().equals( PartMonitor.class ); boolean notLightSource = !this.getClass().equals( PartMonitor.class );
final int POWERED_FLAG = 1; final int POWERED_FLAG = 4;
final int BOOTING_FLAG = 2; final int BOOTING_FLAG = 8;
final int CHANNEL_FLAG = 4; final int CHANNEL_FLAG = 16;
byte spin = 0; // 0-3
int clientFlags = 0; // sent as byte. int clientFlags = 0; // sent as byte.
@Override
public void onPlacement(EntityPlayer player, ItemStack held, ForgeDirection side)
{
super.onPlacement( player, held, side );
byte rotation = (byte) (MathHelper.floor_double( (double) ((player.rotationYaw * 4F) / 360F) + 2.5D ) & 3);
if ( side == ForgeDirection.UP )
spin = rotation;
else if ( side == ForgeDirection.DOWN )
spin = rotation;
}
@Override
public void writeToNBT(NBTTagCompound data)
{
super.writeToNBT( data );
data.setByte( "spin", (byte) spin );
}
@Override
public void readFromNBT(NBTTagCompound data)
{
super.readFromNBT( data );
spin = data.getByte( "spin" );
}
@Override
public boolean onPartActivate(EntityPlayer player, Vec3 pos)
{
TileEntity te = getTile();
if ( !player.isSneaking() && Platform.isWrench( player, player.inventory.getCurrentItem(), te.xCoord, te.yCoord, te.zCoord ) )
{
if ( Platform.isServer() )
{
if ( spin > 3 )
spin = 0;
switch (spin)
{
case 0:
spin = 1;
break;
case 1:
spin = 3;
break;
case 2:
spin = 0;
break;
case 3:
spin = 2;
break;
}
this.host.markForUpdate();
this.saveChanges();
}
return true;
}
else
return super.onPartActivate( player, pos );
}
@MENetworkEventSubscribe @MENetworkEventSubscribe
public void bootingRender(MENetworkBootingStatusChange c) public void bootingRender(MENetworkBootingStatusChange c)
{ {
@ -63,7 +131,8 @@ public class PartMonitor extends AEBasePart implements IPartMonitor, IPowerChann
public void writeToStream(ByteBuf data) throws IOException public void writeToStream(ByteBuf data) throws IOException
{ {
super.writeToStream( data ); super.writeToStream( data );
clientFlags = 0; clientFlags = spin & 3;
;
try try
{ {
@ -90,6 +159,7 @@ public class PartMonitor extends AEBasePart implements IPartMonitor, IPowerChann
super.readFromStream( data ); super.readFromStream( data );
int oldFlags = clientFlags; int oldFlags = clientFlags;
clientFlags = data.readByte(); clientFlags = data.readByte();
spin = (byte) (clientFlags & 3);
if ( clientFlags == oldFlags ) if ( clientFlags == oldFlags )
return false; return false;
return true; return true;
@ -179,6 +249,8 @@ public class PartMonitor extends AEBasePart implements IPartMonitor, IPowerChann
Tessellator.instance.setBrightness( l << 20 | l << 4 ); Tessellator.instance.setBrightness( l << 20 | l << 4 );
} }
renderer.uvRotateBottom = renderer.uvRotateEast = renderer.uvRotateNorth = renderer.uvRotateSouth = renderer.uvRotateTop = renderer.uvRotateWest = this.spin;
Tessellator.instance.setColorOpaque_I( getColor().whiteVariant ); Tessellator.instance.setColorOpaque_I( getColor().whiteVariant );
rh.renderFace( x, y, z, frontBright.getIcon(), ForgeDirection.SOUTH, renderer ); rh.renderFace( x, y, z, frontBright.getIcon(), ForgeDirection.SOUTH, renderer );
@ -188,6 +260,8 @@ public class PartMonitor extends AEBasePart implements IPartMonitor, IPowerChann
Tessellator.instance.setColorOpaque_I( getColor().blackVariant ); Tessellator.instance.setColorOpaque_I( getColor().blackVariant );
rh.renderFace( x, y, z, frontColored.getIcon(), ForgeDirection.SOUTH, renderer ); rh.renderFace( x, y, z, frontColored.getIcon(), ForgeDirection.SOUTH, renderer );
renderer.uvRotateBottom = renderer.uvRotateEast = renderer.uvRotateNorth = renderer.uvRotateSouth = renderer.uvRotateTop = renderer.uvRotateWest = 0;
if ( notLightSource ) if ( notLightSource )
{ {
rh.setTexture( CableBusTextures.PartMonitorSidesStatus.getIcon(), CableBusTextures.PartMonitorSidesStatus.getIcon(), rh.setTexture( CableBusTextures.PartMonitorSidesStatus.getIcon(), CableBusTextures.PartMonitorSidesStatus.getIcon(),

View file

@ -14,7 +14,6 @@ import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
import net.minecraft.nbt.NBTTagCompound; import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.tileentity.TileEntity; import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.MathHelper;
import net.minecraft.util.MovingObjectPosition; import net.minecraft.util.MovingObjectPosition;
import net.minecraft.util.Vec3; import net.minecraft.util.Vec3;
import net.minecraftforge.common.util.ForgeDirection; import net.minecraftforge.common.util.ForgeDirection;
@ -45,29 +44,14 @@ import cpw.mods.fml.relauncher.SideOnly;
public class PartStorageMonitor extends PartMonitor implements IPartStorageMonitor, IStackWatcherHost public class PartStorageMonitor extends PartMonitor implements IPartStorageMonitor, IStackWatcherHost
{ {
byte spin;
IAEItemStack configuredItem; IAEItemStack configuredItem;
boolean isLocked; boolean isLocked;
@Override
public void onPlacement(EntityPlayer player, ItemStack held, ForgeDirection side)
{
super.onPlacement( player, held, side );
byte rotation = (byte) (MathHelper.floor_double( (double) ((player.rotationYaw * 4F) / 360F) + 2.5D ) & 3);
if ( side == ForgeDirection.UP )
spin = rotation;
else if ( side == ForgeDirection.DOWN )
spin = rotation;
}
@Override @Override
public void writeToNBT(NBTTagCompound data) public void writeToNBT(NBTTagCompound data)
{ {
super.writeToNBT( data ); super.writeToNBT( data );
data.setByte( "spin", spin );
data.setBoolean( "isLocked", isLocked ); data.setBoolean( "isLocked", isLocked );
NBTTagCompound myItem = new NBTTagCompound(); NBTTagCompound myItem = new NBTTagCompound();
@ -82,7 +66,6 @@ public class PartStorageMonitor extends PartMonitor implements IPartStorageMonit
{ {
super.readFromNBT( data ); super.readFromNBT( data );
spin = data.getByte( "spin" );
isLocked = data.getBoolean( "isLocked" ); isLocked = data.getBoolean( "isLocked" );
NBTTagCompound myItem = data.getCompoundTag( "configuredItem" ); NBTTagCompound myItem = data.getCompoundTag( "configuredItem" );

View file

@ -32,7 +32,7 @@ public class PartTerminal extends PartMonitor implements ITerminalHost, IConfigM
AppEngInternalInventory viewCell = new AppEngInternalInventory( this, 5 ); AppEngInternalInventory viewCell = new AppEngInternalInventory( this, 5 );
public PartTerminal(Class clz, ItemStack is) { public PartTerminal(Class clz, ItemStack is) {
super( clz, is,true ); super( clz, is, true );
cm.registerSetting( Settings.SORT_BY, SortOrder.NAME ); cm.registerSetting( Settings.SORT_BY, SortOrder.NAME );
cm.registerSetting( Settings.VIEW_MODE, ViewItems.ALL ); cm.registerSetting( Settings.VIEW_MODE, ViewItems.ALL );
@ -42,8 +42,8 @@ public class PartTerminal extends PartMonitor implements ITerminalHost, IConfigM
@Override @Override
public void getDrops(List<ItemStack> drops, boolean wrenched) public void getDrops(List<ItemStack> drops, boolean wrenched)
{ {
super.getDrops(drops, wrenched); super.getDrops( drops, wrenched );
for (ItemStack is : viewCell) for (ItemStack is : viewCell)
if ( is != null ) if ( is != null )
drops.add( is ); drops.add( is );
@ -66,7 +66,7 @@ public class PartTerminal extends PartMonitor implements ITerminalHost, IConfigM
} }
public PartTerminal(ItemStack is) { public PartTerminal(ItemStack is) {
super( PartTerminal.class, is,true ); super( PartTerminal.class, is, true );
frontBright = CableBusTextures.PartTerminal_Bright; frontBright = CableBusTextures.PartTerminal_Bright;
frontColored = CableBusTextures.PartTerminal_Colored; frontColored = CableBusTextures.PartTerminal_Colored;
frontDark = CableBusTextures.PartTerminal_Dark; frontDark = CableBusTextures.PartTerminal_Dark;
@ -85,16 +85,18 @@ public class PartTerminal extends PartMonitor implements ITerminalHost, IConfigM
@Override @Override
public boolean onPartActivate(EntityPlayer player, Vec3 pos) public boolean onPartActivate(EntityPlayer player, Vec3 pos)
{ {
if ( !player.isSneaking() ) if ( !super.onPartActivate( player, pos ) )
{ {
if ( Platform.isClient() ) if ( !player.isSneaking() )
{
if ( Platform.isClient() )
return true;
Platform.openGUI( player, getHost().getTile(), side, getGui() );
return true; return true;
}
Platform.openGUI( player, getHost().getTile(), side, getGui() );
return true;
} }
return false; return false;
} }