More work on BaseDimDoor. Corrected mistake in CommonProxy.
This commit is contained in:
parent
e6cc4c292f
commit
563c950c17
3 changed files with 35 additions and 53 deletions
|
@ -74,6 +74,7 @@ public class CommonProxy {
|
||||||
TileEntityDimDoor dimTile = (TileEntityDimDoor) tile;
|
TileEntityDimDoor dimTile = (TileEntityDimDoor) tile;
|
||||||
dimTile.openOrClosed = door.isDoorOnRift(world, pos) && door.isUpperDoorBlock(state);
|
dimTile.openOrClosed = door.isDoorOnRift(world, pos) && door.isUpperDoorBlock(state);
|
||||||
dimTile.orientation = state.getValue(BlockDoor.FACING).rotateY().getHorizontalIndex();
|
dimTile.orientation = state.getValue(BlockDoor.FACING).rotateY().getHorizontalIndex();
|
||||||
|
if(state.getValue(BlockDoor.OPEN)) dimTile.orientation |= 4;
|
||||||
dimTile.lockStatus = door.getLockStatus(world, pos);
|
dimTile.lockStatus = door.getLockStatus(world, pos);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,6 +17,7 @@ import net.minecraft.item.Item;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import net.minecraft.util.BlockPos;
|
import net.minecraft.util.BlockPos;
|
||||||
|
import net.minecraft.util.EnumFacing;
|
||||||
import net.minecraft.util.MathHelper;
|
import net.minecraft.util.MathHelper;
|
||||||
import net.minecraft.util.MovingObjectPosition;
|
import net.minecraft.util.MovingObjectPosition;
|
||||||
import net.minecraft.world.IBlockAccess;
|
import net.minecraft.world.IBlockAccess;
|
||||||
|
@ -36,66 +37,45 @@ public abstract class BaseDimDoor extends BlockDoor implements IDimDoor, ITileEn
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onEntityCollidedWithBlock(World world, int x, int y, int z, Entity entity)
|
public void onEntityCollidedWithBlock(World world, BlockPos pos, Entity entity) {
|
||||||
{
|
enterDimDoor(world, pos, entity);
|
||||||
this.enterDimDoor(world, x, y, z, entity);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onBlockActivated(World world, int x, int y, int z, EntityPlayer player, int side, float hitX, float hitY, float hitZ)
|
public boolean onBlockActivated(World world, BlockPos pos, IBlockState state, EntityPlayer player,
|
||||||
{
|
EnumFacing side, float hitX, float hitY, float hitZ) {
|
||||||
|
|
||||||
ItemStack stack = player.inventory.getCurrentItem();
|
ItemStack stack = player.inventory.getCurrentItem();
|
||||||
if (stack != null && stack.getItem() instanceof ItemDDKey)
|
if (stack != null && stack.getItem() instanceof ItemDDKey) {return false;}
|
||||||
{
|
|
||||||
return false;
|
if(!checkCanOpen(world, pos, player)) {return false;}
|
||||||
|
|
||||||
|
if(state.getValue(BlockDoor.HALF) == EnumDoorHalf.UPPER) {
|
||||||
|
pos = pos.down();
|
||||||
|
state = world.getBlockState(pos);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!checkCanOpen(world, x, y, z, player))
|
if(state.getBlock() != this) return false;
|
||||||
{
|
else {
|
||||||
return false;
|
state = state.cycleProperty(BlockDoor.OPEN);
|
||||||
}
|
world.setBlockState(pos, state, 2);
|
||||||
|
world.markBlockRangeForRenderUpdate(pos, pos.up());
|
||||||
int metadata = this.func_150012_g(world, x, y, z);
|
world.playAuxSFXAtEntity(player, state.getValue(BlockDoor.OPEN) ? 1003 : 1006, pos, 0);
|
||||||
int newMetadata = metadata & 7;
|
|
||||||
newMetadata ^= 4;
|
|
||||||
|
|
||||||
if ((metadata & 8) == 0)
|
|
||||||
{
|
|
||||||
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);
|
|
||||||
}
|
|
||||||
|
|
||||||
world.playAuxSFXAtEntity(player, 1003, x, y, z, 0);
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onBlockAdded(World world, int x, int y, int z)
|
public void onBlockAdded(World world, BlockPos pos, IBlockState state) {
|
||||||
{
|
placeLink(world, pos);
|
||||||
this.placeLink(world, x, y, z);
|
world.setTileEntity(pos, createNewTileEntity(world, 0));
|
||||||
world.setTileEntity(x, y, z, this.createNewTileEntity(world, world.getBlockMetadata(x, y, z)));
|
updateAttachedTile(world, pos);
|
||||||
this.updateAttachedTile(world, x, y, z);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Called to update the render information on the tile entity. Could probably implement a data watcher,
|
//Called to update the render information on the tile entity. Could probably implement a data watcher,
|
||||||
//but this works fine and is more versatile I think.
|
//but this works fine and is more versatile I think.
|
||||||
public BaseDimDoor updateAttachedTile(World world, int x, int y, int z)
|
public BaseDimDoor updateAttachedTile(World world, BlockPos pos) {
|
||||||
{
|
DimDoors.proxy.updateDoorTE(this, world, pos);
|
||||||
DimDoors.proxy.updateDoorTE(this, world, x, y, z);
|
|
||||||
TileEntity tile = world.getTileEntity(x, y, z);
|
|
||||||
if (tile instanceof TileEntityDimDoor)
|
|
||||||
{
|
|
||||||
int metadata = world.getBlockMetadata(x, y, z);
|
|
||||||
TileEntityDimDoor dimTile = (TileEntityDimDoor) tile;
|
|
||||||
dimTile.openOrClosed = isDoorOnRift(world, x, y, z) && isUpperDoorBlock(metadata);
|
|
||||||
dimTile.orientation = this.func_150012_g(world, x, y, z) & 7;
|
|
||||||
}
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -304,7 +284,7 @@ public abstract class BaseDimDoor extends BlockDoor implements IDimDoor, ITileEn
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void enterDimDoor(World world, int x, int y, int z, Entity entity)
|
public void enterDimDoor(World world, BlockPos pos, Entity entity)
|
||||||
{
|
{
|
||||||
// FX entities dont exist on the server
|
// FX entities dont exist on the server
|
||||||
if (world.isRemote)
|
if (world.isRemote)
|
||||||
|
@ -386,14 +366,14 @@ public abstract class BaseDimDoor extends BlockDoor implements IDimDoor, ITileEn
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public boolean checkCanOpen(World world, int x, int y, int z)
|
public boolean checkCanOpen(World world, BlockPos pos)
|
||||||
{
|
{
|
||||||
return this.checkCanOpen(world, x, y, z, null);
|
return this.checkCanOpen(world, pos, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean checkCanOpen(World world, int x, int y, int z, EntityPlayer player)
|
public boolean checkCanOpen(World world, BlockPos pos, EntityPlayer player)
|
||||||
{
|
{
|
||||||
DimLink link = getLink(world, x, y, z);
|
DimLink link = getLink(world, pos);
|
||||||
if(link==null||player==null)
|
if(link==null||player==null)
|
||||||
{
|
{
|
||||||
return link==null;
|
return link==null;
|
||||||
|
|
|
@ -3,6 +3,7 @@ package com.zixiken.dimdoors.blocks;
|
||||||
import net.minecraft.entity.Entity;
|
import net.minecraft.entity.Entity;
|
||||||
import net.minecraft.item.Item;
|
import net.minecraft.item.Item;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
|
import net.minecraft.util.BlockPos;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
public interface IDimDoor
|
public interface IDimDoor
|
||||||
|
@ -15,7 +16,7 @@ public interface IDimDoor
|
||||||
* @param z
|
* @param z
|
||||||
* @param entity
|
* @param entity
|
||||||
*/
|
*/
|
||||||
public void enterDimDoor(World world, int x, int y, int z, Entity entity);
|
public void enterDimDoor(World world, BlockPos pos, Entity entity);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* called when a door is placed to determine how it will place a link
|
* called when a door is placed to determine how it will place a link
|
||||||
|
@ -24,11 +25,11 @@ public interface IDimDoor
|
||||||
* @param y
|
* @param y
|
||||||
* @param z
|
* @param z
|
||||||
*/
|
*/
|
||||||
public void placeLink(World world, int x, int y, int z);
|
public void placeLink(World world, BlockPos pos);
|
||||||
|
|
||||||
public Item getDoorItem();
|
public Item getDoorItem();
|
||||||
|
|
||||||
public TileEntity initDoorTE(World world, int x, int y, int z);
|
public TileEntity initDoorTE(World world, BlockPos pos);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* checks if any of this doors blocks are overlapping with a rift
|
* checks if any of this doors blocks are overlapping with a rift
|
||||||
|
@ -38,6 +39,6 @@ public interface IDimDoor
|
||||||
* @param z
|
* @param z
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
public boolean isDoorOnRift(World world, int x, int y, int z);
|
public boolean isDoorOnRift(World world, BlockPos pos);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue