mirror of
https://github.com/Jozufozu/Flywheel.git
synced 2025-01-07 12:56:31 +01:00
bell movement behaviour
This commit is contained in:
parent
9bf81f4d7f
commit
111e69d189
6 changed files with 60 additions and 10 deletions
|
@ -1,8 +1,10 @@
|
||||||
package com.simibubi.create;
|
package com.simibubi.create;
|
||||||
|
|
||||||
|
import com.simibubi.create.content.contraptions.components.actors.BellMovementBehaviour;
|
||||||
import com.simibubi.create.content.contraptions.components.structureMovement.MovementBehaviour;
|
import com.simibubi.create.content.contraptions.components.structureMovement.MovementBehaviour;
|
||||||
import com.tterrag.registrate.util.nullness.NonNullConsumer;
|
import com.tterrag.registrate.util.nullness.NonNullConsumer;
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
|
import net.minecraft.block.Blocks;
|
||||||
import net.minecraft.util.ResourceLocation;
|
import net.minecraft.util.ResourceLocation;
|
||||||
|
|
||||||
import javax.annotation.Nullable;
|
import javax.annotation.Nullable;
|
||||||
|
@ -34,5 +36,7 @@ public class AllMovementBehaviours {
|
||||||
return b -> addMovementBehaviour(b.getRegistryName(), movementBehaviour);
|
return b -> addMovementBehaviour(b.getRegistryName(), movementBehaviour);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void register() {}
|
static void register() {
|
||||||
|
addMovementBehaviour(Blocks.BELL.getRegistryName(), new BellMovementBehaviour());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,32 @@
|
||||||
|
package com.simibubi.create.content.contraptions.components.actors;
|
||||||
|
|
||||||
|
import com.simibubi.create.content.contraptions.components.structureMovement.MovementBehaviour;
|
||||||
|
import com.simibubi.create.content.contraptions.components.structureMovement.MovementContext;
|
||||||
|
|
||||||
|
import net.minecraft.util.SoundCategory;
|
||||||
|
import net.minecraft.util.SoundEvents;
|
||||||
|
import net.minecraft.util.math.BlockPos;
|
||||||
|
import net.minecraft.util.math.Vec3d;
|
||||||
|
|
||||||
|
public class BellMovementBehaviour extends MovementBehaviour {
|
||||||
|
@Override
|
||||||
|
public boolean hasSpecialMovementRenderer() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSpeedChanged(MovementContext context, Vec3d oldMotion, Vec3d motion) {
|
||||||
|
double dotProduct = oldMotion.dotProduct(motion);
|
||||||
|
|
||||||
|
if (dotProduct <= 0 && (context.relativeMotion.length() != 0 || context.rotation.length() == 0)
|
||||||
|
|| context.firstMovement)
|
||||||
|
context.world.playSound(null, new BlockPos(context.position), SoundEvents.BLOCK_BELL_USE,
|
||||||
|
SoundCategory.BLOCKS, 2.0F, 1.0F);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void stopMoving(MovementContext context) {
|
||||||
|
context.world.playSound(null, new BlockPos(context.position), SoundEvents.BLOCK_BELL_USE, SoundCategory.BLOCKS,
|
||||||
|
2.0F, 1.0F);
|
||||||
|
}
|
||||||
|
}
|
|
@ -464,7 +464,8 @@ public abstract class Contraption {
|
||||||
else
|
else
|
||||||
renderOrder.add(0, info.pos);
|
renderOrder.add(0, info.pos);
|
||||||
CompoundNBT tag = info.nbt;
|
CompoundNBT tag = info.nbt;
|
||||||
if (tag == null || AllMovementBehaviours.hasMovementBehaviour(block))
|
MovementBehaviour movementBehaviour = AllMovementBehaviours.getMovementBehaviour(block);
|
||||||
|
if (tag == null || movementBehaviour == null || movementBehaviour.hasSpecialMovementRenderer())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
tag.putInt("x", info.pos.getX());
|
tag.putInt("x", info.pos.getX());
|
||||||
|
@ -472,6 +473,8 @@ public abstract class Contraption {
|
||||||
tag.putInt("z", info.pos.getZ());
|
tag.putInt("z", info.pos.getZ());
|
||||||
|
|
||||||
TileEntity te = TileEntity.create(tag);
|
TileEntity te = TileEntity.create(tag);
|
||||||
|
if (te == null)
|
||||||
|
return;
|
||||||
te.setLocation(new WrappedWorld(world) {
|
te.setLocation(new WrappedWorld(world) {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -459,6 +459,7 @@ public class ContraptionEntity extends Entity implements IEntityAdditionalSpawnD
|
||||||
|
|
||||||
boolean newPosVisited = false;
|
boolean newPosVisited = false;
|
||||||
BlockPos gridPosition = new BlockPos(actorPosition);
|
BlockPos gridPosition = new BlockPos(actorPosition);
|
||||||
|
Vec3d oldMotion = context.motion;
|
||||||
|
|
||||||
if (!context.stall) {
|
if (!context.stall) {
|
||||||
Vec3d previousPosition = context.position;
|
Vec3d previousPosition = context.position;
|
||||||
|
@ -500,6 +501,8 @@ public class ContraptionEntity extends Entity implements IEntityAdditionalSpawnD
|
||||||
actor.visitNewPosition(context, gridPosition);
|
actor.visitNewPosition(context, gridPosition);
|
||||||
context.firstMovement = false;
|
context.firstMovement = false;
|
||||||
}
|
}
|
||||||
|
if (!oldMotion.equals(context.motion))
|
||||||
|
actor.onSpeedChanged(context, oldMotion, context.motion);
|
||||||
actor.tick(context);
|
actor.tick(context);
|
||||||
contraption.stalled |= context.stall;
|
contraption.stalled |= context.stall;
|
||||||
}
|
}
|
||||||
|
|
|
@ -106,11 +106,12 @@ public class ContraptionRenderer {
|
||||||
for (MatrixStack m : matrixStacks) {
|
for (MatrixStack m : matrixStacks) {
|
||||||
m.push();
|
m.push();
|
||||||
MatrixStacker.of(m)
|
MatrixStacker.of(m)
|
||||||
.translate(blockInfo.pos);
|
.translate(blockInfo.pos);
|
||||||
}
|
}
|
||||||
|
|
||||||
Contraption.getMovement(blockInfo.state)
|
MovementBehaviour movementBehaviour = Contraption.getMovement(blockInfo.state);
|
||||||
.renderInContraption(context, ms, msLocal, buffer);
|
if (movementBehaviour != null)
|
||||||
|
movementBehaviour.renderInContraption(context, ms, msLocal, buffer);
|
||||||
|
|
||||||
for (MatrixStack m : matrixStacks)
|
for (MatrixStack m : matrixStacks)
|
||||||
m.pop();
|
m.pop();
|
||||||
|
|
|
@ -47,8 +47,15 @@ public abstract class MovementBehaviour {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean hasSpecialMovementRenderer() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
@OnlyIn(Dist.CLIENT)
|
@OnlyIn(Dist.CLIENT)
|
||||||
public void renderInContraption(MovementContext context, MatrixStack ms, MatrixStack msLocal,
|
public void renderInContraption(MovementContext context, MatrixStack ms, MatrixStack msLocal,
|
||||||
IRenderTypeBuffer buffer) {}
|
IRenderTypeBuffer buffer) {}
|
||||||
|
|
||||||
|
public void onSpeedChanged(MovementContext context, Vec3d oldMotion, Vec3d motion) {
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue