Handle the redstone property different

This commit is contained in:
zontreck 2024-04-30 04:04:48 -07:00
parent 65a21bcefc
commit 58a732782d
2 changed files with 16 additions and 13 deletions

View file

@ -64,32 +64,35 @@ public abstract class RedstoneBlock extends RotatableBlock
@Override
public void onNeighborChange(BlockState state, LevelReader level, BlockPos pos, BlockPos neighbor) {
onRedstone(level, pos, redstoneIsActivated(level, pos));
boolean rs = redstoneIsActivated(level, pos);
onRedstone(level, pos, rs);
boolean inp = state.getValue(INPUT_POWER);
state.setValue(INPUT_POWER, redstoneIsActivated(level, pos));
state.setValue(INPUT_POWER, rs);
if(inp != redstoneIsActivated(level,pos))
onRedstoneInputChanged(level, pos, state.getValue(INPUT_POWER));
if(inp != rs)
onRedstoneInputChanged(level, pos, rs);
}
@Override
public void neighborChanged(BlockState state, Level level, BlockPos pos, Block block, BlockPos other, boolean unknown) {
onRedstone(level, pos, redstoneIsActivated(level, pos));
boolean rs = redstoneIsActivated(level, pos);
onRedstone(level, pos, rs);
boolean inp = state.getValue(INPUT_POWER);
state.setValue(INPUT_POWER, redstoneIsActivated(level, pos));
state.setValue(INPUT_POWER, rs);
if(inp != redstoneIsActivated(level,pos))
onRedstoneInputChanged(level, pos, state.getValue(INPUT_POWER));
if(inp != rs)
onRedstoneInputChanged(level, pos, rs);
}
@Override
public void onPlace(BlockState state, Level level, BlockPos pos, BlockState p_60569_, boolean p_60570_) {
onRedstone(level, pos, redstoneIsActivated(level, pos));
boolean rs = redstoneIsActivated(level, pos);
onRedstone(level, pos, rs);
boolean inp = state.getValue(INPUT_POWER);
state.setValue(INPUT_POWER, redstoneIsActivated(level, pos));
state.setValue(INPUT_POWER, rs);
if(inp != redstoneIsActivated(level,pos))
onRedstoneInputChanged(level, pos, state.getValue(INPUT_POWER));
if(inp != rs)
onRedstoneInputChanged(level, pos, rs);
}
}