Fix rifts not rendering, fix rifts not closing, door blocks not synched
This commit is contained in:
parent
4d26a2ec31
commit
76d2f20f5d
5 changed files with 32 additions and 29 deletions
|
@ -140,7 +140,7 @@ public class CommonProxy implements IGuiHandler
|
||||||
int metadata = world.getBlockMetadata(x, y, z);
|
int metadata = world.getBlockMetadata(x, y, z);
|
||||||
TileEntityDimDoor dimTile = (TileEntityDimDoor) tile;
|
TileEntityDimDoor dimTile = (TileEntityDimDoor) tile;
|
||||||
dimTile.openOrClosed = door.isDoorOnRift(world, x, y, z)&&door.isUpperDoorBlock(metadata);
|
dimTile.openOrClosed = door.isDoorOnRift(world, x, y, z)&&door.isUpperDoorBlock(metadata);
|
||||||
dimTile.orientation = world.getBlockMetadata(x,y,z) & 7;
|
dimTile.orientation = door.func_150012_g(world, x,y,z) & 7;
|
||||||
dimTile.lockStatus = door.getLockStatus(world, x, y, z);
|
dimTile.lockStatus = door.getLockStatus(world, x, y, z);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -90,26 +90,23 @@ public abstract class BaseDimDoor extends BlockDoor implements IDimDoor, ITileEn
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
final int MAGIC_CONSTANT = 1003;
|
int metadata = this.func_150012_g(world, x, y, z);
|
||||||
|
int newMetadata = metadata & 7;
|
||||||
|
newMetadata ^= 4;
|
||||||
|
|
||||||
int metadata = world.getBlockMetadata(x, y, z);
|
if ((metadata & 8) == 0)
|
||||||
int lowMeta = metadata & 7;
|
{
|
||||||
lowMeta ^= 4;
|
world.setBlockMetadataWithNotify(x, y, z, newMetadata, 2);
|
||||||
|
world.markBlockRangeForRenderUpdate(x, y, z, x, y, z);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
world.setBlockMetadataWithNotify(x, y - 1, z, newMetadata, 2);
|
||||||
|
world.markBlockRangeForRenderUpdate(x, y - 1, z, x, y, z);
|
||||||
|
}
|
||||||
|
|
||||||
if (isUpperDoorBlock(metadata))
|
world.playAuxSFXAtEntity(player, 1003, x, y, z, 0);
|
||||||
{
|
return true;
|
||||||
world.setBlockMetadataWithNotify(x, y - 1, z, lowMeta, 2);
|
|
||||||
world.markBlockRangeForRenderUpdate(x, y - 1, z, x, y, z);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
world.setBlockMetadataWithNotify(x, y, z, lowMeta, 2);
|
|
||||||
world.markBlockRangeForRenderUpdate(x, y, z, x, y, z);
|
|
||||||
}
|
|
||||||
|
|
||||||
world.playAuxSFXAtEntity(player, MAGIC_CONSTANT, x, y, z, 0);
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -129,7 +126,7 @@ public abstract class BaseDimDoor extends BlockDoor implements IDimDoor, ITileEn
|
||||||
{
|
{
|
||||||
if (side != 1 && side != 0)
|
if (side != 1 && side != 0)
|
||||||
{
|
{
|
||||||
int fullMetadata = blockAccess.getBlockMetadata(x, y, z);
|
int fullMetadata = func_150012_g(blockAccess, x, y, z);
|
||||||
int orientation = fullMetadata & 3;
|
int orientation = fullMetadata & 3;
|
||||||
boolean reversed = false;
|
boolean reversed = false;
|
||||||
|
|
||||||
|
@ -246,7 +243,7 @@ public abstract class BaseDimDoor extends BlockDoor implements IDimDoor, ITileEn
|
||||||
@Override
|
@Override
|
||||||
public void setBlockBoundsBasedOnState(IBlockAccess par1IBlockAccess, int par2, int par3, int par4)
|
public void setBlockBoundsBasedOnState(IBlockAccess par1IBlockAccess, int par2, int par3, int par4)
|
||||||
{
|
{
|
||||||
this.setDoorRotation(par1IBlockAccess.getBlockMetadata(par2, par3, par4));
|
this.setDoorRotation(func_150012_g(par1IBlockAccess, par2, par3, par4));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -33,21 +33,27 @@ public class TileEntityDimDoor extends DDTileEntityBase
|
||||||
@Override
|
@Override
|
||||||
public Packet getDescriptionPacket()
|
public Packet getDescriptionPacket()
|
||||||
{
|
{
|
||||||
|
NBTTagCompound tag = new NBTTagCompound();
|
||||||
|
writeToNBT(tag);
|
||||||
if(PocketManager.getLink(xCoord, yCoord, zCoord, worldObj)!=null)
|
if(PocketManager.getLink(xCoord, yCoord, zCoord, worldObj)!=null)
|
||||||
{
|
{
|
||||||
ClientLinkData linkData = new ClientLinkData(PocketManager.getLink(xCoord, yCoord, zCoord, worldObj));
|
ClientLinkData linkData = new ClientLinkData(PocketManager.getLink(xCoord, yCoord, zCoord, worldObj));
|
||||||
NBTTagCompound tag = new NBTTagCompound();
|
NBTTagCompound link = new NBTTagCompound();
|
||||||
linkData.writeToNBT(tag);
|
linkData.writeToNBT(link);
|
||||||
return new S35PacketUpdateTileEntity(this.xCoord, this.yCoord, this.zCoord, 1, tag);
|
tag.setTag("Link", link);
|
||||||
}
|
}
|
||||||
return null;
|
return new S35PacketUpdateTileEntity(this.xCoord, this.yCoord, this.zCoord, 1, tag);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onDataPacket(NetworkManager net, S35PacketUpdateTileEntity pkt) {
|
public void onDataPacket(NetworkManager net, S35PacketUpdateTileEntity pkt) {
|
||||||
NBTTagCompound tag = pkt.func_148857_g();
|
NBTTagCompound tag = pkt.func_148857_g();
|
||||||
ClientLinkData linkData = ClientLinkData.readFromNBT(tag);
|
readFromNBT(tag);
|
||||||
PocketManager.getLinkWatcher().onCreated(linkData);
|
|
||||||
|
if (tag.hasKey("Link")) {
|
||||||
|
ClientLinkData linkData = ClientLinkData.readFromNBT(tag.getCompoundTag("Link"));
|
||||||
|
PocketManager.getLinkWatcher().onCreated(linkData);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -164,7 +164,7 @@ public class TileEntityRift extends DDTileEntityBase
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (growth == 0 && !worldObj.isRemote)
|
if (growth <= 0 && !worldObj.isRemote)
|
||||||
{
|
{
|
||||||
DimLink link = PocketManager.getLink(this.xCoord, this.yCoord, this.zCoord, worldObj);
|
DimLink link = PocketManager.getLink(this.xCoord, this.yCoord, this.zCoord, worldObj);
|
||||||
if (link != null)
|
if (link != null)
|
||||||
|
|
|
@ -40,7 +40,7 @@ public class ClientProxy extends CommonProxy
|
||||||
int metadata = world.getBlockMetadata(x, y, z);
|
int metadata = world.getBlockMetadata(x, y, z);
|
||||||
TileEntityDimDoor dimTile = (TileEntityDimDoor) tile;
|
TileEntityDimDoor dimTile = (TileEntityDimDoor) tile;
|
||||||
dimTile.openOrClosed = door.isDoorOnRift(world, x, y, z)&&door.isUpperDoorBlock(metadata);
|
dimTile.openOrClosed = door.isDoorOnRift(world, x, y, z)&&door.isUpperDoorBlock(metadata);
|
||||||
dimTile.orientation = world.getBlockMetadata(x, y, z) & 7;
|
dimTile.orientation = door.func_150012_g(world, x, y, z) & 7;
|
||||||
dimTile.lockStatus = door.getLockStatus(world, x, y, z);
|
dimTile.lockStatus = door.getLockStatus(world, x, y, z);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue