mirror of
https://github.com/Jozufozu/Flywheel.git
synced 2025-01-15 23:55:53 +01:00
Assemble gantry carriage when shaft is extended
This commit is contained in:
parent
305b16fea9
commit
d0040260d7
2 changed files with 26 additions and 10 deletions
|
@ -98,7 +98,7 @@ public class GantryShaftBlock extends DirectionalKineticBlock {
|
||||||
return state;
|
return state;
|
||||||
boolean connect = AllBlocks.GANTRY_SHAFT.has(neighbour) && neighbour.get(FACING) == facing;
|
boolean connect = AllBlocks.GANTRY_SHAFT.has(neighbour) && neighbour.get(FACING) == facing;
|
||||||
|
|
||||||
Part part = state.get(PART);
|
Part part = state.get(PART), prevPart = part;
|
||||||
if (direction.getAxisDirection() == facing.getAxisDirection()) {
|
if (direction.getAxisDirection() == facing.getAxisDirection()) {
|
||||||
if (connect) {
|
if (connect) {
|
||||||
if (part == Part.END)
|
if (part == Part.END)
|
||||||
|
@ -125,6 +125,13 @@ public class GantryShaftBlock extends DirectionalKineticBlock {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!world.isRemote() && part == Part.MIDDLE && prevPart != Part.MIDDLE) {
|
||||||
|
TileEntity te = world.getTileEntity(pos);
|
||||||
|
if (te instanceof GantryShaftTileEntity) {
|
||||||
|
((GantryShaftTileEntity)te).checkAttachedCarriageBlocks(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return state.with(PART, part);
|
return state.with(PART, part);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -19,11 +19,8 @@ public class GantryShaftTileEntity extends KineticTileEntity {
|
||||||
super(typeIn);
|
super(typeIn);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
public void checkAttachedCarriageBlocks(boolean willBeMiddle) {
|
||||||
public void onSpeedChanged(float previousSpeed) {
|
if (!canAssembleOn(willBeMiddle))
|
||||||
super.onSpeedChanged(previousSpeed);
|
|
||||||
|
|
||||||
if (!canAssembleOn())
|
|
||||||
return;
|
return;
|
||||||
for (Direction d : Iterate.directions) {
|
for (Direction d : Iterate.directions) {
|
||||||
if (d.getAxis() == getBlockState().get(GantryShaftBlock.FACING)
|
if (d.getAxis() == getBlockState().get(GantryShaftBlock.FACING)
|
||||||
|
@ -39,7 +36,12 @@ public class GantryShaftTileEntity extends KineticTileEntity {
|
||||||
if (tileEntity instanceof GantryCarriageTileEntity)
|
if (tileEntity instanceof GantryCarriageTileEntity)
|
||||||
((GantryCarriageTileEntity) tileEntity).queueAssembly();
|
((GantryCarriageTileEntity) tileEntity).queueAssembly();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSpeedChanged(float previousSpeed) {
|
||||||
|
super.onSpeedChanged(previousSpeed);
|
||||||
|
checkAttachedCarriageBlocks(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -73,6 +75,10 @@ public class GantryShaftTileEntity extends KineticTileEntity {
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean canAssembleOn() {
|
public boolean canAssembleOn() {
|
||||||
|
return canAssembleOn(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean canAssembleOn(boolean willBeMiddle) {
|
||||||
BlockState blockState = getBlockState();
|
BlockState blockState = getBlockState();
|
||||||
if (!AllBlocks.GANTRY_SHAFT.has(blockState))
|
if (!AllBlocks.GANTRY_SHAFT.has(blockState))
|
||||||
return false;
|
return false;
|
||||||
|
@ -80,6 +86,9 @@ public class GantryShaftTileEntity extends KineticTileEntity {
|
||||||
return false;
|
return false;
|
||||||
float speed = getPinionMovementSpeed();
|
float speed = getPinionMovementSpeed();
|
||||||
|
|
||||||
|
if (willBeMiddle)
|
||||||
|
return speed != 0;
|
||||||
|
|
||||||
switch (blockState.get(GantryShaftBlock.PART)) {
|
switch (blockState.get(GantryShaftBlock.PART)) {
|
||||||
case END:
|
case END:
|
||||||
return speed < 0;
|
return speed < 0;
|
||||||
|
|
Loading…
Reference in a new issue