diff --git a/src/main/java/com/simibubi/create/AllBlockPartials.java b/src/main/java/com/simibubi/create/AllBlockPartials.java index 257f387ab..ec06c44cb 100644 --- a/src/main/java/com/simibubi/create/AllBlockPartials.java +++ b/src/main/java/com/simibubi/create/AllBlockPartials.java @@ -52,6 +52,12 @@ public enum AllBlockPartials { BELT_TUNNEL_FLAP("belt_tunnel/flap"), BELT_TUNNEL_INDICATOR("belt_tunnel/indicator"), FLEXPEATER_INDICATOR("repeaters/flexpeater_indicator"), + FLYWHEEL("flywheel/wheel"), + FLYWHEEL_UPPER_ROTATING("flywheel/upper_rotating_connector"), + FLYWHEEL_LOWER_ROTATING("flywheel/lower_rotating_connector"), + FLYWHEEL_UPPER_SLIDING("flywheel/upper_sliding_connector"), + FLYWHEEL_LOWER_SLIDING("flywheel/lower_sliding_connector"), + FURNACE_GENERATOR_FRAME("furnace_engine/frame"), ; diff --git a/src/main/java/com/simibubi/create/AllBlocks.java b/src/main/java/com/simibubi/create/AllBlocks.java index fceceadf1..79397760a 100644 --- a/src/main/java/com/simibubi/create/AllBlocks.java +++ b/src/main/java/com/simibubi/create/AllBlocks.java @@ -25,6 +25,8 @@ import com.simibubi.create.modules.contraptions.components.crusher.CrushingWheel import com.simibubi.create.modules.contraptions.components.deployer.DeployerBlock; import com.simibubi.create.modules.contraptions.components.fan.EncasedFanBlock; import com.simibubi.create.modules.contraptions.components.fan.NozzleBlock; +import com.simibubi.create.modules.contraptions.components.flywheel.FlywheelBlock; +import com.simibubi.create.modules.contraptions.components.flywheel.engine.FurnaceEngineBlock; import com.simibubi.create.modules.contraptions.components.mixer.MechanicalMixerBlock; import com.simibubi.create.modules.contraptions.components.motor.MotorBlock; import com.simibubi.create.modules.contraptions.components.press.MechanicalPressBlock; @@ -118,13 +120,17 @@ public enum AllBlocks { NOZZLE(new NozzleBlock()), TURNTABLE(new TurntableBlock()), HAND_CRANK(new HandCrankBlock()), - + CRUSHING_WHEEL(new CrushingWheelBlock()), CRUSHING_WHEEL_CONTROLLER(new CrushingWheelControllerBlock()), MECHANICAL_PRESS(new MechanicalPressBlock()), MECHANICAL_MIXER(new MechanicalMixerBlock()), BASIN(new BasinBlock()), MECHANICAL_CRAFTER(new MechanicalCrafterBlock()), + + FLYWHEEL(new FlywheelBlock()), + FURNACE_ENGINE(new FurnaceEngineBlock()), + SPEED_GAUGE(new GaugeBlock(GaugeBlock.Type.SPEED)), STRESS_GAUGE(new GaugeBlock(GaugeBlock.Type.STRESS)), diff --git a/src/main/java/com/simibubi/create/AllTileEntities.java b/src/main/java/com/simibubi/create/AllTileEntities.java index 2b63251d7..5924f8106 100644 --- a/src/main/java/com/simibubi/create/AllTileEntities.java +++ b/src/main/java/com/simibubi/create/AllTileEntities.java @@ -25,6 +25,10 @@ import com.simibubi.create.modules.contraptions.components.deployer.DeployerTile import com.simibubi.create.modules.contraptions.components.fan.EncasedFanTileEntity; import com.simibubi.create.modules.contraptions.components.fan.EncasedFanTileEntityRenderer; import com.simibubi.create.modules.contraptions.components.fan.NozzleTileEntity; +import com.simibubi.create.modules.contraptions.components.flywheel.FlywheelRenderer; +import com.simibubi.create.modules.contraptions.components.flywheel.FlywheelTileEntity; +import com.simibubi.create.modules.contraptions.components.flywheel.engine.EngineRenderer; +import com.simibubi.create.modules.contraptions.components.flywheel.engine.FurnaceEngineTileEntity; import com.simibubi.create.modules.contraptions.components.mixer.MechanicalMixerTileEntity; import com.simibubi.create.modules.contraptions.components.mixer.MechanicalMixerTileEntityRenderer; import com.simibubi.create.modules.contraptions.components.motor.MotorTileEntity; @@ -111,6 +115,8 @@ public enum AllTileEntities { DRILL(DrillTileEntity::new, AllBlocks.DRILL), SAW(SawTileEntity::new, AllBlocks.SAW), HARVESTER(HarvesterTileEntity::new, AllBlocks.HARVESTER), + FLYWHEEL(FlywheelTileEntity::new, AllBlocks.FLYWHEEL), + FURNACE_ENGINE(FurnaceEngineTileEntity::new, AllBlocks.FURNACE_ENGINE), CRUSHING_WHEEL(CrushingWheelTileEntity::new, AllBlocks.CRUSHING_WHEEL), CRUSHING_WHEEL_CONTROLLER(CrushingWheelControllerTileEntity::new, AllBlocks.CRUSHING_WHEEL_CONTROLLER), WATER_WHEEL(WaterWheelTileEntity::new, AllBlocks.WATER_WHEEL), @@ -200,6 +206,8 @@ public enum AllTileEntities { bind(StressGaugeTileEntity.class, new GaugeTileEntityRenderer(GaugeBlock.Type.STRESS)); bind(BasinTileEntity.class, new BasinTileEntityRenderer()); bind(DeployerTileEntity.class, new DeployerTileEntityRenderer()); + bind(FlywheelTileEntity.class, new FlywheelRenderer()); + bind(FurnaceEngineTileEntity.class, new EngineRenderer<>()); bind(RedstoneLinkTileEntity.class, new SmartTileEntityRenderer<>()); bind(ExtractorTileEntity.class, new SmartTileEntityRenderer<>()); diff --git a/src/main/java/com/simibubi/create/foundation/utility/AllShapes.java b/src/main/java/com/simibubi/create/foundation/utility/AllShapes.java index 99b234100..2710dd88a 100644 --- a/src/main/java/com/simibubi/create/foundation/utility/AllShapes.java +++ b/src/main/java/com/simibubi/create/foundation/utility/AllShapes.java @@ -30,7 +30,10 @@ public class AllShapes { TRANSPOSER = VoxelShaper.forDirectional(VoxelShapes.or( makeCuboidShape(4, 4, -1, 12, 12, 1), makeCuboidShape(5, 5, 0, 11, 11, 16), - makeCuboidShape(4, 4, 11, 12, 12, 17)), Direction.SOUTH) + makeCuboidShape(4, 4, 11, 12, 12, 17)), Direction.SOUTH), + FURNACE_ENGINE = VoxelShaper.forHorizontal(VoxelShapes.or( + makeCuboidShape(1, 1, 0, 15, 15, 16), + makeCuboidShape(0, 0, 9, 16, 16, 14)), Direction.SOUTH) ; diff --git a/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/FlywheelBlock.java b/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/FlywheelBlock.java new file mode 100644 index 000000000..2f40ac30a --- /dev/null +++ b/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/FlywheelBlock.java @@ -0,0 +1,99 @@ +package com.simibubi.create.modules.contraptions.components.flywheel; + +import com.simibubi.create.foundation.utility.Lang; +import com.simibubi.create.modules.contraptions.base.HorizontalKineticBlock; + +import net.minecraft.block.Block; +import net.minecraft.block.BlockState; +import net.minecraft.block.Blocks; +import net.minecraft.item.BlockItemUseContext; +import net.minecraft.state.EnumProperty; +import net.minecraft.state.StateContainer.Builder; +import net.minecraft.tileentity.TileEntity; +import net.minecraft.util.Direction; +import net.minecraft.util.Direction.Axis; +import net.minecraft.util.IStringSerializable; +import net.minecraft.util.math.BlockPos; +import net.minecraft.world.IBlockReader; +import net.minecraft.world.IWorldReader; +import net.minecraft.world.World; + +public class FlywheelBlock extends HorizontalKineticBlock { + + public static EnumProperty CONNECTION = EnumProperty.create("connection", ConnectionState.class); + + public FlywheelBlock() { + super(Properties.from(Blocks.GOLD_BLOCK)); + setDefaultState(getDefaultState().with(CONNECTION, ConnectionState.NONE)); + } + + @Override + protected void fillStateContainer(Builder builder) { + super.fillStateContainer(builder.add(CONNECTION)); + } + + @Override + public TileEntity createTileEntity(BlockState state, IBlockReader world) { + return new FlywheelTileEntity(); + } + + @Override + public BlockState getStateForPlacement(BlockItemUseContext context) { + Direction preferred = getPreferredHorizontalFacing(context); + if (preferred != null) + return getDefaultState().with(HORIZONTAL_FACING, preferred.getOpposite()); + return this.getDefaultState().with(HORIZONTAL_FACING, context.getPlacementHorizontalFacing()); + } + + @Override + protected boolean hasStaticPart() { + return true; + } + + public static boolean isConnected(BlockState state) { + return getConnection(state) != null; + } + + public static Direction getConnection(BlockState state) { + Direction facing = state.get(HORIZONTAL_FACING); + ConnectionState connection = state.get(CONNECTION); + + if (connection == ConnectionState.LEFT) + return facing.rotateYCCW(); + if (connection == ConnectionState.RIGHT) + return facing.rotateY(); + return null; + } + + public static void setConnection(World world, BlockPos pos, BlockState state, Direction direction) { + Direction facing = state.get(HORIZONTAL_FACING); + ConnectionState connection = ConnectionState.NONE; + + if (direction == facing.rotateY()) + connection = ConnectionState.RIGHT; + if (direction == facing.rotateYCCW()) + connection = ConnectionState.LEFT; + + world.setBlockState(pos, state.with(CONNECTION, connection), 18); + } + + @Override + public boolean hasShaftTowards(IWorldReader world, BlockPos pos, BlockState state, Direction face) { + return face == state.get(HORIZONTAL_FACING).getOpposite(); + } + + @Override + public Axis getRotationAxis(BlockState state) { + return state.get(HORIZONTAL_FACING).getAxis(); + } + + public enum ConnectionState implements IStringSerializable { + NONE, LEFT, RIGHT; + + @Override + public String getName() { + return Lang.asId(name()); + } + } + +} diff --git a/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/FlywheelRenderer.java b/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/FlywheelRenderer.java new file mode 100644 index 000000000..52b060d9c --- /dev/null +++ b/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/FlywheelRenderer.java @@ -0,0 +1,98 @@ +package com.simibubi.create.modules.contraptions.components.flywheel; + +import static com.simibubi.create.modules.contraptions.base.HorizontalKineticBlock.HORIZONTAL_FACING; + +import com.simibubi.create.AllBlockPartials; +import com.simibubi.create.foundation.utility.AngleHelper; +import com.simibubi.create.foundation.utility.SuperByteBuffer; +import com.simibubi.create.modules.contraptions.base.KineticTileEntity; +import com.simibubi.create.modules.contraptions.base.KineticTileEntityRenderer; +import com.simibubi.create.modules.contraptions.components.flywheel.FlywheelBlock.ConnectionState; + +import net.minecraft.block.BlockState; +import net.minecraft.client.renderer.BufferBuilder; +import net.minecraft.util.Direction; +import net.minecraft.util.Direction.Axis; +import net.minecraft.util.Direction.AxisDirection; +import net.minecraft.util.math.MathHelper; +import net.minecraft.util.Rotation; + +public class FlywheelRenderer extends KineticTileEntityRenderer { + + @Override + public void renderFast(KineticTileEntity te, double x, double y, double z, float partialTicks, int destroyStage, + BufferBuilder buffer) { + super.renderFast(te, x, y, z, partialTicks, destroyStage, buffer); + + BlockState blockState = te.getBlockState(); + FlywheelTileEntity wte = (FlywheelTileEntity) te; + + SuperByteBuffer wheel = AllBlockPartials.FLYWHEEL.renderOnHorizontal(blockState.rotate(Rotation.CLOCKWISE_90)); + float speed = wte.visualSpeed.get(partialTicks) * 3 / 10f; + float angle = wte.angle + speed * partialTicks; + + if (FlywheelBlock.isConnected(blockState)) { + Direction connection = FlywheelBlock.getConnection(blockState); + int light = blockState.getPackedLightmapCoords(getWorld(), te.getPos().offset(connection)); + float rotation = connection.getAxis() == Axis.X ^ connection.getAxisDirection() == AxisDirection.NEGATIVE + ? -angle + : angle; + boolean flip = blockState.get(FlywheelBlock.CONNECTION) == ConnectionState.LEFT; + + rotateToFacing(transformConnector(AllBlockPartials.FLYWHEEL_UPPER_ROTATING.renderOn(blockState), true, true, + rotation, flip), connection).translate(x, y, z).light(light).renderInto(buffer); + rotateToFacing(transformConnector(AllBlockPartials.FLYWHEEL_LOWER_ROTATING.renderOn(blockState), false, + true, rotation, flip), connection).translate(x, y, z).light(light).renderInto(buffer); + rotateToFacing(transformConnector(AllBlockPartials.FLYWHEEL_UPPER_SLIDING.renderOn(blockState), true, false, + rotation, flip), connection).translate(x, y, z).light(light).renderInto(buffer); + rotateToFacing(transformConnector(AllBlockPartials.FLYWHEEL_LOWER_SLIDING.renderOn(blockState), false, + false, rotation, flip), connection).translate(x, y, z).light(light).renderInto(buffer); + } + + kineticRotationTransform(wheel, te, blockState.get(HORIZONTAL_FACING).getAxis(), AngleHelper.rad(angle), + getWorld()); + wheel.translate(x, y, z).renderInto(buffer); + } + + @Override + protected SuperByteBuffer getRotatedModel(KineticTileEntity te) { + return AllBlockPartials.SHAFT_HALF.renderOnDirectional(te.getBlockState(), + te.getBlockState().get(HORIZONTAL_FACING).getOpposite()); + } + + protected SuperByteBuffer transformConnector(SuperByteBuffer buffer, boolean upper, boolean rotating, float angle, + boolean flip) { + + float shift = upper ? 1 / 4f : -1 / 8f; + float offset = upper ? 1 / 4f : 1 / 4f; + float radians = (float) (angle / 180 * Math.PI); + float shifting = MathHelper.sin(radians) * shift + offset; + + float maxAngle = upper ? -5 : -15; + float minAngle = upper ? -45 : 5; + float barAngle = 0; + + if (rotating) + barAngle = MathHelper.lerp((MathHelper.sin((float) (radians + Math.PI / 2)) + 1) / 2, minAngle, maxAngle); + + float pivotX = (upper ? 8f : 3f) / 16; + float pivotY = (upper ? 8f : 2f) / 16; + float pivotZ = (upper ? 23f : 21.5f) / 16f; + + if (flip && !upper) + buffer.translate(9 / 16f, 0, 0); + + buffer.translate(-pivotX, -pivotY, -pivotZ); + if (rotating) + buffer.rotate(Axis.X, AngleHelper.rad(barAngle)); + buffer.translate(pivotX, pivotY, pivotZ + shifting); + + return buffer; + } + + protected SuperByteBuffer rotateToFacing(SuperByteBuffer buffer, Direction facing) { + buffer.rotateCentered(Axis.Y, AngleHelper.rad(AngleHelper.horizontalAngle(facing))); + return buffer; + } + +} diff --git a/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/FlywheelTileEntity.java b/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/FlywheelTileEntity.java new file mode 100644 index 000000000..f272c60e3 --- /dev/null +++ b/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/FlywheelTileEntity.java @@ -0,0 +1,109 @@ +package com.simibubi.create.modules.contraptions.components.flywheel; + +import com.simibubi.create.AllTileEntities; +import com.simibubi.create.foundation.gui.widgets.InterpolatedChasingValue; +import com.simibubi.create.modules.contraptions.base.GeneratingKineticTileEntity; + +import net.minecraft.nbt.CompoundNBT; +import net.minecraft.util.math.AxisAlignedBB; + +public class FlywheelTileEntity extends GeneratingKineticTileEntity { + + private float generatedCapacity; + private float generatedSpeed; + private int stoppingCooldown; + + // Client + InterpolatedChasingValue visualSpeed = new InterpolatedChasingValue(); + float angle; + + public FlywheelTileEntity() { + super(AllTileEntities.FLYWHEEL.type); + } + + public void setRotation(float speed, float capacity) { + if (generatedSpeed != speed || generatedCapacity != capacity) { + + if (speed == 0) { + if (stoppingCooldown == 0) + stoppingCooldown = 40; + return; + } + + stoppingCooldown = 0; + generatedSpeed = speed; + generatedCapacity = capacity; + updateGeneratedRotation(); + } + } + + @Override + public float getGeneratedSpeed() { + return generatedSpeed; + } + + @Override + public float getAddedStressCapacity() { + return generatedCapacity; + } + + @Override + public void initialize() { + super.initialize(); + } + + @Override + public AxisAlignedBB getRenderBoundingBox() { + return super.getRenderBoundingBox().grow(2); + } + + @Override + public CompoundNBT writeToClient(CompoundNBT compound) { + return super.writeToClient(compound); + } + + @Override + public void readClientUpdate(CompoundNBT tag) { + super.readClientUpdate(tag); + visualSpeed.withSpeed(1 / 32f).target(generatedSpeed); + } + + @Override + public CompoundNBT write(CompoundNBT compound) { + compound.putFloat("GeneratedSpeed", generatedSpeed); + compound.putFloat("GeneratedCapacity", generatedCapacity); + compound.putInt("Cooldown", stoppingCooldown); + return super.write(compound); + } + + @Override + public void read(CompoundNBT compound) { + generatedSpeed = compound.getFloat("GeneratedSpeed"); + generatedCapacity = compound.getFloat("GeneratedCapacity"); + stoppingCooldown = compound.getInt("Cooldown"); + super.read(compound); + } + + @Override + public void tick() { + super.tick(); + + if (world.isRemote) { + visualSpeed.target(generatedSpeed); + visualSpeed.tick(); + angle += visualSpeed.value * 3 / 10f; + angle %= 360; + return; + } + if (stoppingCooldown == 0) + return; + + stoppingCooldown--; + if (stoppingCooldown == 0) { + generatedCapacity = 0; + generatedSpeed = 0; + updateGeneratedRotation(); + } + } + +} diff --git a/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/engine/EngineBlock.java b/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/engine/EngineBlock.java new file mode 100644 index 000000000..b1f291948 --- /dev/null +++ b/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/engine/EngineBlock.java @@ -0,0 +1,95 @@ +package com.simibubi.create.modules.contraptions.components.flywheel.engine; + +import javax.annotation.Nullable; + +import com.simibubi.create.AllBlockPartials; + +import net.minecraft.block.Block; +import net.minecraft.block.BlockState; +import net.minecraft.block.HorizontalBlock; +import net.minecraft.item.BlockItemUseContext; +import net.minecraft.state.StateContainer.Builder; +import net.minecraft.tileentity.TileEntity; +import net.minecraft.util.Direction; +import net.minecraft.util.math.BlockPos; +import net.minecraft.world.IBlockReader; +import net.minecraft.world.IWorldReader; +import net.minecraft.world.World; +import net.minecraftforge.api.distmarker.Dist; +import net.minecraftforge.api.distmarker.OnlyIn; + +public abstract class EngineBlock extends HorizontalBlock { + + protected EngineBlock(Properties builder) { + super(builder); + } + + @Override + public boolean isValidPosition(BlockState state, IWorldReader worldIn, BlockPos pos) { + return isValidPosition(state, worldIn, pos, state.get(HORIZONTAL_FACING)); + } + + @Override + public boolean hasTileEntity(BlockState state) { + return true; + } + + @Override + public abstract TileEntity createTileEntity(BlockState state, IBlockReader world); + + @Override + public BlockState getStateForPlacement(BlockItemUseContext context) { + Direction facing = context.getFace(); + return getDefaultState().with(HORIZONTAL_FACING, + facing.getAxis().isVertical() ? context.getPlacementHorizontalFacing().getOpposite() : facing); + } + + @Override + protected void fillStateContainer(Builder builder) { + super.fillStateContainer(builder.add(HORIZONTAL_FACING)); + } + + @Override + public void neighborChanged(BlockState state, World worldIn, BlockPos pos, Block blockIn, BlockPos fromPos, + boolean isMoving) { + if (worldIn.isRemote) + return; + + if (fromPos.equals(getBaseBlockPos(state, pos))) { + if (!isValidPosition(state, worldIn, pos)) { + worldIn.destroyBlock(pos, true); + return; + } + } + } + + private boolean isValidPosition(BlockState state, IBlockReader world, BlockPos pos, Direction facing) { + BlockPos baseBlockPos = getBaseBlockPos(state, pos); + if (!isValidBaseBlock(world.getBlockState(baseBlockPos), world, pos)) + return false; + for (Direction otherFacing : Direction.values()) { + if (otherFacing.getAxis().isVertical()) + continue; + if (otherFacing == facing) + continue; + BlockPos otherPos = baseBlockPos.offset(otherFacing); + BlockState otherState = world.getBlockState(otherPos); + if (otherState.getBlock() instanceof EngineBlock + && getBaseBlockPos(otherState, otherPos).equals(baseBlockPos)) + return false; + } + + return true; + } + + public static BlockPos getBaseBlockPos(BlockState state, BlockPos pos) { + return pos.offset(state.get(HORIZONTAL_FACING).getOpposite()); + } + + @Nullable + @OnlyIn(Dist.CLIENT) + public abstract AllBlockPartials getFrameModel(); + + protected abstract boolean isValidBaseBlock(BlockState baseBlock, IBlockReader world, BlockPos pos); + +} diff --git a/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/engine/EngineRenderer.java b/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/engine/EngineRenderer.java new file mode 100644 index 000000000..9f4579451 --- /dev/null +++ b/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/engine/EngineRenderer.java @@ -0,0 +1,30 @@ +package com.simibubi.create.modules.contraptions.components.flywheel.engine; + +import com.simibubi.create.AllBlockPartials; +import com.simibubi.create.foundation.block.SafeTileEntityRendererFast; +import com.simibubi.create.foundation.utility.AngleHelper; + +import net.minecraft.block.Block; +import net.minecraft.client.renderer.BufferBuilder; +import net.minecraft.util.Direction; +import net.minecraft.util.Direction.Axis; + +public class EngineRenderer extends SafeTileEntityRendererFast { + + @Override + protected void renderFast(T te, double x, double y, double z, float partialTicks, int destroyStage, + BufferBuilder buffer) { + Block block = te.getBlockState().getBlock(); + if (block instanceof EngineBlock) { + EngineBlock engineBlock = (EngineBlock) block; + AllBlockPartials frame = engineBlock.getFrameModel(); + if (frame != null) { + Direction facing = te.getBlockState().get(EngineBlock.HORIZONTAL_FACING); + float angle = AngleHelper.rad(AngleHelper.horizontalAngle(facing)); + frame.renderOn(te.getBlockState()).translate(0, 0, -1).rotateCentered(Axis.Y, angle).translate(x, y, z) + .light(te.getBlockState().getPackedLightmapCoords(getWorld(), te.getPos())).renderInto(buffer); + } + } + } + +} diff --git a/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/engine/EngineTileEntity.java b/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/engine/EngineTileEntity.java new file mode 100644 index 000000000..7bff98dd6 --- /dev/null +++ b/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/engine/EngineTileEntity.java @@ -0,0 +1,99 @@ +package com.simibubi.create.modules.contraptions.components.flywheel.engine; + +import java.util.List; + +import com.simibubi.create.AllBlocks; +import com.simibubi.create.foundation.behaviour.base.SmartTileEntity; +import com.simibubi.create.foundation.behaviour.base.TileEntityBehaviour; +import com.simibubi.create.modules.contraptions.components.flywheel.FlywheelBlock; +import com.simibubi.create.modules.contraptions.components.flywheel.FlywheelTileEntity; + +import net.minecraft.block.BlockState; +import net.minecraft.tileentity.TileEntity; +import net.minecraft.tileentity.TileEntityType; +import net.minecraft.util.Direction; +import net.minecraft.util.math.AxisAlignedBB; +import net.minecraft.util.math.BlockPos; + +public class EngineTileEntity extends SmartTileEntity { + + public float appliedCapacity; + public float appliedSpeed; + protected FlywheelTileEntity poweredWheel; + + public EngineTileEntity(TileEntityType tileEntityTypeIn) { + super(tileEntityTypeIn); + } + + @Override + public void addBehaviours(List behaviours) { + } + + @Override + public boolean hasFastRenderer() { + return true; + } + + @Override + public AxisAlignedBB getRenderBoundingBox() { + return super.getRenderBoundingBox().grow(1.5f); + } + + @Override + public void initialize() { + super.initialize(); + lazyTick(); + } + + @Override + public void lazyTick() { + super.lazyTick(); + if (world.isRemote) + return; + if (poweredWheel != null && poweredWheel.isRemoved()) + poweredWheel = null; + + if (poweredWheel == null) + attachWheel(); + } + + public void attachWheel() { + Direction engineFacing = getBlockState().get(EngineBlock.HORIZONTAL_FACING); + BlockPos wheelPos = pos.offset(engineFacing, 2); + BlockState wheelState = world.getBlockState(wheelPos); + if (!AllBlocks.FLYWHEEL.typeOf(wheelState)) + return; + Direction wheelFacing = wheelState.get(FlywheelBlock.HORIZONTAL_FACING); + if (wheelFacing.getAxis() != engineFacing.rotateY().getAxis()) + return; + if (FlywheelBlock.isConnected(wheelState) + && FlywheelBlock.getConnection(wheelState) != engineFacing.getOpposite()) + return; + TileEntity te = world.getTileEntity(wheelPos); + if (te instanceof FlywheelTileEntity) { + if (!FlywheelBlock.isConnected(wheelState)) + FlywheelBlock.setConnection(world, te.getPos(), te.getBlockState(), engineFacing.getOpposite()); + poweredWheel = (FlywheelTileEntity) te; + refreshWheelSpeed(); + } + } + + public void detachWheel() { + poweredWheel.setRotation(0, 0); + FlywheelBlock.setConnection(world, poweredWheel.getPos(), poweredWheel.getBlockState(), null); + } + + @Override + public void remove() { + if (poweredWheel != null) + detachWheel(); + super.remove(); + } + + protected void refreshWheelSpeed() { + if (poweredWheel == null) + return; + poweredWheel.setRotation(appliedSpeed, appliedCapacity); + } + +} diff --git a/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/engine/FurnaceEngineBlock.java b/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/engine/FurnaceEngineBlock.java new file mode 100644 index 000000000..6d77f6eed --- /dev/null +++ b/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/engine/FurnaceEngineBlock.java @@ -0,0 +1,79 @@ +package com.simibubi.create.modules.contraptions.components.flywheel.engine; + +import com.simibubi.create.AllBlockPartials; +import com.simibubi.create.AllBlocks; +import com.simibubi.create.foundation.block.IWithTileEntity; +import com.simibubi.create.foundation.utility.AllShapes; + +import net.minecraft.block.AbstractFurnaceBlock; +import net.minecraft.block.Block; +import net.minecraft.block.BlockState; +import net.minecraft.block.Blocks; +import net.minecraft.item.BlockItem; +import net.minecraft.item.ItemStack; +import net.minecraft.tileentity.TileEntity; +import net.minecraft.util.math.BlockPos; +import net.minecraft.util.math.shapes.ISelectionContext; +import net.minecraft.util.math.shapes.VoxelShape; +import net.minecraft.world.IBlockReader; +import net.minecraft.world.World; +import net.minecraftforge.event.entity.player.PlayerInteractEvent.RightClickBlock; +import net.minecraftforge.eventbus.api.Event.Result; +import net.minecraftforge.eventbus.api.SubscribeEvent; +import net.minecraftforge.fml.common.Mod.EventBusSubscriber; + +@EventBusSubscriber +public class FurnaceEngineBlock extends EngineBlock implements IWithTileEntity { + + public FurnaceEngineBlock() { + super(Properties.from(Blocks.GOLD_BLOCK)); + } + + @Override + protected boolean isValidBaseBlock(BlockState baseBlock, IBlockReader world, BlockPos pos) { + return baseBlock.getBlock() instanceof AbstractFurnaceBlock; + } + + @Override + public VoxelShape getShape(BlockState state, IBlockReader worldIn, BlockPos pos, ISelectionContext context) { + return AllShapes.FURNACE_ENGINE.get(state.get(HORIZONTAL_FACING)); + } + + @Override + public AllBlockPartials getFrameModel() { + return AllBlockPartials.FURNACE_GENERATOR_FRAME; + } + + @Override + public TileEntity createTileEntity(BlockState state, IBlockReader world) { + return new FurnaceEngineTileEntity(); + } + + @Override + public void neighborChanged(BlockState state, World worldIn, BlockPos pos, Block blockIn, BlockPos fromPos, + boolean isMoving) { + super.neighborChanged(state, worldIn, pos, blockIn, fromPos, isMoving); + if (worldIn.isRemote) + return; + + if (fromPos.equals(getBaseBlockPos(state, pos))) + if (isValidPosition(state, worldIn, pos)) + withTileEntityDo(worldIn, pos, FurnaceEngineTileEntity::updateFurnace); + } + + @SubscribeEvent + public static void usingFurnaceEngineOnFurnacePreventsGUI(RightClickBlock event) { + ItemStack item = event.getItemStack(); + if (!(item.getItem() instanceof BlockItem)) + return; + BlockItem blockItem = (BlockItem) item.getItem(); + if (blockItem.getBlock() != AllBlocks.FURNACE_ENGINE.get()) + return; + BlockState state = event.getWorld().getBlockState(event.getPos()); + if (event.getFace().getAxis().isVertical()) + return; + if (state.getBlock() instanceof AbstractFurnaceBlock) + event.setUseBlock(Result.DENY); + } + +} diff --git a/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/engine/FurnaceEngineTileEntity.java b/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/engine/FurnaceEngineTileEntity.java new file mode 100644 index 000000000..185361304 --- /dev/null +++ b/src/main/java/com/simibubi/create/modules/contraptions/components/flywheel/engine/FurnaceEngineTileEntity.java @@ -0,0 +1,36 @@ +package com.simibubi.create.modules.contraptions.components.flywheel.engine; + +import com.simibubi.create.AllTileEntities; + +import net.minecraft.block.AbstractFurnaceBlock; +import net.minecraft.block.BlockState; +import net.minecraft.block.Blocks; + +public class FurnaceEngineTileEntity extends EngineTileEntity { + + public FurnaceEngineTileEntity() { + super(AllTileEntities.FURNACE_ENGINE.type); + } + + @Override + public void lazyTick() { + updateFurnace(); + super.lazyTick(); + } + + public void updateFurnace() { + BlockState state = world.getBlockState(EngineBlock.getBaseBlockPos(getBlockState(), pos)); + if (!(state.getBlock() instanceof AbstractFurnaceBlock)) + return; + + float modifier = state.getBlock() == Blocks.BLAST_FURNACE ? 2 : 1; + boolean active = state.has(AbstractFurnaceBlock.LIT) && state.get(AbstractFurnaceBlock.LIT); + float speed = active ? 16 * modifier : 0; + float capacity = active ? 512 : 0; + + appliedCapacity = capacity; + appliedSpeed = speed; + refreshWheelSpeed(); + } + +} diff --git a/src/main/java/com/simibubi/create/modules/contraptions/relays/gauge/GaugeInformationRenderer.java b/src/main/java/com/simibubi/create/modules/contraptions/relays/gauge/GaugeInformationRenderer.java index 9a6eb4acd..bb3bf47e4 100644 --- a/src/main/java/com/simibubi/create/modules/contraptions/relays/gauge/GaugeInformationRenderer.java +++ b/src/main/java/com/simibubi/create/modules/contraptions/relays/gauge/GaugeInformationRenderer.java @@ -115,8 +115,8 @@ public class GaugeInformationRenderer { tooltip.add(spacing + GRAY + _stressImpact); String addedStress = AQUA + "" + format(stressApplied) + _stressUnit + " " + DARK_GRAY + _atCurrentSpeed; - String addedStressAtBase = GRAY + "" + format(stressApplied * te.getSpeed()) + _stressUnit + " " + DARK_GRAY - + _baseValue; + String addedStressAtBase = GRAY + "" + format(stressApplied * Math.abs(te.getSpeed())) + _stressUnit + " " + + DARK_GRAY + _baseValue; tooltip.add(spacing + " " + addedStress); tooltip.add(spacing + " " + addedStressAtBase); } diff --git a/src/main/resources/assets/create/blockstates/flywheel.json b/src/main/resources/assets/create/blockstates/flywheel.json new file mode 100644 index 000000000..8a469a059 --- /dev/null +++ b/src/main/resources/assets/create/blockstates/flywheel.json @@ -0,0 +1,18 @@ +{ + "forge_marker": 1, + "defaults": { + }, + "variants": { + "facing": { + "north": { "y": 270 }, + "south": { "y": 90 }, + "east": { "y": 0 }, + "west": { "y": 180 } + }, + "connection": { + "none": { "model": "create:block/flywheel/casing_no_connection" }, + "left": { "model": "create:block/flywheel/casing_left" }, + "right": { "model": "create:block/flywheel/casing_right" } + } + } +} \ No newline at end of file diff --git a/src/main/resources/assets/create/blockstates/furnace_engine.json b/src/main/resources/assets/create/blockstates/furnace_engine.json new file mode 100644 index 000000000..e2abdd163 --- /dev/null +++ b/src/main/resources/assets/create/blockstates/furnace_engine.json @@ -0,0 +1,14 @@ +{ + "forge_marker": 1, + "defaults": { + "model": "create:block/furnace_engine/body" + }, + "variants": { + "facing": { + "north": { "y": 180 }, + "south": { "y": 0 }, + "west": { "y": 90 }, + "east": { "y": 270 } + } + } +} \ No newline at end of file diff --git a/src/main/resources/assets/create/lang/en_us.json b/src/main/resources/assets/create/lang/en_us.json index 75df95664..e708d3fcb 100644 --- a/src/main/resources/assets/create/lang/en_us.json +++ b/src/main/resources/assets/create/lang/en_us.json @@ -103,6 +103,8 @@ "block.create.deployer": "Deployer", "block.create.basin": "Basin", "block.create.mechanical_crafter": "Mechanical Crafter", + "block.create.flywheel": "Flywheel", + "block.create.furnace_engine": "Furnace Engine", "block.create.speed_gauge": "Speedometer", "block.create.stress_gauge": "Stress Gauge", "block.create.cart_assembler": "Cart Assembler", diff --git a/src/main/resources/assets/create/models/block/flywheel/casing_left.json b/src/main/resources/assets/create/models/block/flywheel/casing_left.json new file mode 100644 index 000000000..dac493187 --- /dev/null +++ b/src/main/resources/assets/create/models/block/flywheel/casing_left.json @@ -0,0 +1,95 @@ +{ + "credit": "Made with Blockbench", + "textures": { + "0": "create:block/steam_engine_wheel", + "5": "create:block/brass_casing", + "7": "create:block/brass_gearbox", + "particle": "create:block/steam_engine_wheel" + }, + "elements": [ + { + "from": [1, 0, 0], + "to": [12, 16, 16], + "faces": { + "north": {"uv": [0, 10, 8, 15.5], "rotation": 270, "texture": "#0"}, + "east": {"uv": [0, 0, 16, 16], "texture": "#7"}, + "south": {"uv": [8, 15.5, 16, 10], "rotation": 270, "texture": "#0"}, + "west": {"uv": [0, 0, 16, 16], "texture": "#7"}, + "up": {"uv": [8, 10.5, 16, 16], "rotation": 270, "texture": "#0"}, + "down": {"uv": [8, 10.5, 16, 16], "rotation": 270, "texture": "#0"} + } + }, + { + "from": [0, 0, 0], + "to": [1, 2, 16], + "rotation": {"angle": 0, "axis": "y", "origin": [8, 8, 24]}, + "faces": { + "north": {"uv": [15, 14, 16, 16], "texture": "#5"}, + "east": {"uv": [0, 0, 16, 2], "texture": "#5"}, + "south": {"uv": [0, 14, 1, 16], "texture": "#5"}, + "west": {"uv": [0, 14, 16, 16], "texture": "#5"}, + "up": {"uv": [0, 1, 16, 2], "rotation": 90, "texture": "#5"}, + "down": {"uv": [0, 0, 16, 1], "rotation": 270, "texture": "#5"} + } + }, + { + "from": [0, 14, 0], + "to": [1, 16, 16], + "rotation": {"angle": 0, "axis": "y", "origin": [0, 8, 8]}, + "faces": { + "north": {"uv": [0, 14, 1, 16], "rotation": 180, "texture": "#5"}, + "east": {"uv": [0, 0, 16, 2], "rotation": 180, "texture": "#5"}, + "south": {"uv": [15, 14, 16, 16], "rotation": 180, "texture": "#5"}, + "west": {"uv": [0, 14, 16, 16], "rotation": 180, "texture": "#5"}, + "up": {"uv": [0, 0, 16, 1], "rotation": 270, "texture": "#5"}, + "down": {"uv": [0, 1, 16, 2], "rotation": 90, "texture": "#5"} + } + }, + { + "from": [0, 2, 0], + "to": [1, 14, 2], + "rotation": {"angle": 0, "axis": "y", "origin": [0, 8, 8]}, + "faces": { + "north": {"uv": [2, 0, 14, 1], "rotation": 90, "texture": "#5"}, + "east": {"uv": [0, 0, 12, 2], "rotation": 270, "texture": "#5"}, + "south": {"uv": [2, 1, 14, 2], "rotation": 90, "texture": "#5"}, + "west": {"uv": [2, 14, 14, 16], "rotation": 90, "texture": "#5"}, + "up": {"uv": [15, 14, 16, 16], "rotation": 180, "texture": "#5"}, + "down": {"uv": [0, 14, 1, 16], "texture": "#5"} + } + }, + { + "from": [0, 2, 14], + "to": [1, 14, 16], + "rotation": {"angle": 0, "axis": "y", "origin": [0, 8, 8]}, + "faces": { + "north": {"uv": [2, 1, 14, 2], "rotation": 270, "texture": "#5"}, + "east": {"uv": [0, 0, 12, 2], "rotation": 90, "texture": "#5"}, + "south": {"uv": [2, 0, 14, 1], "rotation": 270, "texture": "#5"}, + "west": {"uv": [2, 14, 14, 16], "rotation": 270, "texture": "#5"}, + "up": {"uv": [0, 14, 1, 16], "texture": "#5"}, + "down": {"uv": [15, 14, 16, 16], "rotation": 180, "texture": "#5"} + } + }, + { + "from": [10.9, 3, 3], + "to": [19.9, 13, 13], + "rotation": {"angle": 0, "axis": "y", "origin": [14.9, 8, 8]}, + "faces": { + "north": {"uv": [11.5, 0, 16, 5], "rotation": 180, "texture": "#0"}, + "east": {"uv": [11, 5, 16, 10], "texture": "#0"}, + "south": {"uv": [11.5, 0, 16, 5], "texture": "#0"}, + "west": {"uv": [11, 5, 16, 10], "texture": "#0"}, + "up": {"uv": [11.5, 0, 16, 5], "texture": "#0"}, + "down": {"uv": [11.5, 0, 16, 5], "texture": "#0"} + } + } + ], + "groups": [ + { + "name": "transmission", + "origin": [-8, 8, 8], + "children": [0, 1, 2, 3, 4, 5] + } + ] +} \ No newline at end of file diff --git a/src/main/resources/assets/create/models/block/flywheel/casing_no_connection.json b/src/main/resources/assets/create/models/block/flywheel/casing_no_connection.json new file mode 100644 index 000000000..ff52149d8 --- /dev/null +++ b/src/main/resources/assets/create/models/block/flywheel/casing_no_connection.json @@ -0,0 +1,95 @@ +{ + "credit": "Made with Blockbench", + "textures": { + "0": "create:block/steam_engine_wheel", + "5": "create:block/brass_casing", + "7": "create:block/brass_gearbox", + "particle": "create:block/steam_engine_wheel" + }, + "elements": [ + { + "from": [1, 0, 0], + "to": [12, 16, 16], + "faces": { + "north": {"uv": [8, 10.5, 16, 16], "rotation": 90, "texture": "#0"}, + "east": {"uv": [0, 0, 16, 16], "texture": "#7"}, + "south": {"uv": [8, 10.5, 16, 16], "rotation": 270, "texture": "#0"}, + "west": {"uv": [0, 0, 16, 16], "texture": "#7"}, + "up": {"uv": [8, 10.5, 16, 16], "rotation": 270, "texture": "#0"}, + "down": {"uv": [8, 10.5, 16, 16], "rotation": 270, "texture": "#0"} + } + }, + { + "from": [0, 0, 0], + "to": [1, 2, 16], + "rotation": {"angle": 0, "axis": "y", "origin": [8, 8, 24]}, + "faces": { + "north": {"uv": [15, 14, 16, 16], "texture": "#5"}, + "east": {"uv": [0, 0, 16, 2], "texture": "#5"}, + "south": {"uv": [0, 14, 1, 16], "texture": "#5"}, + "west": {"uv": [0, 14, 16, 16], "texture": "#5"}, + "up": {"uv": [0, 1, 16, 2], "rotation": 90, "texture": "#5"}, + "down": {"uv": [0, 0, 16, 1], "rotation": 270, "texture": "#5"} + } + }, + { + "from": [0, 14, 0], + "to": [1, 16, 16], + "rotation": {"angle": 0, "axis": "y", "origin": [0, 8, 8]}, + "faces": { + "north": {"uv": [0, 14, 1, 16], "rotation": 180, "texture": "#5"}, + "east": {"uv": [0, 0, 16, 2], "rotation": 180, "texture": "#5"}, + "south": {"uv": [15, 14, 16, 16], "rotation": 180, "texture": "#5"}, + "west": {"uv": [0, 14, 16, 16], "rotation": 180, "texture": "#5"}, + "up": {"uv": [0, 0, 16, 1], "rotation": 270, "texture": "#5"}, + "down": {"uv": [0, 1, 16, 2], "rotation": 90, "texture": "#5"} + } + }, + { + "from": [0, 2, 0], + "to": [1, 14, 2], + "rotation": {"angle": 0, "axis": "y", "origin": [0, 8, 8]}, + "faces": { + "north": {"uv": [2, 0, 14, 1], "rotation": 90, "texture": "#5"}, + "east": {"uv": [0, 0, 12, 2], "rotation": 270, "texture": "#5"}, + "south": {"uv": [2, 1, 14, 2], "rotation": 90, "texture": "#5"}, + "west": {"uv": [2, 14, 14, 16], "rotation": 90, "texture": "#5"}, + "up": {"uv": [15, 14, 16, 16], "rotation": 180, "texture": "#5"}, + "down": {"uv": [0, 14, 1, 16], "texture": "#5"} + } + }, + { + "from": [0, 2, 14], + "to": [1, 14, 16], + "rotation": {"angle": 0, "axis": "y", "origin": [0, 8, 8]}, + "faces": { + "north": {"uv": [2, 1, 14, 2], "rotation": 270, "texture": "#5"}, + "east": {"uv": [0, 0, 12, 2], "rotation": 90, "texture": "#5"}, + "south": {"uv": [2, 0, 14, 1], "rotation": 270, "texture": "#5"}, + "west": {"uv": [2, 14, 14, 16], "rotation": 270, "texture": "#5"}, + "up": {"uv": [0, 14, 1, 16], "texture": "#5"}, + "down": {"uv": [15, 14, 16, 16], "rotation": 180, "texture": "#5"} + } + }, + { + "from": [10.9, 3, 3], + "to": [19.9, 13, 13], + "rotation": {"angle": 0, "axis": "y", "origin": [14.9, 8, 8]}, + "faces": { + "north": {"uv": [11.5, 0, 16, 5], "rotation": 180, "texture": "#0"}, + "east": {"uv": [11, 5, 16, 10], "texture": "#0"}, + "south": {"uv": [11.5, 0, 16, 5], "texture": "#0"}, + "west": {"uv": [11, 5, 16, 10], "texture": "#0"}, + "up": {"uv": [11.5, 0, 16, 5], "texture": "#0"}, + "down": {"uv": [11.5, 0, 16, 5], "texture": "#0"} + } + } + ], + "groups": [ + { + "name": "transmission", + "origin": [-8, 8, 8], + "children": [0, 1, 2, 3, 4, 5] + } + ] +} \ No newline at end of file diff --git a/src/main/resources/assets/create/models/block/flywheel/casing_right.json b/src/main/resources/assets/create/models/block/flywheel/casing_right.json new file mode 100644 index 000000000..706c95184 --- /dev/null +++ b/src/main/resources/assets/create/models/block/flywheel/casing_right.json @@ -0,0 +1,95 @@ +{ + "credit": "Made with Blockbench", + "textures": { + "0": "create:block/steam_engine_wheel", + "5": "create:block/brass_casing", + "7": "create:block/brass_gearbox", + "particle": "create:block/steam_engine_wheel" + }, + "elements": [ + { + "from": [1, 0, 0], + "to": [12, 16, 16], + "faces": { + "north": {"uv": [8, 10.5, 16, 16], "rotation": 90, "texture": "#0"}, + "east": {"uv": [0, 0, 16, 16], "texture": "#7"}, + "south": {"uv": [0, 15.5, 8, 10], "rotation": 270, "texture": "#0"}, + "west": {"uv": [0, 0, 16, 16], "texture": "#7"}, + "up": {"uv": [8, 10.5, 16, 16], "rotation": 270, "texture": "#0"}, + "down": {"uv": [8, 10.5, 16, 16], "rotation": 270, "texture": "#0"} + } + }, + { + "from": [0, 0, 0], + "to": [1, 2, 16], + "rotation": {"angle": 0, "axis": "y", "origin": [8, 8, 24]}, + "faces": { + "north": {"uv": [15, 14, 16, 16], "texture": "#5"}, + "east": {"uv": [0, 0, 16, 2], "texture": "#5"}, + "south": {"uv": [0, 14, 1, 16], "texture": "#5"}, + "west": {"uv": [0, 14, 16, 16], "texture": "#5"}, + "up": {"uv": [0, 1, 16, 2], "rotation": 90, "texture": "#5"}, + "down": {"uv": [0, 0, 16, 1], "rotation": 270, "texture": "#5"} + } + }, + { + "from": [0, 14, 0], + "to": [1, 16, 16], + "rotation": {"angle": 0, "axis": "y", "origin": [0, 8, 8]}, + "faces": { + "north": {"uv": [0, 14, 1, 16], "rotation": 180, "texture": "#5"}, + "east": {"uv": [0, 0, 16, 2], "rotation": 180, "texture": "#5"}, + "south": {"uv": [15, 14, 16, 16], "rotation": 180, "texture": "#5"}, + "west": {"uv": [0, 14, 16, 16], "rotation": 180, "texture": "#5"}, + "up": {"uv": [0, 0, 16, 1], "rotation": 270, "texture": "#5"}, + "down": {"uv": [0, 1, 16, 2], "rotation": 90, "texture": "#5"} + } + }, + { + "from": [0, 2, 0], + "to": [1, 14, 2], + "rotation": {"angle": 0, "axis": "y", "origin": [0, 8, 8]}, + "faces": { + "north": {"uv": [2, 0, 14, 1], "rotation": 90, "texture": "#5"}, + "east": {"uv": [0, 0, 12, 2], "rotation": 270, "texture": "#5"}, + "south": {"uv": [2, 1, 14, 2], "rotation": 90, "texture": "#5"}, + "west": {"uv": [2, 14, 14, 16], "rotation": 90, "texture": "#5"}, + "up": {"uv": [15, 14, 16, 16], "rotation": 180, "texture": "#5"}, + "down": {"uv": [0, 14, 1, 16], "texture": "#5"} + } + }, + { + "from": [0, 2, 14], + "to": [1, 14, 16], + "rotation": {"angle": 0, "axis": "y", "origin": [0, 8, 8]}, + "faces": { + "north": {"uv": [2, 1, 14, 2], "rotation": 270, "texture": "#5"}, + "east": {"uv": [0, 0, 12, 2], "rotation": 90, "texture": "#5"}, + "south": {"uv": [2, 0, 14, 1], "rotation": 270, "texture": "#5"}, + "west": {"uv": [2, 14, 14, 16], "rotation": 270, "texture": "#5"}, + "up": {"uv": [0, 14, 1, 16], "texture": "#5"}, + "down": {"uv": [15, 14, 16, 16], "rotation": 180, "texture": "#5"} + } + }, + { + "from": [10.9, 3, 3], + "to": [19.9, 13, 13], + "rotation": {"angle": 0, "axis": "y", "origin": [14.9, 8, 8]}, + "faces": { + "north": {"uv": [11.5, 0, 16, 5], "rotation": 180, "texture": "#0"}, + "east": {"uv": [11, 5, 16, 10], "texture": "#0"}, + "south": {"uv": [11.5, 0, 16, 5], "texture": "#0"}, + "west": {"uv": [11, 5, 16, 10], "texture": "#0"}, + "up": {"uv": [11.5, 0, 16, 5], "texture": "#0"}, + "down": {"uv": [11.5, 0, 16, 5], "texture": "#0"} + } + } + ], + "groups": [ + { + "name": "transmission", + "origin": [-8, 8, 8], + "children": [0, 1, 2, 3, 4, 5] + } + ] +} \ No newline at end of file diff --git a/src/main/resources/assets/create/models/block/flywheel/flywheel.bbmodel b/src/main/resources/assets/create/models/block/flywheel/flywheel.bbmodel new file mode 100644 index 000000000..a1c9455f2 --- /dev/null +++ b/src/main/resources/assets/create/models/block/flywheel/flywheel.bbmodel @@ -0,0 +1 @@ +{"meta":{"format_version":"3.2","model_format":"java_block","box_uv":false},"name":"item","resolution":{"width":16,"height":16},"elements":[{"name":"cube","from":[22,6,6],"to":[32,10,10],"autouv":0,"color":0,"origin":[-5,8,8],"faces":{"north":{"uv":[2,7,7,9],"texture":0},"east":{"uv":[0,7,2,9],"texture":0},"south":{"uv":[2,7,7,9],"texture":0},"west":{"uv":[0,7,2,9],"texture":0},"up":{"uv":[2,7,7,9],"texture":0},"down":{"uv":[2,7,7,9],"texture":0}},"uuid":"50a686cc-3204-b7bf-1566-d1ef05844c60"},{"name":"cube","from":[7,7,7],"to":[23,9,9],"autouv":0,"color":4,"rotation":[0,0,-22.5],"origin":[23,8,8],"faces":{"north":{"uv":[0,9,8,10],"rotation":180,"texture":0},"east":{"uv":[0,0,0,0],"rotation":180,"texture":null},"south":{"uv":[0,9,8,10],"rotation":180,"texture":0},"west":{"uv":[0,0,0,0],"rotation":180,"texture":null},"up":{"uv":[0,9,8,10],"rotation":180,"texture":0},"down":{"uv":[0,9,8,10],"rotation":180,"texture":0}},"uuid":"b575be0b-21f0-8150-9d24-be88ac50d1df"},{"name":"cube","from":[3,3,-3.9000000000000004],"to":[13,13,5.1],"autouv":0,"color":5,"origin":[8,8,1.0999999999999996],"faces":{"north":{"uv":[11,5,16,10],"texture":0},"east":{"uv":[11.5,0,16,5],"texture":0},"south":{"uv":[11,5,16,10],"texture":0},"west":{"uv":[11.5,0,16,5],"rotation":180,"texture":0},"up":{"uv":[11.5,0,16,5],"rotation":270,"texture":0},"down":{"uv":[11.5,0,16,5],"rotation":90,"texture":0}},"uuid":"2f1e2920-2ea2-8af4-3221-eb3bc7043169"},{"name":"cube","from":[0,0,4],"to":[16,16,15],"autouv":0,"color":5,"origin":[8,8,8],"faces":{"north":{"uv":[0,0,16,16],"texture":5},"east":{"uv":[0,15.5,8,10],"rotation":270,"texture":0},"south":{"uv":[0,0,16,16],"texture":5},"west":{"uv":[8,10.5,16,16],"rotation":90,"texture":0},"up":{"uv":[8,10.5,16,16],"rotation":180,"texture":0},"down":{"uv":[8,10.5,16,16],"texture":0}},"uuid":"b0cd1b60-1f63-cbfa-eb62-4b456dfe2734"},{"name":"spoke","from":[6,-8,-0.8999999999999995],"to":[10,3,3.1000000000000005],"autouv":0,"color":0,"rotation":[0,0,-45],"origin":[8,8,1.1000000000000005],"faces":{"north":{"uv":[9,4.5,11,10],"rotation":180,"texture":0},"east":{"uv":[9,4.5,11,10],"rotation":180,"texture":0},"south":{"uv":[9,4.5,11,10],"rotation":180,"texture":0},"west":{"uv":[9,4.5,11,10],"rotation":180,"texture":0},"up":{"uv":[0,0,0,0],"rotation":90,"texture":null},"down":{"uv":[0,0,0,0],"rotation":270,"texture":null}},"uuid":"cb470bb9-82ea-3186-ac3f-e6cd886649bc"},{"name":"cube","from":[-0.5,23.5,-1.8500000000000005],"to":[16.5,28.5,4.049999999999998],"autouv":0,"color":4,"rotation":[0,0,-45],"origin":[8,8,1.0999999999999988],"faces":{"north":{"uv":[0,0,8.5,2.5],"texture":0},"east":{"uv":[8.5,0,11.5,2.5],"texture":0},"south":{"uv":[0,0,8.5,2.5],"texture":0},"west":{"uv":[8.5,0,11.5,2.5],"texture":0},"up":{"uv":[0,2.5,8.5,5.5],"texture":0},"down":{"uv":[0,2.5,8.5,5.5],"texture":0}},"uuid":"63aed4d8-2ff2-0746-1545-6a76e0d97a9c"},{"name":"cube","from":[-0.5,23.5,-1.9000000000000012],"to":[16.5,28.5,4.099999999999999],"autouv":0,"color":4,"origin":[8,8,1.0999999999999988],"faces":{"north":{"uv":[0,0,8.5,2.5],"texture":0},"east":{"uv":[8.5,0,11.5,2],"texture":0},"south":{"uv":[0,0,8.5,2.5],"texture":0},"west":{"uv":[8.5,0,11.5,2.5],"texture":0},"up":{"uv":[0,2.5,8.5,5.5],"texture":0},"down":{"uv":[0,2.5,8.5,5.5],"texture":0}},"uuid":"6fce1c92-91b6-6314-3bcc-81af1da4fcde"},{"name":"cube","from":[14.75,7,11.549999999999997],"to":[30.75,9,13.449999999999996],"autouv":0,"color":7,"rotation":[0,0,-22.5],"origin":[15,8,21],"faces":{"north":{"uv":[0,9,8,10],"rotation":180,"texture":0},"east":{"uv":[0,0,0,0],"rotation":270,"texture":null},"south":{"uv":[0,9,8,10],"rotation":180,"texture":0},"west":{"uv":[0,0,0,0],"rotation":270,"texture":null},"up":{"uv":[0,9,8,10],"rotation":180,"texture":0},"down":{"uv":[0,9,8,10],"rotation":180,"texture":0}},"uuid":"206f3d87-1379-a949-ead0-500086d5bbe2"},{"name":"cube","from":[29,1,11.5],"to":[32,3,13.5],"autouv":0,"color":4,"origin":[8,8,17],"faces":{"north":{"uv":[6.5,9,8,10],"rotation":180,"texture":0},"east":{"uv":[0,9,1.5,10],"rotation":180,"texture":0},"south":{"uv":[0,9,1.5,10],"rotation":180,"texture":0},"west":{"uv":[0,9,1.5,10],"rotation":180,"texture":0},"up":{"uv":[0,9,1.5,10],"rotation":180,"texture":0},"down":{"uv":[0,9,1.5,10],"rotation":180,"texture":0}},"uuid":"0af1e6ff-4a9e-283a-2942-84d3ec8b5836"},{"name":"cube","from":[23.5,-0.5,-1.9000000000000012],"to":[28.5,16.5,4.099999999999999],"autouv":0,"color":4,"origin":[8,8,1.0999999999999988],"faces":{"north":{"uv":[0,0,8.5,2.5],"rotation":270,"texture":0},"east":{"uv":[0,2.5,8.5,5.5],"rotation":90,"texture":0},"south":{"uv":[0,0,8.5,2.5],"rotation":90,"texture":0},"west":{"uv":[0,2.5,8.5,5.5],"rotation":90,"texture":0},"up":{"uv":[8.5,0,11.5,2.5],"rotation":90,"texture":0},"down":{"uv":[8.5,0,11.5,2],"rotation":90,"texture":0}},"uuid":"a5520e2b-ba0a-b510-e5ea-f1a950a16250"},{"name":"cube","from":[-0.5,-12.5,-1.8500000000000005],"to":[16.5,-7.5,4.049999999999998],"autouv":0,"color":4,"rotation":[0,0,45],"origin":[8,8,1.0999999999999988],"faces":{"north":{"uv":[0,0,8.5,2.5],"rotation":180,"texture":0},"east":{"uv":[8.5,0,11.5,2.5],"rotation":180,"texture":0},"south":{"uv":[0,0,8.5,2.5],"rotation":180,"texture":0},"west":{"uv":[8.5,0,11.5,2.5],"rotation":180,"texture":0},"up":{"uv":[0,2.5,8.5,5.5],"rotation":180,"texture":0},"down":{"uv":[0,2.5,8.5,5.5],"rotation":180,"texture":0}},"uuid":"2f5b7526-cca3-7518-3496-d1b0bbe08e75"},{"name":"cube","from":[-12.5,-0.5,-1.8500000000000005],"to":[-7.5,16.5,4.049999999999998],"autouv":0,"color":4,"rotation":[0,0,-45],"origin":[8,8,1.0999999999999988],"faces":{"north":{"uv":[0,0,8.5,2.5],"rotation":90,"texture":0},"east":{"uv":[0,2.5,8.5,5.5],"rotation":270,"texture":0},"south":{"uv":[0,0,8.5,2.5],"rotation":270,"texture":0},"west":{"uv":[0,2.5,8.5,5.5],"rotation":270,"texture":0},"up":{"uv":[8.5,0,11.5,2.5],"rotation":270,"texture":0},"down":{"uv":[8.5,0,11.5,2.5],"rotation":270,"texture":0}},"uuid":"429976b8-16fe-3f5c-55db-9aab4c9fbebc"},{"name":"cube","from":[-12.5,-0.5,-1.9000000000000012],"to":[-7.5,16.5,4.099999999999999],"autouv":0,"color":4,"origin":[8,8,1.0999999999999988],"faces":{"north":{"uv":[0,0,8.5,2.5],"rotation":90,"texture":0},"east":{"uv":[0,2.5,8.5,5.5],"rotation":270,"texture":0},"south":{"uv":[0,0,8.5,2.5],"rotation":270,"texture":0},"west":{"uv":[0,2.5,8.5,5.5],"rotation":270,"texture":0},"up":{"uv":[8.5,0,11.5,2],"rotation":270,"texture":0},"down":{"uv":[8.5,0,11.5,2.5],"rotation":270,"texture":0}},"uuid":"50806591-41a8-f2bc-7a1d-e43b23b96408"},{"name":"cube","from":[-0.5,-12.5,-1.8500000000000005],"to":[16.5,-7.5,4.049999999999998],"autouv":0,"color":4,"rotation":[0,0,-45],"origin":[8,8,1.0999999999999988],"faces":{"north":{"uv":[0,0,8.5,2.5],"rotation":180,"texture":0},"east":{"uv":[8.5,0,11.5,2.5],"rotation":180,"texture":0},"south":{"uv":[0,0,8.5,2.5],"rotation":180,"texture":0},"west":{"uv":[8.5,0,11.5,2.5],"rotation":180,"texture":0},"up":{"uv":[0,2.5,8.5,5.5],"rotation":180,"texture":0},"down":{"uv":[0,2.5,8.5,5.5],"rotation":180,"texture":0}},"uuid":"801950a3-dd0a-627f-7246-561bcad27e88"},{"name":"cube","from":[-0.5,-12.5,-1.9000000000000012],"to":[16.5,-7.5,4.099999999999999],"autouv":0,"color":4,"origin":[8,8,1.0999999999999988],"faces":{"north":{"uv":[0,0,8.5,2.5],"rotation":180,"texture":0},"east":{"uv":[8.5,0,11.5,2.5],"rotation":180,"texture":0},"south":{"uv":[0,0,8.5,2.5],"rotation":180,"texture":0},"west":{"uv":[8.5,0,11.5,2],"rotation":180,"texture":0},"up":{"uv":[0,2.5,8.5,5.5],"rotation":180,"texture":0},"down":{"uv":[0,2.5,8.5,5.5],"rotation":180,"texture":0}},"uuid":"b991a213-a5c0-1951-d6f3-229a0c14d9c5"},{"name":"cube","from":[0,0,15],"to":[16,2,16],"autouv":0,"color":3,"origin":[24,8,8],"faces":{"north":{"uv":[0,0,16,2],"texture":4},"east":{"uv":[0,14,1,16],"texture":4},"south":{"uv":[0,14,16,16],"texture":4},"west":{"uv":[15,14,16,16],"texture":4},"up":{"uv":[0,1,16,2],"texture":4},"down":{"uv":[0,0,16,1],"texture":4}},"uuid":"7883be7c-2f95-da04-1f6b-6eb29690cc04"},{"name":"cube","from":[0,14,15],"to":[16,16,16],"autouv":0,"color":3,"origin":[8,8,16],"faces":{"north":{"uv":[0,0,16,2],"rotation":180,"texture":4},"east":{"uv":[15,14,16,16],"rotation":180,"texture":4},"south":{"uv":[0,14,16,16],"rotation":180,"texture":4},"west":{"uv":[0,14,1,16],"rotation":180,"texture":4},"up":{"uv":[0,0,16,1],"rotation":180,"texture":4},"down":{"uv":[0,1,16,2],"rotation":180,"texture":4}},"uuid":"af3517df-2487-59e1-2d3b-ac71c65b47eb"},{"name":"cube","from":[0,2,15],"to":[2,14,16],"autouv":0,"color":3,"origin":[8,8,16],"faces":{"north":{"uv":[0,0,12,2],"rotation":270,"texture":4},"east":{"uv":[2,1,14,2],"rotation":90,"texture":4},"south":{"uv":[2,14,14,16],"rotation":90,"texture":4},"west":{"uv":[2,0,14,1],"rotation":90,"texture":4},"up":{"uv":[15,14,16,16],"rotation":90,"texture":4},"down":{"uv":[0,14,1,16],"rotation":90,"texture":4}},"uuid":"3236180d-0eb5-9846-f6df-71338b95b172"},{"name":"cube","from":[14,2,15],"to":[16,14,16],"autouv":0,"color":3,"origin":[8,8,16],"faces":{"north":{"uv":[0,0,12,2],"rotation":90,"texture":4},"east":{"uv":[2,0,14,1],"rotation":270,"texture":4},"south":{"uv":[2,14,14,16],"rotation":270,"texture":4},"west":{"uv":[2,1,14,2],"rotation":270,"texture":4},"up":{"uv":[0,14,1,16],"rotation":270,"texture":4},"down":{"uv":[15,14,16,16],"rotation":270,"texture":4}},"uuid":"ffb4c72b-0971-aa72-e873-312bea4c432f"},{"name":"spoke","from":[-8,6,-0.8999999999999995],"to":[3,10,3.1000000000000005],"autouv":0,"color":0,"rotation":[0,0,-45],"origin":[8,8,1.1000000000000005],"faces":{"north":{"uv":[9,4.5,11,10],"rotation":90,"texture":0},"east":{"uv":[0,0,0,0],"rotation":180,"texture":null},"south":{"uv":[9,4.5,11,10],"rotation":270,"texture":0},"west":{"uv":[0,0,0,0],"texture":null},"up":{"uv":[9,4.5,11,10],"rotation":270,"texture":0},"down":{"uv":[9,4.5,11,10],"rotation":270,"texture":0}},"uuid":"1dba4685-5282-a030-17a2-2f9374e8c6a1"},{"name":"spoke","from":[-8,6,-0.8999999999999995],"to":[3,10,3.1000000000000005],"autouv":0,"color":0,"origin":[8,8,1.1000000000000005],"faces":{"north":{"uv":[9,4.5,11,10],"rotation":90,"texture":0},"east":{"uv":[0,0,0,0],"rotation":180,"texture":null},"south":{"uv":[9,4.5,11,10],"rotation":270,"texture":0},"west":{"uv":[0,0,0,0],"texture":null},"up":{"uv":[9,4.5,11,10],"rotation":270,"texture":0},"down":{"uv":[9,4.5,11,10],"rotation":270,"texture":0}},"uuid":"b7cb6152-0be0-b1df-252e-0cab5138efdf"},{"name":"spoke","from":[13,6,-0.8999999999999995],"to":[24,10,3.1000000000000005],"autouv":0,"color":0,"rotation":[0,0,-45],"origin":[8,8,1.1000000000000005],"faces":{"north":{"uv":[9,4.5,11,10],"rotation":270,"texture":0},"east":{"uv":[0,0,0,0],"rotation":180,"texture":null},"south":{"uv":[9,4.5,11,10],"rotation":90,"texture":0},"west":{"uv":[0,0,0,0],"texture":null},"up":{"uv":[9,4.5,11,10],"rotation":90,"texture":0},"down":{"uv":[9,4.5,11,10],"rotation":90,"texture":0}},"uuid":"1b7cc7a0-6cc9-31a9-143f-94aee22489b4"},{"name":"spoke","from":[6,13,-0.8999999999999995],"to":[10,24,3.1000000000000005],"autouv":0,"color":0,"rotation":[0,0,-45],"origin":[8,8,1.1000000000000005],"faces":{"north":{"uv":[9,4.5,11,10],"texture":0},"east":{"uv":[9,4.5,11,10],"texture":0},"south":{"uv":[9,4.5,11,10],"texture":0},"west":{"uv":[9,4.5,11,10],"texture":0},"up":{"uv":[0,0,0,0],"rotation":90,"texture":null},"down":{"uv":[0,0,0,0],"rotation":270,"texture":null}},"uuid":"e65ae52f-ddd5-8121-f730-88b35ea0fb5a"},{"name":"spoke","from":[13,6,-0.8999999999999995],"to":[24,10,3.1000000000000005],"autouv":0,"color":0,"origin":[8,8,1.1000000000000005],"faces":{"north":{"uv":[9,4.5,11,10],"rotation":270,"texture":0},"east":{"uv":[0,0,0,0],"rotation":180,"texture":null},"south":{"uv":[9,4.5,11,10],"rotation":90,"texture":0},"west":{"uv":[0,0,0,0],"texture":null},"up":{"uv":[9,4.5,11,10],"rotation":90,"texture":0},"down":{"uv":[9,4.5,11,10],"rotation":90,"texture":0}},"uuid":"d7980b7f-ef13-e3e1-ab0d-537ffccff639"},{"name":"spoke","from":[6,-8,-0.8999999999999995],"to":[10,3,3.1000000000000005],"autouv":0,"color":0,"origin":[8,8,1.1000000000000005],"faces":{"north":{"uv":[9,4.5,11,10],"rotation":180,"texture":0},"east":{"uv":[9,4.5,11,10],"rotation":180,"texture":0},"south":{"uv":[9,4.5,11,10],"rotation":180,"texture":0},"west":{"uv":[9,4.5,11,10],"rotation":180,"texture":0},"up":{"uv":[0,0,0,0],"rotation":90,"texture":null},"down":{"uv":[0,0,0,0],"rotation":270,"texture":null}},"uuid":"841862c5-48f4-a81f-17fb-497457cbe793"},{"name":"spoke","from":[6,13,-0.8999999999999995],"to":[10,24,3.1000000000000005],"autouv":0,"color":0,"origin":[8,8,1.1000000000000005],"faces":{"north":{"uv":[9,4.5,11,10],"texture":0},"east":{"uv":[9,4.5,11,10],"texture":0},"south":{"uv":[9,4.5,11,10],"texture":0},"west":{"uv":[9,4.5,11,10],"texture":0},"up":{"uv":[0,0,0,0],"rotation":90,"texture":null},"down":{"uv":[0,0,0,0],"rotation":270,"texture":null}},"uuid":"29d0cc13-9e08-c9ca-7219-6f1c06816a16"}],"outliner":[{"name":"transmission","uuid":"29aace9e-9299-b75e-5ed5-db8534b5fcbd","export":true,"isOpen":true,"visibility":true,"autouv":0,"origin":[-8,8,8],"children":["0af1e6ff-4a9e-283a-2942-84d3ec8b5836","206f3d87-1379-a949-ead0-500086d5bbe2","50a686cc-3204-b7bf-1566-d1ef05844c60","b575be0b-21f0-8150-9d24-be88ac50d1df","b0cd1b60-1f63-cbfa-eb62-4b456dfe2734","7883be7c-2f95-da04-1f6b-6eb29690cc04","af3517df-2487-59e1-2d3b-ac71c65b47eb","3236180d-0eb5-9846-f6df-71338b95b172","ffb4c72b-0971-aa72-e873-312bea4c432f"]},{"name":"wheel","uuid":"a3567eb7-af40-11f6-7e9b-dab5508c4ff5","export":true,"isOpen":true,"visibility":true,"autouv":0,"origin":[24,8,8],"children":["2f1e2920-2ea2-8af4-3221-eb3bc7043169","6fce1c92-91b6-6314-3bcc-81af1da4fcde","b991a213-a5c0-1951-d6f3-229a0c14d9c5","a5520e2b-ba0a-b510-e5ea-f1a950a16250","50806591-41a8-f2bc-7a1d-e43b23b96408","63aed4d8-2ff2-0746-1545-6a76e0d97a9c","801950a3-dd0a-627f-7246-561bcad27e88","2f5b7526-cca3-7518-3496-d1b0bbe08e75","429976b8-16fe-3f5c-55db-9aab4c9fbebc","cb470bb9-82ea-3186-ac3f-e6cd886649bc","e65ae52f-ddd5-8121-f730-88b35ea0fb5a","b7cb6152-0be0-b1df-252e-0cab5138efdf","d7980b7f-ef13-e3e1-ab0d-537ffccff639","1dba4685-5282-a030-17a2-2f9374e8c6a1","841862c5-48f4-a81f-17fb-497457cbe793","1b7cc7a0-6cc9-31a9-143f-94aee22489b4","29d0cc13-9e08-c9ca-7219-6f1c06816a16"]}],"textures":[{"path":"C:\\Users\\simon\\Desktop\\Forge\\Create\\src\\main\\resources\\assets\\create\\textures\\block\\steam_engine_wheel.png","name":"steam_engine_wheel.png","folder":"block","namespace":"create","id":"0","particle":true,"mode":"bitmap","saved":true,"uuid":"00cbd3bd-665f-44c1-56df-1cd7fc617269","source":""},{"path":"C:\\Users\\simon\\Desktop\\Forge\\Create\\src\\main\\resources\\assets\\create\\textures\\block\\axis.png","name":"axis.png","folder":"block","namespace":"create","id":"1","particle":false,"mode":"bitmap","saved":true,"uuid":"11fa98c7-e27a-e24b-c2d5-5354841d3e37","source":""},{"path":"C:\\Users\\simon\\Desktop\\Forge\\Create\\src\\main\\resources\\assets\\create\\textures\\block\\axis_top.png","name":"axis_top.png","folder":"block","namespace":"create","id":"2","particle":false,"mode":"bitmap","saved":true,"uuid":"279bd0dd-96c2-3792-e8c9-19b78bfa04b1","source":""},{"path":"C:\\Users\\simon\\Desktop\\Forge\\Create\\src\\main\\resources\\assets\\create\\textures\\block\\furnace_cylinder.png","name":"furnace_cylinder.png","folder":"block","namespace":"create","id":"1_1","particle":false,"mode":"bitmap","saved":true,"uuid":"22db08fc-cd87-a68b-b384-8c82a249326f","source":""},{"path":"C:\\Users\\simon\\Desktop\\Forge\\Create\\src\\main\\resources\\assets\\create\\textures\\block\\brass_casing.png","name":"brass_casing.png","folder":"block","namespace":"create","id":"5","particle":false,"mode":"bitmap","saved":true,"uuid":"03f2b83c-2540-b890-0fa9-1048ec09c3c0","source":""},{"path":"C:\\Users\\simon\\Desktop\\Forge\\Create\\src\\main\\resources\\assets\\create\\textures\\block\\brass_gearbox.png","name":"brass_gearbox.png","folder":"block","namespace":"create","id":"7","particle":false,"mode":"bitmap","saved":true,"uuid":"c8e5c536-6dcc-dc5c-680c-9d18e67c9b7d","source":""},{"path":"D:\\simon\\Minecraft\\Minecraft Assets\\minecraft\\textures\\MC Block Textures\\furnace_front.png","name":"furnace_front.png","folder":"MC Block Textures","namespace":"minecraft","id":"6","particle":false,"mode":"bitmap","saved":true,"uuid":"3895c9c0-992f-69b9-72eb-ef854cb1a475","source":""},{"path":"D:\\simon\\Minecraft\\Minecraft Assets\\minecraft\\textures\\MC Block Textures\\furnace_side.png","name":"furnace_side.png","folder":"MC Block Textures","namespace":"minecraft","id":"8","particle":false,"mode":"bitmap","saved":true,"uuid":"178a3ef8-0486-c590-9946-223b61cd6838","source":""},{"path":"D:\\simon\\Minecraft\\Minecraft Assets\\minecraft\\textures\\MC Block Textures\\furnace_top.png","name":"furnace_top.png","folder":"MC Block Textures","namespace":"minecraft","id":"9","particle":false,"mode":"bitmap","saved":true,"uuid":"467cb437-a46b-4f88-1e88-7b712905e30d","source":""},{"path":"C:\\Users\\simon\\Desktop\\Forge\\Create\\src\\main\\resources\\assets\\create\\textures\\block\\brass_block.png","name":"brass_block.png","folder":"block","namespace":"create","id":"10","particle":false,"mode":"bitmap","saved":true,"uuid":"a8ef7d1b-65c5-0db5-120d-dad3d9c754cf","source":""}],"display":{"thirdperson_righthand":{"rotation":[75,-67,0],"translation":[0,2.5,-2],"scale":[0.375,0.375,0.375]},"thirdperson_lefthand":{"rotation":[75,-67,0],"translation":[0,2.5,-2],"scale":[0.375,0.375,0.375]},"firstperson_righthand":{"rotation":[0,-91,0],"scale":[0.4,0.4,0.4]},"firstperson_lefthand":{"rotation":[0,-91,0],"scale":[0.4,0.4,0.4]},"ground":{"rotation":[90,0,0],"translation":[0,2,0],"scale":[0.25,0.25,0.25]},"gui":{"rotation":[30,225,0],"translation":[-0.25,0.75,0],"scale":[0.35,0.35,0.35]},"fixed":{"scale":[0.45,0.45,0.45]}}} \ No newline at end of file diff --git a/src/main/resources/assets/create/models/block/flywheel/item.json b/src/main/resources/assets/create/models/block/flywheel/item.json new file mode 100644 index 000000000..8d77ecbc4 --- /dev/null +++ b/src/main/resources/assets/create/models/block/flywheel/item.json @@ -0,0 +1,381 @@ +{ + "credit": "Made with Blockbench", + "textures": { + "0": "create:block/steam_engine_wheel", + "5": "create:block/brass_casing", + "7": "create:block/brass_gearbox", + "particle": "create:block/steam_engine_wheel" + }, + "elements": [ + { + "from": [29, 1, 11.5], + "to": [32, 3, 13.5], + "rotation": {"angle": 0, "axis": "y", "origin": [8, 8, 17]}, + "faces": { + "north": {"uv": [6.5, 9, 8, 10], "rotation": 180, "texture": "#0"}, + "east": {"uv": [0, 9, 1.5, 10], "rotation": 180, "texture": "#0"}, + "south": {"uv": [0, 9, 1.5, 10], "rotation": 180, "texture": "#0"}, + "west": {"uv": [0, 9, 1.5, 10], "rotation": 180, "texture": "#0"}, + "up": {"uv": [0, 9, 1.5, 10], "rotation": 180, "texture": "#0"}, + "down": {"uv": [0, 9, 1.5, 10], "rotation": 180, "texture": "#0"} + } + }, + { + "from": [14.75, 7, 11.55], + "to": [30.75, 9, 13.45], + "rotation": {"angle": -22.5, "axis": "z", "origin": [15, 8, 21]}, + "faces": { + "north": {"uv": [0, 9, 8, 10], "rotation": 180, "texture": "#0"}, + "south": {"uv": [0, 9, 8, 10], "rotation": 180, "texture": "#0"}, + "up": {"uv": [0, 9, 8, 10], "rotation": 180, "texture": "#0"}, + "down": {"uv": [0, 9, 8, 10], "rotation": 180, "texture": "#0"} + } + }, + { + "from": [22, 6, 6], + "to": [32, 10, 10], + "rotation": {"angle": 0, "axis": "y", "origin": [-5, 8, 8]}, + "faces": { + "north": {"uv": [2, 7, 7, 9], "texture": "#0"}, + "east": {"uv": [0, 7, 2, 9], "texture": "#0"}, + "south": {"uv": [2, 7, 7, 9], "texture": "#0"}, + "west": {"uv": [0, 7, 2, 9], "texture": "#0"}, + "up": {"uv": [2, 7, 7, 9], "texture": "#0"}, + "down": {"uv": [2, 7, 7, 9], "texture": "#0"} + } + }, + { + "from": [7, 7, 7], + "to": [23, 9, 9], + "rotation": {"angle": -22.5, "axis": "z", "origin": [23, 8, 8]}, + "faces": { + "north": {"uv": [0, 9, 8, 10], "rotation": 180, "texture": "#0"}, + "south": {"uv": [0, 9, 8, 10], "rotation": 180, "texture": "#0"}, + "up": {"uv": [0, 9, 8, 10], "rotation": 180, "texture": "#0"}, + "down": {"uv": [0, 9, 8, 10], "rotation": 180, "texture": "#0"} + } + }, + { + "from": [0, 0, 4], + "to": [16, 16, 15], + "faces": { + "north": {"uv": [0, 0, 16, 16], "texture": "#7"}, + "east": {"uv": [0, 15.5, 8, 10], "rotation": 270, "texture": "#0"}, + "south": {"uv": [0, 0, 16, 16], "texture": "#7"}, + "west": {"uv": [8, 10.5, 16, 16], "rotation": 90, "texture": "#0"}, + "up": {"uv": [8, 10.5, 16, 16], "rotation": 180, "texture": "#0"}, + "down": {"uv": [8, 10.5, 16, 16], "texture": "#0"} + } + }, + { + "from": [0, 0, 15], + "to": [16, 2, 16], + "rotation": {"angle": 0, "axis": "y", "origin": [24, 8, 8]}, + "faces": { + "north": {"uv": [0, 0, 16, 2], "texture": "#5"}, + "east": {"uv": [0, 14, 1, 16], "texture": "#5"}, + "south": {"uv": [0, 14, 16, 16], "texture": "#5"}, + "west": {"uv": [15, 14, 16, 16], "texture": "#5"}, + "up": {"uv": [0, 1, 16, 2], "texture": "#5"}, + "down": {"uv": [0, 0, 16, 1], "texture": "#5"} + } + }, + { + "from": [0, 14, 15], + "to": [16, 16, 16], + "rotation": {"angle": 0, "axis": "z", "origin": [8, 8, 16]}, + "faces": { + "north": {"uv": [0, 0, 16, 2], "rotation": 180, "texture": "#5"}, + "east": {"uv": [15, 14, 16, 16], "rotation": 180, "texture": "#5"}, + "south": {"uv": [0, 14, 16, 16], "rotation": 180, "texture": "#5"}, + "west": {"uv": [0, 14, 1, 16], "rotation": 180, "texture": "#5"}, + "up": {"uv": [0, 0, 16, 1], "rotation": 180, "texture": "#5"}, + "down": {"uv": [0, 1, 16, 2], "rotation": 180, "texture": "#5"} + } + }, + { + "from": [0, 2, 15], + "to": [2, 14, 16], + "rotation": {"angle": 0, "axis": "z", "origin": [8, 8, 16]}, + "faces": { + "north": {"uv": [0, 0, 12, 2], "rotation": 270, "texture": "#5"}, + "east": {"uv": [2, 1, 14, 2], "rotation": 90, "texture": "#5"}, + "south": {"uv": [2, 14, 14, 16], "rotation": 90, "texture": "#5"}, + "west": {"uv": [2, 0, 14, 1], "rotation": 90, "texture": "#5"}, + "up": {"uv": [15, 14, 16, 16], "rotation": 90, "texture": "#5"}, + "down": {"uv": [0, 14, 1, 16], "rotation": 90, "texture": "#5"} + } + }, + { + "from": [14, 2, 15], + "to": [16, 14, 16], + "rotation": {"angle": 0, "axis": "z", "origin": [8, 8, 16]}, + "faces": { + "north": {"uv": [0, 0, 12, 2], "rotation": 90, "texture": "#5"}, + "east": {"uv": [2, 0, 14, 1], "rotation": 270, "texture": "#5"}, + "south": {"uv": [2, 14, 14, 16], "rotation": 270, "texture": "#5"}, + "west": {"uv": [2, 1, 14, 2], "rotation": 270, "texture": "#5"}, + "up": {"uv": [0, 14, 1, 16], "rotation": 270, "texture": "#5"}, + "down": {"uv": [15, 14, 16, 16], "rotation": 270, "texture": "#5"} + } + }, + { + "from": [3, 3, -3.9], + "to": [13, 13, 5.1], + "rotation": {"angle": 0, "axis": "y", "origin": [8, 8, 1.1]}, + "faces": { + "north": {"uv": [11, 5, 16, 10], "texture": "#0"}, + "east": {"uv": [11.5, 0, 16, 5], "texture": "#0"}, + "south": {"uv": [11, 5, 16, 10], "texture": "#0"}, + "west": {"uv": [11.5, 0, 16, 5], "rotation": 180, "texture": "#0"}, + "up": {"uv": [11.5, 0, 16, 5], "rotation": 270, "texture": "#0"}, + "down": {"uv": [11.5, 0, 16, 5], "rotation": 90, "texture": "#0"} + } + }, + { + "from": [-0.5, 23.5, -1.9], + "to": [16.5, 28.5, 4.1], + "rotation": {"angle": 0, "axis": "y", "origin": [8, 8, 1.1]}, + "faces": { + "north": {"uv": [0, 0, 8.5, 2.5], "texture": "#0"}, + "east": {"uv": [8.5, 0, 11.5, 2], "texture": "#0"}, + "south": {"uv": [0, 0, 8.5, 2.5], "texture": "#0"}, + "west": {"uv": [8.5, 0, 11.5, 2.5], "texture": "#0"}, + "up": {"uv": [0, 2.5, 8.5, 5.5], "texture": "#0"}, + "down": {"uv": [0, 2.5, 8.5, 5.5], "texture": "#0"} + } + }, + { + "from": [-0.5, -12.5, -1.9], + "to": [16.5, -7.5, 4.1], + "rotation": {"angle": 0, "axis": "y", "origin": [8, 8, 1.1]}, + "faces": { + "north": {"uv": [0, 0, 8.5, 2.5], "rotation": 180, "texture": "#0"}, + "east": {"uv": [8.5, 0, 11.5, 2.5], "rotation": 180, "texture": "#0"}, + "south": {"uv": [0, 0, 8.5, 2.5], "rotation": 180, "texture": "#0"}, + "west": {"uv": [8.5, 0, 11.5, 2], "rotation": 180, "texture": "#0"}, + "up": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 180, "texture": "#0"}, + "down": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 180, "texture": "#0"} + } + }, + { + "from": [23.5, -0.5, -1.9], + "to": [28.5, 16.5, 4.1], + "rotation": {"angle": 0, "axis": "y", "origin": [8, 8, 1.1]}, + "faces": { + "north": {"uv": [0, 0, 8.5, 2.5], "rotation": 270, "texture": "#0"}, + "east": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 90, "texture": "#0"}, + "south": {"uv": [0, 0, 8.5, 2.5], "rotation": 90, "texture": "#0"}, + "west": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 90, "texture": "#0"}, + "up": {"uv": [8.5, 0, 11.5, 2.5], "rotation": 90, "texture": "#0"}, + "down": {"uv": [8.5, 0, 11.5, 2], "rotation": 90, "texture": "#0"} + } + }, + { + "from": [-12.5, -0.5, -1.9], + "to": [-7.5, 16.5, 4.1], + "rotation": {"angle": 0, "axis": "y", "origin": [8, 8, 1.1]}, + "faces": { + "north": {"uv": [0, 0, 8.5, 2.5], "rotation": 90, "texture": "#0"}, + "east": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 270, "texture": "#0"}, + "south": {"uv": [0, 0, 8.5, 2.5], "rotation": 270, "texture": "#0"}, + "west": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 270, "texture": "#0"}, + "up": {"uv": [8.5, 0, 11.5, 2], "rotation": 270, "texture": "#0"}, + "down": {"uv": [8.5, 0, 11.5, 2.5], "rotation": 270, "texture": "#0"} + } + }, + { + "from": [-0.5, 23.5, -1.85], + "to": [16.5, 28.5, 4.05], + "rotation": {"angle": -45, "axis": "z", "origin": [8, 8, 1.1]}, + "faces": { + "north": {"uv": [0, 0, 8.5, 2.5], "texture": "#0"}, + "east": {"uv": [8.5, 0, 11.5, 2.5], "texture": "#0"}, + "south": {"uv": [0, 0, 8.5, 2.5], "texture": "#0"}, + "west": {"uv": [8.5, 0, 11.5, 2.5], "texture": "#0"}, + "up": {"uv": [0, 2.5, 8.5, 5.5], "texture": "#0"}, + "down": {"uv": [0, 2.5, 8.5, 5.5], "texture": "#0"} + } + }, + { + "from": [-0.5, -12.5, -1.85], + "to": [16.5, -7.5, 4.05], + "rotation": {"angle": -45, "axis": "z", "origin": [8, 8, 1.1]}, + "faces": { + "north": {"uv": [0, 0, 8.5, 2.5], "rotation": 180, "texture": "#0"}, + "east": {"uv": [8.5, 0, 11.5, 2.5], "rotation": 180, "texture": "#0"}, + "south": {"uv": [0, 0, 8.5, 2.5], "rotation": 180, "texture": "#0"}, + "west": {"uv": [8.5, 0, 11.5, 2.5], "rotation": 180, "texture": "#0"}, + "up": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 180, "texture": "#0"}, + "down": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 180, "texture": "#0"} + } + }, + { + "from": [-0.5, -12.5, -1.85], + "to": [16.5, -7.5, 4.05], + "rotation": {"angle": 45, "axis": "z", "origin": [8, 8, 1.1]}, + "faces": { + "north": {"uv": [0, 0, 8.5, 2.5], "rotation": 180, "texture": "#0"}, + "east": {"uv": [8.5, 0, 11.5, 2.5], "rotation": 180, "texture": "#0"}, + "south": {"uv": [0, 0, 8.5, 2.5], "rotation": 180, "texture": "#0"}, + "west": {"uv": [8.5, 0, 11.5, 2.5], "rotation": 180, "texture": "#0"}, + "up": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 180, "texture": "#0"}, + "down": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 180, "texture": "#0"} + } + }, + { + "from": [-12.5, -0.5, -1.85], + "to": [-7.5, 16.5, 4.05], + "rotation": {"angle": -45, "axis": "z", "origin": [8, 8, 1.1]}, + "faces": { + "north": {"uv": [0, 0, 8.5, 2.5], "rotation": 90, "texture": "#0"}, + "east": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 270, "texture": "#0"}, + "south": {"uv": [0, 0, 8.5, 2.5], "rotation": 270, "texture": "#0"}, + "west": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 270, "texture": "#0"}, + "up": {"uv": [8.5, 0, 11.5, 2.5], "rotation": 270, "texture": "#0"}, + "down": {"uv": [8.5, 0, 11.5, 2.5], "rotation": 270, "texture": "#0"} + } + }, + { + "name": "spoke", + "from": [6, -8, -0.9], + "to": [10, 3, 3.1], + "rotation": {"angle": -45, "axis": "z", "origin": [8, 8, 1.1]}, + "faces": { + "north": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"}, + "east": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"}, + "south": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"}, + "west": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"} + } + }, + { + "name": "spoke", + "from": [6, 13, -0.9], + "to": [10, 24, 3.1], + "rotation": {"angle": -45, "axis": "z", "origin": [8, 8, 1.1]}, + "faces": { + "north": {"uv": [9, 4.5, 11, 10], "texture": "#0"}, + "east": {"uv": [9, 4.5, 11, 10], "texture": "#0"}, + "south": {"uv": [9, 4.5, 11, 10], "texture": "#0"}, + "west": {"uv": [9, 4.5, 11, 10], "texture": "#0"} + } + }, + { + "name": "spoke", + "from": [-8, 6, -0.9], + "to": [3, 10, 3.1], + "rotation": {"angle": 0, "axis": "z", "origin": [8, 8, 1.1]}, + "faces": { + "north": {"uv": [9, 4.5, 11, 10], "rotation": 90, "texture": "#0"}, + "south": {"uv": [9, 4.5, 11, 10], "rotation": 270, "texture": "#0"}, + "up": {"uv": [9, 4.5, 11, 10], "rotation": 270, "texture": "#0"}, + "down": {"uv": [9, 4.5, 11, 10], "rotation": 270, "texture": "#0"} + } + }, + { + "name": "spoke", + "from": [13, 6, -0.9], + "to": [24, 10, 3.1], + "rotation": {"angle": 0, "axis": "z", "origin": [8, 8, 1.1]}, + "faces": { + "north": {"uv": [9, 4.5, 11, 10], "rotation": 270, "texture": "#0"}, + "south": {"uv": [9, 4.5, 11, 10], "rotation": 90, "texture": "#0"}, + "up": {"uv": [9, 4.5, 11, 10], "rotation": 90, "texture": "#0"}, + "down": {"uv": [9, 4.5, 11, 10], "rotation": 90, "texture": "#0"} + } + }, + { + "name": "spoke", + "from": [-8, 6, -0.9], + "to": [3, 10, 3.1], + "rotation": {"angle": -45, "axis": "z", "origin": [8, 8, 1.1]}, + "faces": { + "north": {"uv": [9, 4.5, 11, 10], "rotation": 90, "texture": "#0"}, + "south": {"uv": [9, 4.5, 11, 10], "rotation": 270, "texture": "#0"}, + "up": {"uv": [9, 4.5, 11, 10], "rotation": 270, "texture": "#0"}, + "down": {"uv": [9, 4.5, 11, 10], "rotation": 270, "texture": "#0"} + } + }, + { + "name": "spoke", + "from": [6, -8, -0.9], + "to": [10, 3, 3.1], + "rotation": {"angle": 0, "axis": "z", "origin": [8, 8, 1.1]}, + "faces": { + "north": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"}, + "east": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"}, + "south": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"}, + "west": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"} + } + }, + { + "name": "spoke", + "from": [13, 6, -0.9], + "to": [24, 10, 3.1], + "rotation": {"angle": -45, "axis": "z", "origin": [8, 8, 1.1]}, + "faces": { + "north": {"uv": [9, 4.5, 11, 10], "rotation": 270, "texture": "#0"}, + "south": {"uv": [9, 4.5, 11, 10], "rotation": 90, "texture": "#0"}, + "up": {"uv": [9, 4.5, 11, 10], "rotation": 90, "texture": "#0"}, + "down": {"uv": [9, 4.5, 11, 10], "rotation": 90, "texture": "#0"} + } + }, + { + "name": "spoke", + "from": [6, 13, -0.9], + "to": [10, 24, 3.1], + "rotation": {"angle": 0, "axis": "y", "origin": [8, 8, 1.1]}, + "faces": { + "north": {"uv": [9, 4.5, 11, 10], "texture": "#0"}, + "east": {"uv": [9, 4.5, 11, 10], "texture": "#0"}, + "south": {"uv": [9, 4.5, 11, 10], "texture": "#0"}, + "west": {"uv": [9, 4.5, 11, 10], "texture": "#0"} + } + } + ], + "display": { + "thirdperson_righthand": { + "rotation": [75, -67, 0], + "translation": [0, 2.5, -2], + "scale": [0.375, 0.375, 0.375] + }, + "thirdperson_lefthand": { + "rotation": [75, -67, 0], + "translation": [0, 2.5, -2], + "scale": [0.375, 0.375, 0.375] + }, + "firstperson_righthand": { + "rotation": [0, -91, 0], + "scale": [0.4, 0.4, 0.4] + }, + "firstperson_lefthand": { + "rotation": [0, -91, 0], + "scale": [0.4, 0.4, 0.4] + }, + "ground": { + "rotation": [90, 0, 0], + "translation": [0, 2, 0], + "scale": [0.25, 0.25, 0.25] + }, + "gui": { + "rotation": [30, 225, 0], + "translation": [-0.25, 0.75, 0], + "scale": [0.35, 0.35, 0.35] + }, + "fixed": { + "scale": [0.45, 0.45, 0.45] + } + }, + "groups": [ + { + "name": "transmission", + "origin": [-8, 8, 8], + "children": [0, 1, 2, 3, 4, 5, 6, 7, 8] + }, + { + "name": "wheel", + "origin": [24, 8, 8], + "children": [9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25] + } + ] +} \ No newline at end of file diff --git a/src/main/resources/assets/create/models/block/flywheel/lower_rotating_connector.json b/src/main/resources/assets/create/models/block/flywheel/lower_rotating_connector.json new file mode 100644 index 000000000..835b0cb69 --- /dev/null +++ b/src/main/resources/assets/create/models/block/flywheel/lower_rotating_connector.json @@ -0,0 +1,27 @@ +{ + "credit": "Made with Blockbench", + "textures": { + "0": "create:block/steam_engine_wheel", + "particle": "create:block/steam_engine_wheel" + }, + "elements": [ + { + "from": [2.55, 7, 6.75], + "to": [4.45, 9, 22.75], + "rotation": {"angle": 22.5, "axis": "x", "origin": [-5, 8, 7]}, + "faces": { + "east": {"uv": [0, 9, 8, 10], "rotation": 180, "texture": "#0"}, + "west": {"uv": [0, 9, 8, 10], "rotation": 180, "texture": "#0"}, + "up": {"uv": [0, 9, 8, 10], "rotation": 270, "texture": "#0"}, + "down": {"uv": [0, 9, 8, 10], "rotation": 90, "texture": "#0"} + } + } + ], + "groups": [ + { + "name": "transmission", + "origin": [-8, 8, 8], + "children": [0] + } + ] +} \ No newline at end of file diff --git a/src/main/resources/assets/create/models/block/flywheel/lower_sliding_connector.json b/src/main/resources/assets/create/models/block/flywheel/lower_sliding_connector.json new file mode 100644 index 000000000..16194017a --- /dev/null +++ b/src/main/resources/assets/create/models/block/flywheel/lower_sliding_connector.json @@ -0,0 +1,29 @@ +{ + "credit": "Made with Blockbench", + "textures": { + "0": "create:block/steam_engine_wheel", + "particle": "create:block/steam_engine_wheel" + }, + "elements": [ + { + "from": [2.5, 1, 21], + "to": [4.5, 3, 29], + "rotation": {"angle": 0, "axis": "y", "origin": [-1, 8, 8]}, + "faces": { + "north": {"uv": [0, 9, 1, 10], "rotation": 270, "texture": "#0"}, + "east": {"uv": [0, 9, 4, 10], "rotation": 180, "texture": "#0"}, + "south": {"uv": [0, 9, 1, 10], "rotation": 270, "texture": "#0"}, + "west": {"uv": [0, 9, 4, 10], "texture": "#0"}, + "up": {"uv": [0, 9, 4, 10], "rotation": 270, "texture": "#0"}, + "down": {"uv": [0, 9, 4, 10], "rotation": 270, "texture": "#0"} + } + } + ], + "groups": [ + { + "name": "transmission", + "origin": [-8, 8, 8], + "children": [0] + } + ] +} \ No newline at end of file diff --git a/src/main/resources/assets/create/models/block/flywheel/upper_rotating_connector.json b/src/main/resources/assets/create/models/block/flywheel/upper_rotating_connector.json new file mode 100644 index 000000000..a6e4b99a0 --- /dev/null +++ b/src/main/resources/assets/create/models/block/flywheel/upper_rotating_connector.json @@ -0,0 +1,27 @@ +{ + "credit": "Made with Blockbench", + "textures": { + "0": "create:block/steam_engine_wheel", + "particle": "create:block/steam_engine_wheel" + }, + "elements": [ + { + "from": [7, 7, 7], + "to": [9, 9, 23], + "rotation": {"angle": 22.5, "axis": "x", "origin": [8, 8, 23]}, + "faces": { + "east": {"uv": [0, 9, 8, 10], "rotation": 180, "texture": "#0"}, + "west": {"uv": [0, 9, 8, 10], "rotation": 180, "texture": "#0"}, + "up": {"uv": [0, 9, 8, 10], "rotation": 270, "texture": "#0"}, + "down": {"uv": [0, 9, 8, 10], "rotation": 90, "texture": "#0"} + } + } + ], + "groups": [ + { + "name": "transmission", + "origin": [-8, 8, 8], + "children": [0] + } + ] +} \ No newline at end of file diff --git a/src/main/resources/assets/create/models/block/flywheel/upper_sliding_connector.json b/src/main/resources/assets/create/models/block/flywheel/upper_sliding_connector.json new file mode 100644 index 000000000..177150784 --- /dev/null +++ b/src/main/resources/assets/create/models/block/flywheel/upper_sliding_connector.json @@ -0,0 +1,29 @@ +{ + "credit": "Made with Blockbench", + "textures": { + "0": "create:block/steam_engine_wheel", + "particle": "create:block/steam_engine_wheel" + }, + "elements": [ + { + "from": [6, 6, 22], + "to": [10, 10, 32], + "rotation": {"angle": 0, "axis": "y", "origin": [8, 8, -5]}, + "faces": { + "north": {"uv": [0, 7, 2, 9], "texture": "#0"}, + "east": {"uv": [2, 7, 7, 9], "texture": "#0"}, + "south": {"uv": [0, 7, 2, 9], "texture": "#0"}, + "west": {"uv": [2, 7, 7, 9], "texture": "#0"}, + "up": {"uv": [2, 7, 7, 9], "rotation": 90, "texture": "#0"}, + "down": {"uv": [2, 7, 7, 9], "rotation": 270, "texture": "#0"} + } + } + ], + "groups": [ + { + "name": "transmission", + "origin": [-8, 8, 8], + "children": [0] + } + ] +} \ No newline at end of file diff --git a/src/main/resources/assets/create/models/block/flywheel/wheel.json b/src/main/resources/assets/create/models/block/flywheel/wheel.json new file mode 100644 index 000000000..997dd77e1 --- /dev/null +++ b/src/main/resources/assets/create/models/block/flywheel/wheel.json @@ -0,0 +1,221 @@ +{ + "credit": "Made with Blockbench", + "textures": { + "0": "create:block/steam_engine_wheel", + "particle": "create:block/steam_engine_wheel" + }, + "elements": [ + { + "from": [11.9, 23.5, -0.5], + "to": [17.9, 28.5, 16.5], + "rotation": {"angle": 0, "axis": "x", "origin": [14.9, 8, 8]}, + "faces": { + "north": {"uv": [8.5, 0, 11.5, 2.5], "texture": "#0"}, + "east": {"uv": [0, 0, 8.5, 2.5], "texture": "#0"}, + "south": {"uv": [8.5, 0, 11.5, 2], "texture": "#0"}, + "west": {"uv": [0, 0, 8.5, 2.5], "texture": "#0"}, + "up": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 90, "texture": "#0"}, + "down": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 270, "texture": "#0"} + } + }, + { + "from": [11.9, -12.5, -0.5], + "to": [17.9, -7.5, 16.5], + "rotation": {"angle": 0, "axis": "x", "origin": [14.9, 8, 8]}, + "faces": { + "north": {"uv": [8.5, 0, 11.5, 2], "rotation": 180, "texture": "#0"}, + "east": {"uv": [0, 0, 8.5, 2.5], "rotation": 180, "texture": "#0"}, + "south": {"uv": [8.5, 0, 11.5, 2.5], "rotation": 180, "texture": "#0"}, + "west": {"uv": [0, 0, 8.5, 2.5], "rotation": 180, "texture": "#0"}, + "up": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 270, "texture": "#0"}, + "down": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 90, "texture": "#0"} + } + }, + { + "from": [11.9, -0.5, 23.5], + "to": [17.9, 16.5, 28.5], + "rotation": {"angle": 0, "axis": "x", "origin": [14.9, 8, 8]}, + "faces": { + "north": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 90, "texture": "#0"}, + "east": {"uv": [0, 0, 8.5, 2.5], "rotation": 270, "texture": "#0"}, + "south": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 90, "texture": "#0"}, + "west": {"uv": [0, 0, 8.5, 2.5], "rotation": 90, "texture": "#0"}, + "up": {"uv": [8.5, 0, 11.5, 2.5], "rotation": 180, "texture": "#0"}, + "down": {"uv": [8.5, 0, 11.5, 2], "texture": "#0"} + } + }, + { + "from": [11.9, -0.5, -12.5], + "to": [17.9, 16.5, -7.5], + "rotation": {"angle": 0, "axis": "x", "origin": [14.9, 8, 8]}, + "faces": { + "north": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 270, "texture": "#0"}, + "east": {"uv": [0, 0, 8.5, 2.5], "rotation": 90, "texture": "#0"}, + "south": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 270, "texture": "#0"}, + "west": {"uv": [0, 0, 8.5, 2.5], "rotation": 270, "texture": "#0"}, + "up": {"uv": [8.5, 0, 11.5, 2], "texture": "#0"}, + "down": {"uv": [8.5, 0, 11.5, 2.5], "rotation": 180, "texture": "#0"} + } + }, + { + "from": [11.95, 23.5, -0.5], + "to": [17.85, 28.5, 16.5], + "rotation": {"angle": 45, "axis": "x", "origin": [14.9, 8, 8]}, + "faces": { + "north": {"uv": [8.5, 0, 11.5, 2.5], "texture": "#0"}, + "east": {"uv": [0, 0, 8.5, 2.5], "texture": "#0"}, + "south": {"uv": [8.5, 0, 11.5, 2.5], "texture": "#0"}, + "west": {"uv": [0, 0, 8.5, 2.5], "texture": "#0"}, + "up": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 90, "texture": "#0"}, + "down": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 270, "texture": "#0"} + } + }, + { + "from": [11.95, -12.5, -0.5], + "to": [17.85, -7.5, 16.5], + "rotation": {"angle": 45, "axis": "x", "origin": [14.9, 8, 8]}, + "faces": { + "north": {"uv": [8.5, 0, 11.5, 2.5], "rotation": 180, "texture": "#0"}, + "east": {"uv": [0, 0, 8.5, 2.5], "rotation": 180, "texture": "#0"}, + "south": {"uv": [8.5, 0, 11.5, 2.5], "rotation": 180, "texture": "#0"}, + "west": {"uv": [0, 0, 8.5, 2.5], "rotation": 180, "texture": "#0"}, + "up": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 270, "texture": "#0"}, + "down": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 90, "texture": "#0"} + } + }, + { + "from": [11.95, -12.5, -0.5], + "to": [17.85, -7.5, 16.5], + "rotation": {"angle": -45, "axis": "x", "origin": [14.9, 8, 8]}, + "faces": { + "north": {"uv": [8.5, 0, 11.5, 2.5], "rotation": 180, "texture": "#0"}, + "east": {"uv": [0, 0, 8.5, 2.5], "rotation": 180, "texture": "#0"}, + "south": {"uv": [8.5, 0, 11.5, 2.5], "rotation": 180, "texture": "#0"}, + "west": {"uv": [0, 0, 8.5, 2.5], "rotation": 180, "texture": "#0"}, + "up": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 270, "texture": "#0"}, + "down": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 90, "texture": "#0"} + } + }, + { + "from": [11.95, -0.5, -12.5], + "to": [17.85, 16.5, -7.5], + "rotation": {"angle": 45, "axis": "x", "origin": [14.9, 8, 8]}, + "faces": { + "north": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 270, "texture": "#0"}, + "east": {"uv": [0, 0, 8.5, 2.5], "rotation": 90, "texture": "#0"}, + "south": {"uv": [0, 2.5, 8.5, 5.5], "rotation": 270, "texture": "#0"}, + "west": {"uv": [0, 0, 8.5, 2.5], "rotation": 270, "texture": "#0"}, + "up": {"uv": [8.5, 0, 11.5, 2.5], "texture": "#0"}, + "down": {"uv": [8.5, 0, 11.5, 2.5], "rotation": 180, "texture": "#0"} + } + }, + { + "name": "spoke", + "from": [12.9, -8, 6], + "to": [16.9, 3, 10], + "rotation": {"angle": 45, "axis": "x", "origin": [14.9, 8, 8]}, + "faces": { + "north": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"}, + "east": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"}, + "south": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"}, + "west": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"} + } + }, + { + "name": "spoke", + "from": [12.9, 13, 6], + "to": [16.9, 24, 10], + "rotation": {"angle": 45, "axis": "x", "origin": [14.9, 8, 8]}, + "faces": { + "north": {"uv": [9, 4.5, 11, 10], "texture": "#0"}, + "east": {"uv": [9, 4.5, 11, 10], "texture": "#0"}, + "south": {"uv": [9, 4.5, 11, 10], "texture": "#0"}, + "west": {"uv": [9, 4.5, 11, 10], "texture": "#0"} + } + }, + { + "name": "spoke", + "from": [12.9, 6, -8], + "to": [16.9, 10, 3], + "rotation": {"angle": 0, "axis": "x", "origin": [14.9, 8, 8]}, + "faces": { + "east": {"uv": [9, 4.5, 11, 10], "rotation": 90, "texture": "#0"}, + "west": {"uv": [9, 4.5, 11, 10], "rotation": 270, "texture": "#0"}, + "up": {"uv": [9, 4.5, 11, 10], "texture": "#0"}, + "down": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"} + } + }, + { + "name": "spoke", + "from": [12.9, 6, 13], + "to": [16.9, 10, 24], + "rotation": {"angle": 0, "axis": "x", "origin": [14.9, 8, 8]}, + "faces": { + "east": {"uv": [9, 4.5, 11, 10], "rotation": 270, "texture": "#0"}, + "west": {"uv": [9, 4.5, 11, 10], "rotation": 90, "texture": "#0"}, + "up": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"}, + "down": {"uv": [9, 4.5, 11, 10], "texture": "#0"} + } + }, + { + "name": "spoke", + "from": [12.9, 6, -8], + "to": [16.9, 10, 3], + "rotation": {"angle": 45, "axis": "x", "origin": [14.9, 8, 8]}, + "faces": { + "east": {"uv": [9, 4.5, 11, 10], "rotation": 90, "texture": "#0"}, + "west": {"uv": [9, 4.5, 11, 10], "rotation": 270, "texture": "#0"}, + "up": {"uv": [9, 4.5, 11, 10], "texture": "#0"}, + "down": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"} + } + }, + { + "name": "spoke", + "from": [12.9, -8, 6], + "to": [16.9, 3, 10], + "rotation": {"angle": 0, "axis": "x", "origin": [14.9, 8, 8]}, + "faces": { + "north": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"}, + "east": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"}, + "south": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"}, + "west": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"} + } + }, + { + "name": "spoke", + "from": [12.9, 6, 13], + "to": [16.9, 10, 24], + "rotation": {"angle": 45, "axis": "x", "origin": [14.9, 8, 8]}, + "faces": { + "east": {"uv": [9, 4.5, 11, 10], "rotation": 270, "texture": "#0"}, + "west": {"uv": [9, 4.5, 11, 10], "rotation": 90, "texture": "#0"}, + "up": {"uv": [9, 4.5, 11, 10], "rotation": 180, "texture": "#0"}, + "down": {"uv": [9, 4.5, 11, 10], "texture": "#0"} + } + }, + { + "name": "spoke", + "from": [12.9, 13, 6], + "to": [16.9, 24, 10], + "rotation": {"angle": 0, "axis": "x", "origin": [14.9, 8, 8]}, + "faces": { + "north": {"uv": [9, 4.5, 11, 10], "texture": "#0"}, + "east": {"uv": [9, 4.5, 11, 10], "texture": "#0"}, + "south": {"uv": [9, 4.5, 11, 10], "texture": "#0"}, + "west": {"uv": [9, 4.5, 11, 10], "texture": "#0"} + } + } + ], + "groups": [ + { + "name": "transmission", + "origin": [-8, 8, 8], + "children": [] + }, + { + "name": "wheel", + "origin": [24, 8, 8], + "children": [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15] + } + ] +} \ No newline at end of file diff --git a/src/main/resources/assets/create/models/block/furnace_engine/body.json b/src/main/resources/assets/create/models/block/furnace_engine/body.json new file mode 100644 index 000000000..d421a627f --- /dev/null +++ b/src/main/resources/assets/create/models/block/furnace_engine/body.json @@ -0,0 +1,133 @@ +{ + "credit": "Made with Blockbench", + "textures": { + "5": "create:block/brass_casing", + "particle": "create:block/brass_block", + "1_1": "create:block/furnace_cylinder" + }, + "elements": [ + { + "name": "Ring", + "from": [0, 0, 9], + "to": [16, 16, 14], + "faces": { + "north": {"uv": [0, 0, 16, 16], "texture": "#5"}, + "east": {"uv": [0, 7, 2.5, 15], "texture": "#1_1"}, + "south": {"uv": [0, 0, 16, 16], "texture": "#5"}, + "west": {"uv": [0, 7, 2.5, 15], "texture": "#1_1"}, + "up": {"uv": [0, 7, 2.5, 15], "rotation": 270, "texture": "#1_1"}, + "down": {"uv": [0, 7, 2.5, 15], "rotation": 90, "texture": "#1_1"} + } + }, + { + "name": "Cylinder", + "from": [1, 1, 0], + "to": [15, 15, 16], + "faces": { + "north": {"uv": [8, 0, 15, 7], "texture": "#1_1"}, + "east": {"uv": [0, 0, 8, 7], "texture": "#1_1"}, + "south": {"uv": [8, 0, 15, 7], "texture": "#1_1"}, + "west": {"uv": [0, 0, 8, 7], "rotation": 180, "texture": "#1_1"}, + "up": {"uv": [0, 0, 8, 7], "rotation": 270, "texture": "#1_1"}, + "down": {"uv": [0, 0, 8, 7], "rotation": 90, "texture": "#1_1"} + } + }, + { + "from": [10.5, 0, 0], + "to": [14.5, 4, 9], + "faces": { + "east": {"uv": [2.5, 7, 7, 9], "rotation": 180, "texture": "#1_1"}, + "west": {"uv": [2.5, 7, 7, 9], "rotation": 180, "texture": "#1_1"}, + "up": {"uv": [2.5, 7, 7, 9], "rotation": 90, "texture": "#1_1"}, + "down": {"uv": [2.5, 7, 7, 9], "rotation": 270, "texture": "#1_1"} + } + }, + { + "from": [1.5, 0, 0], + "to": [5.5, 4, 9], + "faces": { + "east": {"uv": [7, 7, 2.5, 9], "rotation": 180, "texture": "#1_1"}, + "west": {"uv": [7, 7, 2.5, 9], "rotation": 180, "texture": "#1_1"}, + "up": {"uv": [2.5, 9, 7, 7], "rotation": 90, "texture": "#1_1"}, + "down": {"uv": [2.5, 9, 7, 7], "rotation": 270, "texture": "#1_1"} + } + }, + { + "name": "LowerPort", + "from": [10.5, 0.1, 13.9], + "to": [14.5, 4.1, 16.9], + "faces": { + "north": {"uv": [10, 0, 14, 4], "texture": "#1_1"}, + "east": {"uv": [3, 13, 4.5, 15], "rotation": 180, "texture": "#1_1"}, + "south": {"uv": [2.5, 13, 4.5, 15], "texture": "#1_1"}, + "west": {"uv": [3, 13, 4.5, 15], "texture": "#1_1"}, + "up": {"uv": [3, 13, 4.5, 15], "rotation": 90, "texture": "#1_1"}, + "down": {"uv": [3, 13, 4.5, 15], "rotation": 270, "texture": "#1_1"} + } + }, + { + "name": "LowerPort", + "from": [1.5, 0.1, 13.9], + "to": [5.5, 4.1, 16.9], + "faces": { + "north": {"uv": [14, 0, 10, 4], "texture": "#1_1"}, + "east": {"uv": [4.5, 13, 3, 15], "texture": "#1_1"}, + "south": {"uv": [4.5, 13, 2.5, 15], "texture": "#1_1"}, + "west": {"uv": [4.5, 13, 3, 15], "rotation": 180, "texture": "#1_1"}, + "up": {"uv": [3, 15, 4.5, 13], "rotation": 90, "texture": "#1_1"}, + "down": {"uv": [3, 15, 4.5, 13], "rotation": 270, "texture": "#1_1"} + } + }, + { + "name": "Port", + "from": [4, 4, 15.8], + "to": [12, 12, 17.8], + "faces": { + "east": {"uv": [5.5, 9, 6.5, 13], "rotation": 180, "texture": "#1_1"}, + "south": {"uv": [2.5, 9, 6.5, 13], "texture": "#1_1"}, + "west": {"uv": [5.5, 9, 6.5, 13], "texture": "#1_1"}, + "up": {"uv": [5.5, 9, 6.5, 13], "rotation": 90, "texture": "#1_1"}, + "down": {"uv": [5.5, 9, 6.5, 13], "rotation": 270, "texture": "#1_1"} + } + } + ], + "display": { + "thirdperson_righthand": { + "rotation": [75, 135, 0], + "translation": [0, 2.5, 0], + "scale": [0.375, 0.375, 0.375] + }, + "thirdperson_lefthand": { + "rotation": [75, 135, 0], + "translation": [0, 2.5, 0], + "scale": [0.375, 0.375, 0.375] + }, + "firstperson_righthand": { + "rotation": [0, 45, 0], + "scale": [0.4, 0.4, 0.4] + }, + "firstperson_lefthand": { + "rotation": [0, 225, 0], + "scale": [0.4, 0.4, 0.4] + }, + "ground": { + "translation": [0, 3, 0], + "scale": [0.25, 0.25, 0.25] + }, + "gui": { + "rotation": [30, 45, 0], + "scale": [0.625, 0.625, 0.625] + }, + "fixed": { + "rotation": [0, 180, 0], + "scale": [0.5, 0.5, 0.5] + } + }, + "groups": [ + { + "name": "SteamCylinder", + "origin": [8, 8, 8], + "children": [0, 1, 2, 3, 4, 5, 6] + } + ] +} \ No newline at end of file diff --git a/src/main/resources/assets/create/models/block/furnace_engine/frame.json b/src/main/resources/assets/create/models/block/furnace_engine/frame.json new file mode 100644 index 000000000..2966a5a63 --- /dev/null +++ b/src/main/resources/assets/create/models/block/furnace_engine/frame.json @@ -0,0 +1,89 @@ +{ + "credit": "Made with Blockbench", + "textures": { + "particle": "create:block/steam_engine_wheel", + "1_1": "create:block/furnace_cylinder" + }, + "elements": [ + { + "name": "Cylinder", + "from": [1.1, 1.1, -1.9], + "to": [14.9, 14.9, 0.1], + "rotation": {"angle": 0, "axis": "y", "origin": [8, 8, 7]}, + "faces": { + "north": {"uv": [8, 0, 15, 7], "texture": "#1_1"}, + "east": {"uv": [14, 0, 15, 7], "texture": "#1_1"}, + "south": {"uv": [7, 7, 16, 16], "texture": "#1_1"}, + "west": {"uv": [14, 0, 15, 7], "rotation": 180, "texture": "#1_1"}, + "up": {"uv": [14, 0, 15, 7], "rotation": 270, "texture": "#1_1"}, + "down": {"uv": [14, 0, 15, 7], "rotation": 90, "texture": "#1_1"} + } + }, + { + "from": [-0.9, 12, -0.9], + "to": [16.9, 16.1, 16.9], + "rotation": {"angle": 0, "axis": "y", "origin": [8, 8, 7]}, + "faces": { + "north": {"uv": [7, 7, 16, 9], "texture": "#1_1"}, + "east": {"uv": [7, 7, 16, 9], "texture": "#1_1"}, + "south": {"uv": [7, 7, 16, 9], "texture": "#1_1"}, + "west": {"uv": [7, 7, 16, 9], "texture": "#1_1"}, + "up": {"uv": [7, 7, 16, 16], "rotation": 270, "texture": "#1_1"}, + "down": {"uv": [7, 7, 16, 16], "rotation": 90, "texture": "#1_1"} + } + }, + { + "from": [-0.9, 8, -0.9], + "to": [16.9, 12, 16.9], + "rotation": {"angle": 0, "axis": "y", "origin": [8, 8, 7]}, + "faces": { + "north": {"uv": [7, 14, 16, 16], "texture": "#1_1"}, + "east": {"uv": [7, 14, 16, 16], "texture": "#1_1"}, + "south": {"uv": [7, 14, 16, 16], "texture": "#1_1"}, + "west": {"uv": [7, 14, 16, 16], "texture": "#1_1"}, + "up": {"uv": [7, 7, 16, 16], "rotation": 270, "texture": "#1_1"}, + "down": {"uv": [7, 7, 16, 16], "rotation": 90, "texture": "#1_1"} + } + } + ], + "display": { + "thirdperson_righthand": { + "rotation": [75, -67, 0], + "translation": [0, 2.5, -2], + "scale": [0.375, 0.375, 0.375] + }, + "thirdperson_lefthand": { + "rotation": [75, -67, 0], + "translation": [0, 2.5, -2], + "scale": [0.375, 0.375, 0.375] + }, + "firstperson_righthand": { + "rotation": [0, -91, 0], + "scale": [0.4, 0.4, 0.4] + }, + "firstperson_lefthand": { + "rotation": [0, -91, 0], + "scale": [0.4, 0.4, 0.4] + }, + "ground": { + "rotation": [90, 0, 0], + "translation": [0, 2, 0], + "scale": [0.25, 0.25, 0.25] + }, + "gui": { + "rotation": [30, 225, 0], + "translation": [-0.25, 0.75, 0], + "scale": [0.35, 0.35, 0.35] + }, + "fixed": { + "scale": [0.45, 0.45, 0.45] + } + }, + "groups": [ + { + "name": "SteamCylinder", + "origin": [8, 8, 8], + "children": [0, 1, 2] + } + ] +} \ No newline at end of file diff --git a/src/main/resources/assets/create/models/block/furnace_engine/item.json b/src/main/resources/assets/create/models/block/furnace_engine/item.json new file mode 100644 index 000000000..22110a645 --- /dev/null +++ b/src/main/resources/assets/create/models/block/furnace_engine/item.json @@ -0,0 +1,110 @@ +{ + "credit": "Made with Blockbench", + "textures": { + "5": "create:block/brass_casing", + "particle": "create:block/steam_engine_wheel", + "1_1": "create:block/furnace_cylinder" + }, + "elements": [ + { + "name": "Ring", + "from": [0, 0, 9], + "to": [16, 16, 14], + "faces": { + "north": {"uv": [0, 0, 16, 16], "texture": "#5"}, + "east": {"uv": [0, 7, 2.5, 15], "texture": "#1_1"}, + "south": {"uv": [0, 0, 16, 16], "texture": "#5"}, + "west": {"uv": [0, 7, 2.5, 15], "texture": "#1_1"}, + "up": {"uv": [0, 7, 2.5, 15], "rotation": 270, "texture": "#1_1"}, + "down": {"uv": [0, 7, 2.5, 15], "rotation": 90, "texture": "#1_1"} + } + }, + { + "name": "Cylinder", + "from": [1, 1, 0], + "to": [15, 15, 16], + "faces": { + "north": {"uv": [8, 0, 15, 7], "texture": "#1_1"}, + "east": {"uv": [0, 0, 8, 7], "texture": "#1_1"}, + "south": {"uv": [8, 0, 15, 7], "texture": "#1_1"}, + "west": {"uv": [0, 0, 8, 7], "rotation": 180, "texture": "#1_1"}, + "up": {"uv": [0, 0, 8, 7], "rotation": 270, "texture": "#1_1"}, + "down": {"uv": [0, 0, 8, 7], "rotation": 90, "texture": "#1_1"} + } + }, + { + "from": [10.5, 0, 0], + "to": [14.5, 4, 9], + "faces": { + "east": {"uv": [2.5, 7, 7, 9], "rotation": 180, "texture": "#1_1"}, + "west": {"uv": [2.5, 7, 7, 9], "rotation": 180, "texture": "#1_1"}, + "up": {"uv": [2.5, 7, 7, 9], "rotation": 90, "texture": "#1_1"}, + "down": {"uv": [2.5, 7, 7, 9], "rotation": 270, "texture": "#1_1"} + } + }, + { + "name": "LowerPort", + "from": [10.5, 0.1, 13.9], + "to": [14.5, 4.1, 16.9], + "faces": { + "north": {"uv": [10, 0, 14, 4], "texture": "#1_1"}, + "east": {"uv": [3, 13, 4.5, 15], "rotation": 180, "texture": "#1_1"}, + "south": {"uv": [2.5, 13, 4.5, 15], "texture": "#1_1"}, + "west": {"uv": [3, 13, 4.5, 15], "texture": "#1_1"}, + "up": {"uv": [3, 13, 4.5, 15], "rotation": 90, "texture": "#1_1"}, + "down": {"uv": [3, 13, 4.5, 15], "rotation": 270, "texture": "#1_1"} + } + }, + { + "name": "Port", + "from": [4, 4, 15.8], + "to": [12, 12, 17.8], + "faces": { + "east": {"uv": [5.5, 9, 6.5, 13], "rotation": 180, "texture": "#1_1"}, + "south": {"uv": [2.5, 9, 6.5, 13], "texture": "#1_1"}, + "west": {"uv": [5.5, 9, 6.5, 13], "texture": "#1_1"}, + "up": {"uv": [5.5, 9, 6.5, 13], "rotation": 90, "texture": "#1_1"}, + "down": {"uv": [5.5, 9, 6.5, 13], "rotation": 270, "texture": "#1_1"} + } + } + ], + "display": { + "thirdperson_righthand": { + "rotation": [75, 135, 0], + "translation": [0, 2.5, 0], + "scale": [0.375, 0.375, 0.375] + }, + "thirdperson_lefthand": { + "rotation": [75, 135, 0], + "translation": [0, 2.5, 0], + "scale": [0.375, 0.375, 0.375] + }, + "firstperson_righthand": { + "rotation": [0, 45, 0], + "scale": [0.4, 0.4, 0.4] + }, + "firstperson_lefthand": { + "rotation": [0, 225, 0], + "scale": [0.4, 0.4, 0.4] + }, + "ground": { + "translation": [0, 3, 0], + "scale": [0.25, 0.25, 0.25] + }, + "gui": { + "rotation": [30, 45, 0], + "scale": [0.625, 0.625, 0.625] + }, + "fixed": { + "rotation": [0, 180, 0], + "scale": [0.5, 0.5, 0.5] + } + }, + "groups": [ + { + "name": "SteamCylinder", + "origin": [8, 8, 8], + "children": [0, 1, 2, 3, 4] + } + ] +} \ No newline at end of file diff --git a/src/main/resources/assets/create/models/item/flywheel.json b/src/main/resources/assets/create/models/item/flywheel.json new file mode 100644 index 000000000..00e1610e7 --- /dev/null +++ b/src/main/resources/assets/create/models/item/flywheel.json @@ -0,0 +1,3 @@ +{ + "parent": "create:block/flywheel/item" +} \ No newline at end of file diff --git a/src/main/resources/assets/create/models/item/furnace_engine.json b/src/main/resources/assets/create/models/item/furnace_engine.json new file mode 100644 index 000000000..f7e497ca3 --- /dev/null +++ b/src/main/resources/assets/create/models/item/furnace_engine.json @@ -0,0 +1,3 @@ +{ + "parent": "create:block/furnace_engine/item" +} \ No newline at end of file diff --git a/src/main/resources/assets/create/textures/block/brass_gearbox.png b/src/main/resources/assets/create/textures/block/brass_gearbox.png new file mode 100644 index 000000000..c84dbf172 Binary files /dev/null and b/src/main/resources/assets/create/textures/block/brass_gearbox.png differ diff --git a/src/main/resources/assets/create/textures/block/furnace_cylinder.png b/src/main/resources/assets/create/textures/block/furnace_cylinder.png new file mode 100644 index 000000000..cffb1fcae Binary files /dev/null and b/src/main/resources/assets/create/textures/block/furnace_cylinder.png differ diff --git a/src/main/resources/assets/create/textures/block/steam_engine_wheel.png b/src/main/resources/assets/create/textures/block/steam_engine_wheel.png new file mode 100644 index 000000000..252e6dbd2 Binary files /dev/null and b/src/main/resources/assets/create/textures/block/steam_engine_wheel.png differ diff --git a/src/main/resources/data/create/loot_tables/blocks/flywheel.json b/src/main/resources/data/create/loot_tables/blocks/flywheel.json new file mode 100644 index 000000000..9f0018990 --- /dev/null +++ b/src/main/resources/data/create/loot_tables/blocks/flywheel.json @@ -0,0 +1,19 @@ +{ + "type": "minecraft:block", + "pools": [ + { + "rolls": 1, + "entries": [ + { + "type": "minecraft:item", + "name": "create:flywheel" + } + ], + "conditions": [ + { + "condition": "minecraft:survives_explosion" + } + ] + } + ] +} \ No newline at end of file diff --git a/src/main/resources/data/create/loot_tables/blocks/furnace_engine.json b/src/main/resources/data/create/loot_tables/blocks/furnace_engine.json new file mode 100644 index 000000000..e3c600d70 --- /dev/null +++ b/src/main/resources/data/create/loot_tables/blocks/furnace_engine.json @@ -0,0 +1,19 @@ +{ + "type": "minecraft:block", + "pools": [ + { + "rolls": 1, + "entries": [ + { + "type": "minecraft:item", + "name": "create:furnace_engine" + } + ], + "conditions": [ + { + "condition": "minecraft:survives_explosion" + } + ] + } + ] +} \ No newline at end of file diff --git a/src/main/resources/data/create/recipes/mechanical_crafting/crushing_wheel.json b/src/main/resources/data/create/recipes/mechanical_crafting/crushing_wheel.json new file mode 100644 index 000000000..bec146a74 --- /dev/null +++ b/src/main/resources/data/create/recipes/mechanical_crafting/crushing_wheel.json @@ -0,0 +1,34 @@ +{ + "type": "create:mechanical_crafting", + "pattern": [ + " PPP ", + "PSBSP", + "PBCBP", + "PSBSP", + " PPP " + ], + "key": { + "P": { + "item": "minecraft:polished_andesite" + }, + "S": { + "tag": "forge:rods/wooden" + }, + "C": { + "item": "create:large_cogwheel" + }, + "B": { + "item": "create:andesite_alloy" + } + }, + "result": { + "item": "create:crushing_wheel", + "count": 1 + }, + "conditions": [ + { + "type": "create:module", + "module": "contraptions" + } + ] +} \ No newline at end of file diff --git a/src/main/resources/data/create/recipes/mechanical_crafting/flywheel.json b/src/main/resources/data/create/recipes/mechanical_crafting/flywheel.json new file mode 100644 index 000000000..f373fd095 --- /dev/null +++ b/src/main/resources/data/create/recipes/mechanical_crafting/flywheel.json @@ -0,0 +1,34 @@ +{ + "type": "create:mechanical_crafting", + "pattern": [ + " PPP ", + "PSBSP", + "PBCBP", + "PSBSP", + " PPP " + ], + "key": { + "P": { + "tag": "forge:plates/brass" + }, + "S": { + "tag": "forge:rods/wooden" + }, + "C": { + "item": "create:brass_casing" + }, + "B": { + "tag": "forge:ingots/brass" + } + }, + "result": { + "item": "create:flywheel", + "count": 1 + }, + "conditions": [ + { + "type": "create:module", + "module": "contraptions" + } + ] +} \ No newline at end of file diff --git a/src/main/resources/data/create/recipes/mechanical_crafting/furnace_engine.json b/src/main/resources/data/create/recipes/mechanical_crafting/furnace_engine.json new file mode 100644 index 000000000..c275772e3 --- /dev/null +++ b/src/main/resources/data/create/recipes/mechanical_crafting/furnace_engine.json @@ -0,0 +1,35 @@ +{ + "type": "create:mechanical_crafting", + "pattern": [ + "PPB", + "DCA", + "PPB" + ], + "key": { + "P": { + "tag": "forge:plates/brass" + }, + "D": { + "tag": "forge:plates/copper" + }, + "A": { + "item": "minecraft:piston" + }, + "C": { + "item": "create:brass_casing" + }, + "B": { + "tag": "forge:ingots/brass" + } + }, + "result": { + "item": "create:furnace_engine", + "count": 1 + }, + "conditions": [ + { + "type": "create:module", + "module": "contraptions" + } + ] +} \ No newline at end of file diff --git a/src/main/resources/data/create/recipes/mechanical_crafting/integrated_circuit.json b/src/main/resources/data/create/recipes/mechanical_crafting/integrated_circuit.json index bac6e7c36..65d515d72 100644 --- a/src/main/resources/data/create/recipes/mechanical_crafting/integrated_circuit.json +++ b/src/main/resources/data/create/recipes/mechanical_crafting/integrated_circuit.json @@ -17,7 +17,7 @@ "tag": "forge:plates/iron" }, "N": { - "tag": "forge:nuggets/copper" + "tag": "forge:nuggets/gold" } }, "result": {