Sulphur, brimstone
This commit is contained in:
parent
bf7e665b36
commit
44371da207
25 changed files with 317 additions and 63 deletions
70
src/main/java/ru/betterend/blocks/BlockBrimstone.java
Normal file
70
src/main/java/ru/betterend/blocks/BlockBrimstone.java
Normal file
|
@ -0,0 +1,70 @@
|
|||
package ru.betterend.blocks;
|
||||
|
||||
import java.util.Random;
|
||||
|
||||
import net.fabricmc.fabric.api.object.builder.v1.block.FabricBlockSettings;
|
||||
import net.minecraft.block.Block;
|
||||
import net.minecraft.block.BlockState;
|
||||
import net.minecraft.block.Blocks;
|
||||
import net.minecraft.block.MaterialColor;
|
||||
import net.minecraft.fluid.Fluids;
|
||||
import net.minecraft.server.world.ServerWorld;
|
||||
import net.minecraft.state.StateManager;
|
||||
import net.minecraft.state.property.BooleanProperty;
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
import net.minecraft.util.math.Direction;
|
||||
import ru.betterend.blocks.basis.BlockBase;
|
||||
import ru.betterend.registry.EndBlocks;
|
||||
import ru.betterend.util.BlocksHelper;
|
||||
|
||||
public class BlockBrimstone extends BlockBase {
|
||||
public static final BooleanProperty ACTIVATED = BlockProperties.ACTIVATED;
|
||||
|
||||
public BlockBrimstone() {
|
||||
super(FabricBlockSettings.copyOf(Blocks.END_STONE).materialColor(MaterialColor.BROWN).ticksRandomly());
|
||||
setDefaultState(stateManager.getDefaultState().with(ACTIVATED, false));
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void appendProperties(StateManager.Builder<Block, BlockState> stateManager) {
|
||||
stateManager.add(ACTIVATED);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void scheduledTick(BlockState state, ServerWorld world, BlockPos pos, Random random) {
|
||||
boolean deactivate = true;
|
||||
for (Direction dir: BlocksHelper.DIRECTIONS) {
|
||||
if (world.getFluidState(pos.offset(dir)).getFluid().equals(Fluids.WATER)) {
|
||||
deactivate = false;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (state.get(ACTIVATED)) {
|
||||
if (deactivate) {
|
||||
world.setBlockState(pos, getDefaultState().with(ACTIVATED, false));
|
||||
}
|
||||
else if (state.get(ACTIVATED)) {
|
||||
Direction dir = BlocksHelper.randomDirection(random);
|
||||
BlockPos side = pos.offset(dir);
|
||||
BlockState sideState = world.getBlockState(side);
|
||||
if (sideState.getBlock() instanceof BlockSulphurCrystal) {
|
||||
if (sideState.get(BlockSulphurCrystal.AGE) < 2) {
|
||||
int age = sideState.get(BlockSulphurCrystal.AGE) + 1;
|
||||
world.setBlockState(side, sideState.with(BlockSulphurCrystal.AGE, age));
|
||||
}
|
||||
}
|
||||
else if (sideState.isAir() || !sideState.getFluidState().isEmpty()) {
|
||||
boolean water = sideState.getFluidState().getFluid().equals(Fluids.WATER);
|
||||
BlockState crystal = EndBlocks.SULPHUR_CRYSTAL.getDefaultState()
|
||||
.with(BlockSulphurCrystal.FACING, dir)
|
||||
.with(BlockSulphurCrystal.WATERLOGGED, water)
|
||||
.with(BlockSulphurCrystal.AGE, 0);
|
||||
world.setBlockState(side, crystal);
|
||||
}
|
||||
}
|
||||
}
|
||||
else if (!deactivate && !state.get(ACTIVATED)) {
|
||||
world.setBlockState(pos, getDefaultState().with(ACTIVATED, true));
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue