reset oxidation with sand paper

This commit is contained in:
LordGrimmauld 2020-06-10 21:21:12 +02:00
parent 1c3e08bd66
commit a0d87b56a8

View File

@ -4,13 +4,20 @@ import java.util.LinkedList;
import java.util.OptionalDouble;
import java.util.Random;
import com.simibubi.create.content.curiosities.tools.SandPaperItem;
import net.minecraft.block.Block;
import net.minecraft.block.BlockState;
import net.minecraft.entity.player.PlayerEntity;
import net.minecraft.state.IntegerProperty;
import net.minecraft.state.StateContainer.Builder;
import net.minecraft.util.ActionResultType;
import net.minecraft.util.Direction;
import net.minecraft.util.Hand;
import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.BlockRayTraceResult;
import net.minecraft.world.IBlockReader;
import net.minecraft.world.World;
import net.minecraft.world.server.ServerWorld;
public class OxidizingBlock extends Block {
@ -65,4 +72,16 @@ public class OxidizingBlock extends Block {
public float getBlockHardness(BlockState blockState, IBlockReader worldIn, BlockPos pos) {
return this.blockHardness - 0.2f * blockState.get(OXIDIZATION);
}
@Override
public ActionResultType onUse(BlockState state, World world, BlockPos pos,
PlayerEntity player, Hand hand, BlockRayTraceResult blockRayTraceResult) {
if(state.get(OXIDIZATION) > 0 && player.getHeldItem(hand).getItem() instanceof SandPaperItem) {
if(!player.isCreative())
player.getHeldItem(hand).damageItem(1, player, p -> p.sendBreakAnimation(p.getActiveHand()));
world.setBlockState(pos, state.with(OXIDIZATION, 0));
return ActionResultType.SUCCESS;
}
return ActionResultType.PASS;
}
}