Menger sponge, translation, fixes
This commit is contained in:
parent
fd0d49391d
commit
1195ca4cd3
10 changed files with 195 additions and 9 deletions
76
src/main/java/ru/betterend/blocks/BlockMengerSpongeWet.java
Normal file
76
src/main/java/ru/betterend/blocks/BlockMengerSpongeWet.java
Normal file
|
@ -0,0 +1,76 @@
|
|||
package ru.betterend.blocks;
|
||||
|
||||
import java.util.Random;
|
||||
|
||||
import net.fabricmc.api.EnvType;
|
||||
import net.fabricmc.api.Environment;
|
||||
import net.fabricmc.fabric.api.object.builder.v1.block.FabricBlockSettings;
|
||||
import net.minecraft.block.BlockState;
|
||||
import net.minecraft.block.Blocks;
|
||||
import net.minecraft.entity.player.PlayerEntity;
|
||||
import net.minecraft.particle.ParticleTypes;
|
||||
import net.minecraft.sound.SoundCategory;
|
||||
import net.minecraft.sound.SoundEvents;
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
import net.minecraft.util.math.Direction;
|
||||
import net.minecraft.world.World;
|
||||
import ru.betterend.blocks.basis.BlockBase;
|
||||
import ru.betterend.registry.EndBlocks;
|
||||
|
||||
public class BlockMengerSpongeWet extends BlockBase {
|
||||
public BlockMengerSpongeWet() {
|
||||
super(FabricBlockSettings.copyOf(Blocks.WET_SPONGE));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onBlockAdded(BlockState state, World world, BlockPos pos, BlockState oldState, boolean notify) {
|
||||
if (world.getDimension().isUltrawarm()) {
|
||||
world.setBlockState(pos, EndBlocks.MENGER_SPONGE.getDefaultState(), 3);
|
||||
world.syncWorldEvent(2009, pos, 0);
|
||||
world.playSound((PlayerEntity) null, pos, SoundEvents.BLOCK_FIRE_EXTINGUISH, SoundCategory.BLOCKS, 1.0F, (1.0F + world.getRandom().nextFloat() * 0.2F) * 0.7F);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
@Environment(EnvType.CLIENT)
|
||||
public void randomDisplayTick(BlockState state, World world, BlockPos pos, Random random) {
|
||||
Direction direction = Direction.random(random);
|
||||
if (direction != Direction.UP) {
|
||||
BlockPos blockPos = pos.offset(direction);
|
||||
BlockState blockState = world.getBlockState(blockPos);
|
||||
if (!state.isOpaque() || !blockState.isSideSolidFullSquare(world, blockPos, direction.getOpposite())) {
|
||||
double x = (double) pos.getX();
|
||||
double y = (double) pos.getY();
|
||||
double z = (double) pos.getZ();
|
||||
if (direction == Direction.DOWN) {
|
||||
y -= 0.05;
|
||||
x += random.nextDouble();
|
||||
z += random.nextDouble();
|
||||
}
|
||||
else {
|
||||
y += random.nextDouble() * 0.8;
|
||||
if (direction.getAxis() == Direction.Axis.X) {
|
||||
z += random.nextDouble();
|
||||
if (direction == Direction.EAST) {
|
||||
++x;
|
||||
}
|
||||
else {
|
||||
x += 0.05;
|
||||
}
|
||||
}
|
||||
else {
|
||||
x += random.nextDouble();
|
||||
if (direction == Direction.SOUTH) {
|
||||
++z;
|
||||
}
|
||||
else {
|
||||
z += 0.05;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
world.addParticle(ParticleTypes.DRIPPING_WATER, x, y, z, 0, 0, 0);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue