mirror of
https://github.com/Creators-of-Create/Create.git
synced 2025-01-18 17:08:07 +01:00
Immersive pumpkin chuckin'
- Block items shot by the Potato Cannon now spawn a FallingBlock entity when they hit the side of a block
This commit is contained in:
parent
1a273753eb
commit
e561ac8e73
1 changed files with 20 additions and 6 deletions
|
@ -15,6 +15,7 @@ import net.minecraft.block.BlockState;
|
||||||
import net.minecraft.block.Blocks;
|
import net.minecraft.block.Blocks;
|
||||||
import net.minecraft.entity.Entity;
|
import net.minecraft.entity.Entity;
|
||||||
import net.minecraft.entity.LivingEntity;
|
import net.minecraft.entity.LivingEntity;
|
||||||
|
import net.minecraft.entity.item.FallingBlockEntity;
|
||||||
import net.minecraft.entity.passive.FoxEntity;
|
import net.minecraft.entity.passive.FoxEntity;
|
||||||
import net.minecraft.item.Food;
|
import net.minecraft.item.Food;
|
||||||
import net.minecraft.item.Foods;
|
import net.minecraft.item.Foods;
|
||||||
|
@ -316,17 +317,30 @@ public class PotatoCannonProjectileTypes {
|
||||||
|
|
||||||
private static BiConsumer<IWorld, BlockRayTraceResult> placeBlockOnGround(IRegistryDelegate<? extends Block> block) {
|
private static BiConsumer<IWorld, BlockRayTraceResult> placeBlockOnGround(IRegistryDelegate<? extends Block> block) {
|
||||||
return (world, ray) -> {
|
return (world, ray) -> {
|
||||||
if (ray.getFace() != Direction.UP)
|
|
||||||
return;
|
|
||||||
BlockPos hitPos = ray.getPos();
|
BlockPos hitPos = ray.getPos();
|
||||||
if (!world.isAreaLoaded(hitPos, 1))
|
if (!world.isAreaLoaded(hitPos, 1))
|
||||||
return;
|
return;
|
||||||
BlockPos placePos = hitPos.up();
|
Direction face = ray.getFace();
|
||||||
|
BlockPos placePos = hitPos.offset(face);
|
||||||
if (!world.getBlockState(placePos)
|
if (!world.getBlockState(placePos)
|
||||||
.getMaterial()
|
.getMaterial()
|
||||||
.isReplaceable())
|
.isReplaceable())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if (face == Direction.UP) {
|
||||||
world.setBlockState(placePos, block.get().getDefaultState(), 3);
|
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);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue