Fix door relative rotation (dungeon schematics will have to be fixed too)
This commit is contained in:
parent
24c02fba5d
commit
599804a914
5 changed files with 12 additions and 5 deletions
|
@ -121,7 +121,7 @@ public abstract class BlockDimensionalDoor extends BlockDoor implements IRiftPro
|
||||||
@Override
|
@Override
|
||||||
public TileEntityEntranceRift createNewTileEntity(World world, int meta) {
|
public TileEntityEntranceRift createNewTileEntity(World world, int meta) {
|
||||||
TileEntityEntranceRift rift = new TileEntityEntranceRift();
|
TileEntityEntranceRift rift = new TileEntityEntranceRift();
|
||||||
rift.orientation = getStateFromMeta(meta).getValue(BlockDoor.FACING).getOpposite();
|
rift.setOrientation(getStateFromMeta(meta).getValue(BlockDoor.FACING).getOpposite());
|
||||||
rift.extendUp += 1;
|
rift.extendUp += 1;
|
||||||
return rift;
|
return rift;
|
||||||
}
|
}
|
||||||
|
|
|
@ -69,7 +69,7 @@ public class BlockDimensionalPortal extends BlockDimensionalDoor { // TODO: conv
|
||||||
@Override
|
@Override
|
||||||
public TileEntityEntranceRift createNewTileEntity(World world, int meta) {
|
public TileEntityEntranceRift createNewTileEntity(World world, int meta) {
|
||||||
TileEntityEntranceRift rift = new TileEntityEntranceRift();
|
TileEntityEntranceRift rift = new TileEntityEntranceRift();
|
||||||
rift.orientation = getStateFromMeta(meta).getValue(BlockDoor.FACING).getOpposite();
|
rift.setOrientation(getStateFromMeta(meta).getValue(BlockDoor.FACING).getOpposite());
|
||||||
rift.extendUp += 1;
|
rift.extendUp += 1;
|
||||||
rift.pushIn = 0.5;
|
rift.pushIn = 0.5;
|
||||||
return rift;
|
return rift;
|
||||||
|
|
|
@ -59,7 +59,7 @@ public abstract class BlockDimensionalTrapdoor extends BlockTrapDoor implements
|
||||||
@Override
|
@Override
|
||||||
public TileEntityEntranceRift createNewTileEntity(World world, int meta) {
|
public TileEntityEntranceRift createNewTileEntity(World world, int meta) {
|
||||||
TileEntityEntranceRift rift = new TileEntityEntranceRift();
|
TileEntityEntranceRift rift = new TileEntityEntranceRift();
|
||||||
rift.orientation = EnumFacing.UP;
|
rift.setOrientation(EnumFacing.UP);
|
||||||
return rift;
|
return rift;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -188,7 +188,7 @@ import javax.annotation.Nonnull;
|
||||||
|
|
||||||
// Attempt a teleport
|
// Attempt a teleport
|
||||||
try {
|
try {
|
||||||
if (destination.teleport(new RotatedLocation(new Location(world, pos), yaw, pitch), entity)) {
|
if (destination.teleport(new RotatedLocation(new Location(world, pos), yaw, pitch), entity)) { // TODO: yaw should be player's yaw % 90 for floating rifts
|
||||||
VirtualLocation vloc = VirtualLocation.fromLocation(new Location(entity.world, entity.getPosition()));
|
VirtualLocation vloc = VirtualLocation.fromLocation(new Location(entity.world, entity.getPosition()));
|
||||||
DimDoors.sendTranslatedMessage(entity, "You are at x = " + vloc.getX() + ", y = ?, z = " + vloc.getZ() + ", w = " + vloc.getDepth());
|
DimDoors.sendTranslatedMessage(entity, "You are at x = " + vloc.getX() + ", y = ?, z = " + vloc.getZ() + ", w = " + vloc.getDepth());
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -59,6 +59,12 @@ import java.util.Random;
|
||||||
public void setLockStatus(byte lockStatus) { this.lockStatus = lockStatus; markDirty(); }
|
public void setLockStatus(byte lockStatus) { this.lockStatus = lockStatus; markDirty(); }
|
||||||
public void setCloseAfterPassThrough(boolean closeAfterPassThrough) { this.closeAfterPassThrough = closeAfterPassThrough; markDirty(); }
|
public void setCloseAfterPassThrough(boolean closeAfterPassThrough) { this.closeAfterPassThrough = closeAfterPassThrough; markDirty(); }
|
||||||
|
|
||||||
|
public void setOrientation(EnumFacing orientation) {
|
||||||
|
this.orientation = orientation;
|
||||||
|
yaw = orientation.getHorizontalAngle();
|
||||||
|
pitch = orientation.getFrontOffsetY() * 90;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean teleport(Entity entity) {
|
public boolean teleport(Entity entity) {
|
||||||
boolean status = super.teleport(entity);
|
boolean status = super.teleport(entity);
|
||||||
|
@ -72,7 +78,8 @@ import java.util.Random;
|
||||||
@Override
|
@Override
|
||||||
public void teleportTo(Entity entity, float fromYaw, float fromPitch) {
|
public void teleportTo(Entity entity, float fromYaw, float fromPitch) {
|
||||||
if (relativeRotation) {
|
if (relativeRotation) {
|
||||||
TeleportUtils.teleport(entity, new Location(world, pos.offset(orientation, tpOffset)), orientation.getHorizontalAngle() + entity.rotationYaw - fromYaw, entity.rotationPitch - fromPitch);
|
TeleportUtils.teleport(entity, new Location(world, pos.offset(orientation, tpOffset)), orientation.getHorizontalAngle() + entity.rotationYaw - fromYaw, entity.rotationPitch);
|
||||||
|
// TODO: velocity
|
||||||
} else {
|
} else {
|
||||||
teleportTo(entity);
|
teleportTo(entity);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue