From e561ac8e73fd50096e3d99d9c4b2f9149a477712 Mon Sep 17 00:00:00 2001 From: reidbhuntley Date: Sun, 4 Jul 2021 23:34:04 -0400 Subject: [PATCH] Immersive pumpkin chuckin' - Block items shot by the Potato Cannon now spawn a FallingBlock entity when they hit the side of a block --- .../weapons/PotatoCannonProjectileTypes.java | 26 ++++++++++++++----- 1 file changed, 20 insertions(+), 6 deletions(-) diff --git a/src/main/java/com/simibubi/create/content/curiosities/weapons/PotatoCannonProjectileTypes.java b/src/main/java/com/simibubi/create/content/curiosities/weapons/PotatoCannonProjectileTypes.java index ff466020f..676293c6b 100644 --- a/src/main/java/com/simibubi/create/content/curiosities/weapons/PotatoCannonProjectileTypes.java +++ b/src/main/java/com/simibubi/create/content/curiosities/weapons/PotatoCannonProjectileTypes.java @@ -15,6 +15,7 @@ import net.minecraft.block.BlockState; import net.minecraft.block.Blocks; import net.minecraft.entity.Entity; import net.minecraft.entity.LivingEntity; +import net.minecraft.entity.item.FallingBlockEntity; import net.minecraft.entity.passive.FoxEntity; import net.minecraft.item.Food; import net.minecraft.item.Foods; @@ -316,17 +317,30 @@ public class PotatoCannonProjectileTypes { private static BiConsumer placeBlockOnGround(IRegistryDelegate block) { return (world, ray) -> { - if (ray.getFace() != Direction.UP) - return; BlockPos hitPos = ray.getPos(); if (!world.isAreaLoaded(hitPos, 1)) return; - BlockPos placePos = hitPos.up(); + Direction face = ray.getFace(); + BlockPos placePos = hitPos.offset(face); if (!world.getBlockState(placePos) - .getMaterial() - .isReplaceable()) + .getMaterial() + .isReplaceable()) return; - world.setBlockState(placePos, block.get().getDefaultState(), 3); + + if (face == Direction.UP) { + world.setBlockState(placePos, block.get().getDefaultState(), 3); + } else if (world instanceof World) { + double y = ray.getHitVec().y - 0.5; + if (!world.isAirBlock(placePos.up())) + y = Math.min(y, placePos.getY()); + if (!world.isAirBlock(placePos.down())) + y = Math.max(y, placePos.getY()); + + FallingBlockEntity falling = new FallingBlockEntity((World) world, placePos.getX() + 0.5, y, + placePos.getZ() + 0.5, block.get().getDefaultState()); + falling.fallTime = 1; + world.addEntity(falling); + } }; }