mirror of
https://github.com/Jozufozu/Flywheel.git
synced 2025-01-03 19:06:27 +01:00
Merge branch 'mc1.15/dev' into mc1.16/dev
This commit is contained in:
commit
37c3625d4a
12 changed files with 185 additions and 103 deletions
|
@ -14,21 +14,19 @@ import com.simibubi.create.content.curiosities.tools.SandPaperItem;
|
||||||
import com.simibubi.create.foundation.utility.BlockHelper;
|
import com.simibubi.create.foundation.utility.BlockHelper;
|
||||||
import com.simibubi.create.foundation.utility.worldWrappers.WrappedWorld;
|
import com.simibubi.create.foundation.utility.worldWrappers.WrappedWorld;
|
||||||
|
|
||||||
import net.minecraft.advancements.CriteriaTriggers;
|
|
||||||
import net.minecraft.block.AbstractFireBlock;
|
import net.minecraft.block.AbstractFireBlock;
|
||||||
import net.minecraft.block.BeehiveBlock;
|
import net.minecraft.block.BeehiveBlock;
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
import net.minecraft.block.BlockState;
|
import net.minecraft.block.BlockState;
|
||||||
import net.minecraft.block.Blocks;
|
import net.minecraft.block.Blocks;
|
||||||
import net.minecraft.block.material.Material;
|
import net.minecraft.block.material.Material;
|
||||||
import net.minecraft.enchantment.EnchantmentHelper;
|
|
||||||
import net.minecraft.enchantment.Enchantments;
|
|
||||||
import net.minecraft.entity.Entity;
|
import net.minecraft.entity.Entity;
|
||||||
import net.minecraft.entity.LivingEntity;
|
import net.minecraft.entity.LivingEntity;
|
||||||
import net.minecraft.entity.ai.attributes.Attribute;
|
import net.minecraft.entity.ai.attributes.Attribute;
|
||||||
import net.minecraft.entity.ai.attributes.AttributeModifier;
|
import net.minecraft.entity.ai.attributes.AttributeModifier;
|
||||||
import net.minecraft.entity.item.ItemEntity;
|
import net.minecraft.entity.item.ItemEntity;
|
||||||
import net.minecraft.entity.player.PlayerEntity;
|
import net.minecraft.entity.player.PlayerEntity;
|
||||||
|
import net.minecraft.entity.player.ServerPlayerEntity;
|
||||||
import net.minecraft.fluid.Fluid;
|
import net.minecraft.fluid.Fluid;
|
||||||
import net.minecraft.fluid.Fluids;
|
import net.minecraft.fluid.Fluids;
|
||||||
import net.minecraft.inventory.EquipmentSlotType;
|
import net.minecraft.inventory.EquipmentSlotType;
|
||||||
|
@ -41,13 +39,13 @@ import net.minecraft.item.ItemUseContext;
|
||||||
import net.minecraft.item.Items;
|
import net.minecraft.item.Items;
|
||||||
import net.minecraft.nbt.CompoundNBT;
|
import net.minecraft.nbt.CompoundNBT;
|
||||||
import net.minecraft.server.management.PlayerInteractionManager;
|
import net.minecraft.server.management.PlayerInteractionManager;
|
||||||
import net.minecraft.stats.Stats;
|
|
||||||
import net.minecraft.tileentity.BeehiveTileEntity;
|
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import net.minecraft.util.ActionResult;
|
import net.minecraft.util.ActionResult;
|
||||||
import net.minecraft.util.ActionResultType;
|
import net.minecraft.util.ActionResultType;
|
||||||
import net.minecraft.util.Direction;
|
import net.minecraft.util.Direction;
|
||||||
import net.minecraft.util.Hand;
|
import net.minecraft.util.Hand;
|
||||||
|
import net.minecraft.util.SoundCategory;
|
||||||
|
import net.minecraft.util.SoundEvents;
|
||||||
import net.minecraft.util.math.AxisAlignedBB;
|
import net.minecraft.util.math.AxisAlignedBB;
|
||||||
import net.minecraft.util.math.BlockPos;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.util.math.BlockRayTraceResult;
|
import net.minecraft.util.math.BlockRayTraceResult;
|
||||||
|
@ -55,6 +53,7 @@ import net.minecraft.util.math.RayTraceContext;
|
||||||
import net.minecraft.util.math.RayTraceContext.BlockMode;
|
import net.minecraft.util.math.RayTraceContext.BlockMode;
|
||||||
import net.minecraft.util.math.RayTraceContext.FluidMode;
|
import net.minecraft.util.math.RayTraceContext.FluidMode;
|
||||||
import net.minecraft.util.math.vector.Vector3d;
|
import net.minecraft.util.math.vector.Vector3d;
|
||||||
|
import net.minecraft.world.GameType;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
import net.minecraft.world.server.ServerWorld;
|
import net.minecraft.world.server.ServerWorld;
|
||||||
import net.minecraftforge.common.ForgeHooks;
|
import net.minecraftforge.common.ForgeHooks;
|
||||||
|
@ -218,7 +217,7 @@ public class DeployerHandler {
|
||||||
progress += before;
|
progress += before;
|
||||||
|
|
||||||
if (progress >= 1) {
|
if (progress >= 1) {
|
||||||
safeTryHarvestBlock(player.interactionManager, clickedPos);
|
tryHarvestBlock(player.interactionManager, clickedPos);
|
||||||
world.sendBlockBreakProgress(player.getEntityId(), clickedPos, -1);
|
world.sendBlockBreakProgress(player.getEntityId(), clickedPos, -1);
|
||||||
player.blockBreakingProgress = null;
|
player.blockBreakingProgress = null;
|
||||||
return;
|
return;
|
||||||
|
@ -240,7 +239,7 @@ public class DeployerHandler {
|
||||||
Event.Result useItem = DEFAULT;
|
Event.Result useItem = DEFAULT;
|
||||||
if (!clickedState.getShape(world, clickedPos)
|
if (!clickedState.getShape(world, clickedPos)
|
||||||
.isEmpty()) {
|
.isEmpty()) {
|
||||||
RightClickBlock event = ForgeHooks.onRightClickBlock(player, hand, clickedPos, face);
|
RightClickBlock event = ForgeHooks.onRightClickBlock(player, hand, clickedPos, result);
|
||||||
useBlock = event.getUseBlock();
|
useBlock = event.getUseBlock();
|
||||||
useItem = event.getUseItem();
|
useItem = event.getUseItem();
|
||||||
}
|
}
|
||||||
|
@ -257,11 +256,9 @@ public class DeployerHandler {
|
||||||
boolean flag1 =
|
boolean flag1 =
|
||||||
!(player.isSneaking() && holdingSomething) || (stack.doesSneakBypassUse(world, clickedPos, player));
|
!(player.isSneaking() && holdingSomething) || (stack.doesSneakBypassUse(world, clickedPos, player));
|
||||||
|
|
||||||
if (clickedState.getBlock() instanceof BeehiveBlock)
|
|
||||||
return; // Beehives assume a lot about the usage context. Crashes to side-effects
|
|
||||||
|
|
||||||
// Use on block
|
// Use on block
|
||||||
if (useBlock != DENY && flag1 && clickedState.onUse(world, player, hand, result) == ActionResultType.SUCCESS)
|
if (useBlock != DENY && flag1
|
||||||
|
&& safeOnUse(clickedState, world, clickedPos, player, hand, result) == ActionResultType.SUCCESS)
|
||||||
return;
|
return;
|
||||||
if (stack.isEmpty())
|
if (stack.isEmpty())
|
||||||
return;
|
return;
|
||||||
|
@ -296,7 +293,8 @@ public class DeployerHandler {
|
||||||
|
|
||||||
ActionResult<ItemStack> onItemRightClick = item.onItemRightClick(itemUseWorld, player, hand);
|
ActionResult<ItemStack> onItemRightClick = item.onItemRightClick(itemUseWorld, player, hand);
|
||||||
ItemStack resultStack = onItemRightClick.getResult();
|
ItemStack resultStack = onItemRightClick.getResult();
|
||||||
if (resultStack != stack || resultStack.getCount() != stack.getCount() || resultStack.getUseDuration() > 0 || resultStack.getDamage() != stack.getDamage()) {
|
if (resultStack != stack || resultStack.getCount() != stack.getCount() || resultStack.getUseDuration() > 0
|
||||||
|
|| resultStack.getDamage() != stack.getDamage()) {
|
||||||
player.setHeldItem(hand, onItemRightClick.getResult());
|
player.setHeldItem(hand, onItemRightClick.getResult());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -311,51 +309,89 @@ public class DeployerHandler {
|
||||||
player.resetActiveHand();
|
player.resetActiveHand();
|
||||||
}
|
}
|
||||||
|
|
||||||
private static boolean safeTryHarvestBlock(PlayerInteractionManager interactionManager, BlockPos clickedPos) {
|
public static boolean tryHarvestBlock(PlayerInteractionManager interactionManager, BlockPos pos) {
|
||||||
BlockState state = interactionManager.world.getBlockState(clickedPos);
|
// <> PlayerInteractionManager#tryHarvestBlock
|
||||||
if (!(state.getBlock() instanceof BeehiveBlock))
|
|
||||||
return interactionManager.tryHarvestBlock(clickedPos);
|
ServerWorld world = interactionManager.world;
|
||||||
else {
|
ServerPlayerEntity player = interactionManager.player;
|
||||||
harvestBeehive(interactionManager, state, clickedPos);
|
BlockState blockstate = world.getBlockState(pos);
|
||||||
}
|
GameType gameType = interactionManager.getGameType();
|
||||||
|
|
||||||
|
if (net.minecraftforge.common.ForgeHooks.onBlockBreakEvent(world, gameType, player, pos) == -1)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
TileEntity tileentity = world.getTileEntity(pos);
|
||||||
|
if (player.getHeldItemMainhand()
|
||||||
|
.onBlockStartBreak(pos, player))
|
||||||
|
return false;
|
||||||
|
if (player.isBlockBreakingRestricted(world, pos, gameType))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
ItemStack prevHeldItem = player.getHeldItemMainhand();
|
||||||
|
ItemStack heldItem = prevHeldItem.copy();
|
||||||
|
|
||||||
|
boolean canHarvest = blockstate.canHarvestBlock(world, pos, player);
|
||||||
|
prevHeldItem.onBlockDestroyed(world, blockstate, pos, player);
|
||||||
|
if (prevHeldItem.isEmpty() && !heldItem.isEmpty())
|
||||||
|
net.minecraftforge.event.ForgeEventFactory.onPlayerDestroyItem(player, heldItem, Hand.MAIN_HAND);
|
||||||
|
if (!blockstate.removedByPlayer(world, pos, player, canHarvest, world.getFluidState(pos)))
|
||||||
|
return true;
|
||||||
|
|
||||||
|
blockstate.getBlock()
|
||||||
|
.onPlayerDestroy(world, pos, blockstate);
|
||||||
|
if (!canHarvest)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
Block.getDrops(blockstate, world, pos, tileentity, player, prevHeldItem)
|
||||||
|
.forEach(item -> player.inventory.placeItemBackInInventory(world, item));
|
||||||
|
blockstate.spawnAdditionalDrops(world, pos, prevHeldItem);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void harvestBeehive(PlayerInteractionManager interactionManager, BlockState state,
|
public static ActionResultType safeOnUse(BlockState state, World world, BlockPos pos, PlayerEntity player,
|
||||||
BlockPos clickedPos) {
|
Hand hand, BlockRayTraceResult ray) {
|
||||||
// Modified code from PlayerInteractionManager, Block and BeehiveBlock to handle
|
if (state.getBlock() instanceof BeehiveBlock)
|
||||||
// deployers breaking beehives without crash.
|
return safeOnBeehiveUse(state, world, pos, player, hand);
|
||||||
ItemStack itemstack = interactionManager.player.getHeldItemMainhand();
|
return state.onUse(world, player, hand, ray);
|
||||||
ItemStack itemstack1 = itemstack.copy();
|
|
||||||
|
|
||||||
boolean flag1 = state.canHarvestBlock(interactionManager.world, clickedPos, interactionManager.player);
|
|
||||||
itemstack.onBlockDestroyed(interactionManager.world, state, clickedPos, interactionManager.player);
|
|
||||||
if (itemstack.isEmpty() && !itemstack1.isEmpty())
|
|
||||||
net.minecraftforge.event.ForgeEventFactory.onPlayerDestroyItem(interactionManager.player, itemstack1,
|
|
||||||
Hand.MAIN_HAND);
|
|
||||||
|
|
||||||
boolean flag = state.removedByPlayer(interactionManager.world, clickedPos, interactionManager.player, flag1,
|
|
||||||
interactionManager.world.getFluidState(clickedPos));
|
|
||||||
if (flag)
|
|
||||||
state.getBlock()
|
|
||||||
.onPlayerDestroy(interactionManager.world, clickedPos, state);
|
|
||||||
|
|
||||||
if (flag && flag1) {
|
|
||||||
interactionManager.player.addStat(Stats.BLOCK_MINED.get(state.getBlock()));
|
|
||||||
interactionManager.player.addExhaustion(0.005F);
|
|
||||||
TileEntity te = interactionManager.world.getTileEntity(clickedPos);
|
|
||||||
ItemStack heldItem = interactionManager.player.getHeldItemMainhand();
|
|
||||||
Block.spawnDrops(state, interactionManager.world, clickedPos, te, interactionManager.player, heldItem);
|
|
||||||
|
|
||||||
if (!interactionManager.world.isRemote && te instanceof BeehiveTileEntity) {
|
|
||||||
BeehiveTileEntity beehivetileentity = (BeehiveTileEntity) te;
|
|
||||||
if (EnchantmentHelper.getEnchantmentLevel(Enchantments.SILK_TOUCH, heldItem) == 0) {
|
|
||||||
interactionManager.world.updateComparatorOutputLevel(clickedPos, state.getBlock());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
CriteriaTriggers.BEE_NEST_DESTROYED.test(interactionManager.player,
|
protected static ActionResultType safeOnBeehiveUse(BlockState state, World world, BlockPos pos, PlayerEntity player,
|
||||||
state.getBlock(), heldItem, beehivetileentity.getBeeCount());
|
Hand hand) {
|
||||||
|
// <> BeehiveBlock#onUse
|
||||||
|
|
||||||
|
BeehiveBlock block = (BeehiveBlock) state.getBlock();
|
||||||
|
ItemStack prevHeldItem = player.getHeldItem(hand);
|
||||||
|
int honeyLevel = state.get(BeehiveBlock.HONEY_LEVEL);
|
||||||
|
boolean success = false;
|
||||||
|
if (honeyLevel < 5)
|
||||||
|
return ActionResultType.PASS;
|
||||||
|
|
||||||
|
if (prevHeldItem.getItem() == Items.SHEARS) {
|
||||||
|
world.playSound(player, player.getX(), player.getY(), player.getZ(), SoundEvents.BLOCK_BEEHIVE_SHEAR,
|
||||||
|
SoundCategory.NEUTRAL, 1.0F, 1.0F);
|
||||||
|
// <> BeehiveBlock#dropHoneycomb
|
||||||
|
player.inventory.placeItemBackInInventory(world, new ItemStack(Items.HONEYCOMB, 3));
|
||||||
|
prevHeldItem.damageItem(1, player, s -> s.sendBreakAnimation(hand));
|
||||||
|
success = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (prevHeldItem.getItem() == Items.GLASS_BOTTLE) {
|
||||||
|
prevHeldItem.shrink(1);
|
||||||
|
world.playSound(player, player.getX(), player.getY(), player.getZ(), SoundEvents.ITEM_BOTTLE_FILL,
|
||||||
|
SoundCategory.NEUTRAL, 1.0F, 1.0F);
|
||||||
|
ItemStack honeyBottle = new ItemStack(Items.HONEY_BOTTLE);
|
||||||
|
if (prevHeldItem.isEmpty())
|
||||||
|
player.setHeldItem(hand, honeyBottle);
|
||||||
|
else
|
||||||
|
player.inventory.placeItemBackInInventory(world, honeyBottle);
|
||||||
|
success = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!success)
|
||||||
|
return ActionResultType.PASS;
|
||||||
|
|
||||||
|
block.takeHoney(world, state, pos);
|
||||||
|
return ActionResultType.SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -59,6 +59,11 @@ public class ContraptionKineticRenderer extends InstancedTileRenderer<Contraptio
|
||||||
actors.forEach(ActorInstance::beginFrame);
|
actors.forEach(ActorInstance::beginFrame);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected boolean shouldTick(BlockPos worldPos, float lookX, float lookY, float lookZ, int cX, int cY, int cZ) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
public ActorInstance createActor(Pair<Template.BlockInfo, MovementContext> actor) {
|
public ActorInstance createActor(Pair<Template.BlockInfo, MovementContext> actor) {
|
||||||
Template.BlockInfo blockInfo = actor.getLeft();
|
Template.BlockInfo blockInfo = actor.getLeft();
|
||||||
|
|
|
@ -157,6 +157,8 @@ public class FluidPropagator {
|
||||||
if (PumpBlock.isPump(connectedState) && connectedState.get(PumpBlock.FACING)
|
if (PumpBlock.isPump(connectedState) && connectedState.get(PumpBlock.FACING)
|
||||||
.getAxis() == side.getAxis())
|
.getAxis() == side.getAxis())
|
||||||
return false;
|
return false;
|
||||||
|
if (connectedState.contains(BlockStateProperties.HONEY_LEVEL))
|
||||||
|
return true;
|
||||||
if (BlockHelper.hasBlockSolidSide(connectedState, reader, connectedPos, side.getOpposite()))
|
if (BlockHelper.hasBlockSolidSide(connectedState, reader, connectedPos, side.getOpposite()))
|
||||||
return false;
|
return false;
|
||||||
if (!(connectedState.getMaterial()
|
if (!(connectedState.getMaterial()
|
||||||
|
|
|
@ -1,5 +1,8 @@
|
||||||
package com.simibubi.create.content.contraptions.fluids;
|
package com.simibubi.create.content.contraptions.fluids;
|
||||||
|
|
||||||
|
import static net.minecraft.state.properties.BlockStateProperties.HONEY_LEVEL;
|
||||||
|
import static net.minecraft.state.properties.BlockStateProperties.WATERLOGGED;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import javax.annotation.Nullable;
|
import javax.annotation.Nullable;
|
||||||
|
@ -22,7 +25,6 @@ import net.minecraft.nbt.CompoundNBT;
|
||||||
import net.minecraft.potion.Effect;
|
import net.minecraft.potion.Effect;
|
||||||
import net.minecraft.potion.EffectInstance;
|
import net.minecraft.potion.EffectInstance;
|
||||||
import net.minecraft.potion.PotionUtils;
|
import net.minecraft.potion.PotionUtils;
|
||||||
import net.minecraft.state.properties.BlockStateProperties;
|
|
||||||
import net.minecraft.tags.FluidTags;
|
import net.minecraft.tags.FluidTags;
|
||||||
import net.minecraft.util.Direction;
|
import net.minecraft.util.Direction;
|
||||||
import net.minecraft.util.SoundCategory;
|
import net.minecraft.util.SoundCategory;
|
||||||
|
@ -72,7 +74,13 @@ public class OpenEndedPipe extends FlowSource {
|
||||||
|
|
||||||
BlockState state = world.getBlockState(outputPos);
|
BlockState state = world.getBlockState(outputPos);
|
||||||
FluidState fluidState = state.getFluidState();
|
FluidState fluidState = state.getFluidState();
|
||||||
boolean waterlog = state.contains(BlockStateProperties.WATERLOGGED);
|
boolean waterlog = state.contains(WATERLOGGED);
|
||||||
|
|
||||||
|
if (state.contains(HONEY_LEVEL) && state.get(HONEY_LEVEL) >= 5) {
|
||||||
|
if (!simulate)
|
||||||
|
world.setBlockState(outputPos, state.with(HONEY_LEVEL, 0), 3);
|
||||||
|
return new FluidStack(AllFluids.HONEY.get(), 250);
|
||||||
|
}
|
||||||
|
|
||||||
if (!waterlog && !state.getMaterial()
|
if (!waterlog && !state.getMaterial()
|
||||||
.isReplaceable())
|
.isReplaceable())
|
||||||
|
@ -88,7 +96,7 @@ public class OpenEndedPipe extends FlowSource {
|
||||||
AllTriggers.triggerForNearbyPlayers(AllTriggers.PIPE_SPILL, world, pos, 5);
|
AllTriggers.triggerForNearbyPlayers(AllTriggers.PIPE_SPILL, world, pos, 5);
|
||||||
|
|
||||||
if (waterlog) {
|
if (waterlog) {
|
||||||
world.setBlockState(outputPos, state.with(BlockStateProperties.WATERLOGGED, false), 3);
|
world.setBlockState(outputPos, state.with(WATERLOGGED, false), 3);
|
||||||
world.getPendingFluidTicks()
|
world.getPendingFluidTicks()
|
||||||
.scheduleTick(outputPos, Fluids.WATER, 1);
|
.scheduleTick(outputPos, Fluids.WATER, 1);
|
||||||
return stack;
|
return stack;
|
||||||
|
@ -106,7 +114,7 @@ public class OpenEndedPipe extends FlowSource {
|
||||||
|
|
||||||
BlockState state = world.getBlockState(outputPos);
|
BlockState state = world.getBlockState(outputPos);
|
||||||
FluidState fluidState = state.getFluidState();
|
FluidState fluidState = state.getFluidState();
|
||||||
boolean waterlog = state.contains(BlockStateProperties.WATERLOGGED);
|
boolean waterlog = state.contains(WATERLOGGED);
|
||||||
|
|
||||||
if (!waterlog && !state.getMaterial()
|
if (!waterlog && !state.getMaterial()
|
||||||
.isReplaceable())
|
.isReplaceable())
|
||||||
|
@ -144,7 +152,7 @@ public class OpenEndedPipe extends FlowSource {
|
||||||
AllTriggers.triggerForNearbyPlayers(AllTriggers.PIPE_SPILL, world, pos, 5);
|
AllTriggers.triggerForNearbyPlayers(AllTriggers.PIPE_SPILL, world, pos, 5);
|
||||||
|
|
||||||
if (waterlog) {
|
if (waterlog) {
|
||||||
world.setBlockState(outputPos, state.with(BlockStateProperties.WATERLOGGED, true), 3);
|
world.setBlockState(outputPos, state.with(WATERLOGGED, true), 3);
|
||||||
world.getPendingFluidTicks()
|
world.getPendingFluidTicks()
|
||||||
.scheduleTick(outputPos, Fluids.WATER, 1);
|
.scheduleTick(outputPos, Fluids.WATER, 1);
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -142,6 +142,8 @@ public class FluidPipeBlock extends SixWayBlock implements IWaterLoggable, IWren
|
||||||
public static boolean canConnectTo(IBlockDisplayReader world, BlockPos neighbourPos, BlockState neighbour, Direction direction) {
|
public static boolean canConnectTo(IBlockDisplayReader world, BlockPos neighbourPos, BlockState neighbour, Direction direction) {
|
||||||
if (FluidPropagator.hasFluidCapability(world, neighbourPos, direction.getOpposite()))
|
if (FluidPropagator.hasFluidCapability(world, neighbourPos, direction.getOpposite()))
|
||||||
return true;
|
return true;
|
||||||
|
if (neighbour.has(BlockStateProperties.HONEY_LEVEL))
|
||||||
|
return true;
|
||||||
FluidTransportBehaviour transport = TileEntityBehaviour.get(world, neighbourPos, FluidTransportBehaviour.TYPE);
|
FluidTransportBehaviour transport = TileEntityBehaviour.get(world, neighbourPos, FluidTransportBehaviour.TYPE);
|
||||||
BracketedTileEntityBehaviour bracket = TileEntityBehaviour.get(world, neighbourPos, BracketedTileEntityBehaviour.TYPE);
|
BracketedTileEntityBehaviour bracket = TileEntityBehaviour.get(world, neighbourPos, BracketedTileEntityBehaviour.TYPE);
|
||||||
if (isPipe(neighbour))
|
if (isPipe(neighbour))
|
||||||
|
|
|
@ -78,13 +78,13 @@ public class ArmTileEntity extends KineticTileEntity {
|
||||||
phase = Phase.SEARCH_INPUTS;
|
phase = Phase.SEARCH_INPUTS;
|
||||||
previousTarget = ArmAngleTarget.NO_TARGET;
|
previousTarget = ArmAngleTarget.NO_TARGET;
|
||||||
baseAngle = new InterpolatedAngle();
|
baseAngle = new InterpolatedAngle();
|
||||||
baseAngle.set(previousTarget.baseAngle);
|
baseAngle.init(previousTarget.baseAngle);
|
||||||
lowerArmAngle = new InterpolatedAngle();
|
lowerArmAngle = new InterpolatedAngle();
|
||||||
lowerArmAngle.set(previousTarget.lowerArmAngle);
|
lowerArmAngle.init(previousTarget.lowerArmAngle);
|
||||||
upperArmAngle = new InterpolatedAngle();
|
upperArmAngle = new InterpolatedAngle();
|
||||||
upperArmAngle.set(previousTarget.upperArmAngle);
|
upperArmAngle.init(previousTarget.upperArmAngle);
|
||||||
headAngle = new InterpolatedAngle();
|
headAngle = new InterpolatedAngle();
|
||||||
headAngle.set(previousTarget.headAngle);
|
headAngle.init(previousTarget.headAngle);
|
||||||
clawAngle = new InterpolatedAngle();
|
clawAngle = new InterpolatedAngle();
|
||||||
previousBaseAngle = previousTarget.baseAngle;
|
previousBaseAngle = previousTarget.baseAngle;
|
||||||
updateInteractionPoints = true;
|
updateInteractionPoints = true;
|
||||||
|
|
|
@ -12,15 +12,21 @@ public class CClient extends ConfigBase {
|
||||||
public ConfigFloat fanParticleDensity = f(.5f, 0, 1, "fanParticleDensity");
|
public ConfigFloat fanParticleDensity = f(.5f, 0, 1, "fanParticleDensity");
|
||||||
public ConfigBool rainbowDebug =
|
public ConfigBool rainbowDebug =
|
||||||
b(true, "enableRainbowDebug", "Show colourful debug information while the F3-Menu is open.");
|
b(true, "enableRainbowDebug", "Show colourful debug information while the F3-Menu is open.");
|
||||||
|
|
||||||
public ConfigBool experimentalRendering =
|
public ConfigBool experimentalRendering =
|
||||||
b(true, "experimentalRendering", "Use modern OpenGL features to drastically increase performance.");
|
b(true, "experimentalRendering", "Use modern OpenGL features to drastically increase performance.");
|
||||||
|
public ConfigInt overlayOffsetX = i(20, Integer.MIN_VALUE, Integer.MAX_VALUE, "overlayOffsetX",
|
||||||
public ConfigInt overlayOffsetX = i(20, Integer.MIN_VALUE, Integer.MAX_VALUE, "overlayOffsetX", "Offset the overlay from goggle- and hover- information by this many pixels on the X axis; Use /create overlay");
|
"Offset the overlay from goggle- and hover- information by this many pixels on the X axis; Use /create overlay");
|
||||||
public ConfigInt overlayOffsetY = i(0, Integer.MIN_VALUE, Integer.MAX_VALUE, "overlayOffsetY", "Offset the overlay from goggle- and hover- information by this many pixels on the Y axis; Use /create overlay");
|
public ConfigInt overlayOffsetY = i(0, Integer.MIN_VALUE, Integer.MAX_VALUE, "overlayOffsetY",
|
||||||
|
"Offset the overlay from goggle- and hover- information by this many pixels on the Y axis; Use /create overlay");
|
||||||
|
public ConfigBool smoothPlacementIndicator = b(false, "smoothPlacementIndicator",
|
||||||
|
"Use an alternative indicator when showing where the assisted placement ends up relative to your crosshair");
|
||||||
public ConfigEnum<PlacementIndicatorSetting> placementIndicator = e(PlacementIndicatorSetting.TEXTURE, "placementIndicator", "What indicator should be used when showing where the assisted placement ends up relative to your crosshair");
|
public ConfigEnum<PlacementIndicatorSetting> placementIndicator = e(PlacementIndicatorSetting.TEXTURE, "placementIndicator", "What indicator should be used when showing where the assisted placement ends up relative to your crosshair");
|
||||||
public ConfigBool ignoreFabulousWarning = b(false, "ignoreFabulousWarning", "Setting this to true will prevent Create from sending you a warning when playing with Fabulous graphics enabled");
|
public ConfigBool ignoreFabulousWarning = b(false, "ignoreFabulousWarning", "Setting this to true will prevent Create from sending you a warning when playing with Fabulous graphics enabled");
|
||||||
|
|
||||||
|
public ConfigGroup ponder = group(1, "ponder", "Ponder settings");
|
||||||
|
public ConfigBool comfyReading =
|
||||||
|
b(false, "comfyReading", "Slow down a ponder scene whenever there is text on screen.");
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getName() {
|
public String getName() {
|
||||||
return "client";
|
return "client";
|
||||||
|
|
|
@ -13,6 +13,11 @@ public class InterpolatedValue {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public InterpolatedValue init(float value) {
|
||||||
|
this.lastValue = this.value = value;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
public float get(float partialTicks) {
|
public float get(float partialTicks) {
|
||||||
return MathHelper.lerp(partialTicks, lastValue, value);
|
return MathHelper.lerp(partialTicks, lastValue, value);
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,6 +5,7 @@ import static com.simibubi.create.foundation.ponder.PonderLocalization.LANG_PREF
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Random;
|
||||||
import java.util.stream.IntStream;
|
import java.util.stream.IntStream;
|
||||||
|
|
||||||
import org.apache.commons.lang3.mutable.MutableBoolean;
|
import org.apache.commons.lang3.mutable.MutableBoolean;
|
||||||
|
@ -12,7 +13,12 @@ import org.lwjgl.opengl.GL11;
|
||||||
|
|
||||||
import com.mojang.blaze3d.matrix.MatrixStack;
|
import com.mojang.blaze3d.matrix.MatrixStack;
|
||||||
import com.mojang.blaze3d.systems.RenderSystem;
|
import com.mojang.blaze3d.systems.RenderSystem;
|
||||||
import com.simibubi.create.foundation.gui.*;
|
import com.simibubi.create.foundation.config.AllConfigs;
|
||||||
|
import com.simibubi.create.foundation.gui.AllGuiTextures;
|
||||||
|
import com.simibubi.create.foundation.gui.AllIcons;
|
||||||
|
import com.simibubi.create.foundation.gui.GuiGameElement;
|
||||||
|
import com.simibubi.create.foundation.gui.ScreenOpener;
|
||||||
|
import com.simibubi.create.foundation.gui.UIRenderHelper;
|
||||||
import com.simibubi.create.foundation.ponder.PonderScene.SceneTransform;
|
import com.simibubi.create.foundation.ponder.PonderScene.SceneTransform;
|
||||||
import com.simibubi.create.foundation.ponder.content.DebugScenes;
|
import com.simibubi.create.foundation.ponder.content.DebugScenes;
|
||||||
import com.simibubi.create.foundation.ponder.content.PonderChapter;
|
import com.simibubi.create.foundation.ponder.content.PonderChapter;
|
||||||
|
@ -22,9 +28,15 @@ import com.simibubi.create.foundation.ponder.content.PonderTagScreen;
|
||||||
import com.simibubi.create.foundation.ponder.elements.TextWindowElement;
|
import com.simibubi.create.foundation.ponder.elements.TextWindowElement;
|
||||||
import com.simibubi.create.foundation.ponder.ui.PonderButton;
|
import com.simibubi.create.foundation.ponder.ui.PonderButton;
|
||||||
import com.simibubi.create.foundation.renderState.SuperRenderTypeBuffer;
|
import com.simibubi.create.foundation.renderState.SuperRenderTypeBuffer;
|
||||||
import com.simibubi.create.foundation.utility.*;
|
import com.simibubi.create.foundation.utility.ColorHelper;
|
||||||
|
import com.simibubi.create.foundation.utility.FontHelper;
|
||||||
|
import com.simibubi.create.foundation.utility.Iterate;
|
||||||
|
import com.simibubi.create.foundation.utility.Lang;
|
||||||
|
import com.simibubi.create.foundation.utility.Pair;
|
||||||
|
import com.simibubi.create.foundation.utility.Pointing;
|
||||||
import com.simibubi.create.foundation.utility.animation.LerpedFloat;
|
import com.simibubi.create.foundation.utility.animation.LerpedFloat;
|
||||||
import com.simibubi.create.foundation.utility.animation.LerpedFloat.Chaser;
|
import com.simibubi.create.foundation.utility.animation.LerpedFloat.Chaser;
|
||||||
|
|
||||||
import net.minecraft.client.ClipboardHelper;
|
import net.minecraft.client.ClipboardHelper;
|
||||||
import net.minecraft.client.GameSettings;
|
import net.minecraft.client.GameSettings;
|
||||||
import net.minecraft.client.MainWindow;
|
import net.minecraft.client.MainWindow;
|
||||||
|
@ -50,8 +62,6 @@ import net.minecraft.world.gen.feature.template.Template;
|
||||||
import net.minecraftforge.fml.client.gui.GuiUtils;
|
import net.minecraftforge.fml.client.gui.GuiUtils;
|
||||||
import net.minecraftforge.registries.ForgeRegistries;
|
import net.minecraftforge.registries.ForgeRegistries;
|
||||||
|
|
||||||
import java.util.Random;
|
|
||||||
|
|
||||||
public class PonderUI extends NavigatableSimiScreen {
|
public class PonderUI extends NavigatableSimiScreen {
|
||||||
|
|
||||||
public static int ponderTicks;
|
public static int ponderTicks;
|
||||||
|
@ -76,7 +86,6 @@ public class PonderUI extends NavigatableSimiScreen {
|
||||||
PonderChapter chapter = null;
|
PonderChapter chapter = null;
|
||||||
|
|
||||||
private boolean userViewMode;
|
private boolean userViewMode;
|
||||||
private boolean slowTextMode;
|
|
||||||
private boolean identifyMode;
|
private boolean identifyMode;
|
||||||
private ItemStack hoveredTooltipItem;
|
private ItemStack hoveredTooltipItem;
|
||||||
private BlockPos hoveredBlockPos;
|
private BlockPos hoveredBlockPos;
|
||||||
|
@ -201,7 +210,7 @@ public class PonderUI extends NavigatableSimiScreen {
|
||||||
.fade(0, -1));
|
.fade(0, -1));
|
||||||
|
|
||||||
widgets.add(slowMode = new PonderButton(width - 20 - 31, bY, () -> {
|
widgets.add(slowMode = new PonderButton(width - 20 - 31, bY, () -> {
|
||||||
slowTextMode = !slowTextMode;
|
setComfyReadingEnabled(!isComfyReadingEnabled());
|
||||||
}).showing(AllIcons.I_MTD_SLOW_MODE)
|
}).showing(AllIcons.I_MTD_SLOW_MODE)
|
||||||
.fade(0, -1));
|
.fade(0, -1));
|
||||||
|
|
||||||
|
@ -265,7 +274,7 @@ public class PonderUI extends NavigatableSimiScreen {
|
||||||
PonderScene activeScene = scenes.get(index);
|
PonderScene activeScene = scenes.get(index);
|
||||||
|
|
||||||
extendedTickLength = 0;
|
extendedTickLength = 0;
|
||||||
if (slowTextMode)
|
if (isComfyReadingEnabled())
|
||||||
activeScene.forEachVisible(TextWindowElement.class, twe -> extendedTickLength = 2);
|
activeScene.forEachVisible(TextWindowElement.class, twe -> extendedTickLength = 2);
|
||||||
|
|
||||||
if (extendedTickTimer == 0) {
|
if (extendedTickTimer == 0) {
|
||||||
|
@ -612,7 +621,7 @@ public class PonderUI extends NavigatableSimiScreen {
|
||||||
userMode.dim();
|
userMode.dim();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (slowTextMode)
|
if (isComfyReadingEnabled())
|
||||||
slowMode.flash();
|
slowMode.flash();
|
||||||
else
|
else
|
||||||
slowMode.dim();
|
slowMode.dim();
|
||||||
|
@ -976,4 +985,13 @@ public class PonderUI extends NavigatableSimiScreen {
|
||||||
public void drawRightAlignedString(FontRenderer fontRenderer, MatrixStack ms, String string, int x, int y, int color) {
|
public void drawRightAlignedString(FontRenderer fontRenderer, MatrixStack ms, String string, int x, int y, int color) {
|
||||||
fontRenderer.draw(ms, string, (float)(x - fontRenderer.getStringWidth(string)), (float)y, color);
|
fontRenderer.draw(ms, string, (float)(x - fontRenderer.getStringWidth(string)), (float)y, color);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean isComfyReadingEnabled() {
|
||||||
|
return AllConfigs.CLIENT.comfyReading.get();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setComfyReadingEnabled(boolean slowTextMode) {
|
||||||
|
AllConfigs.CLIENT.comfyReading.set(slowTextMode);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -8,7 +8,7 @@ import net.minecraft.block.Blocks;
|
||||||
|
|
||||||
public class PonderIndex {
|
public class PonderIndex {
|
||||||
|
|
||||||
public static final boolean EDITOR_MODE = true;
|
public static final boolean EDITOR_MODE = false;
|
||||||
|
|
||||||
public static void register() {
|
public static void register() {
|
||||||
// Register storyboards here
|
// Register storyboards here
|
||||||
|
|
|
@ -84,8 +84,8 @@ public class InputWindowElement extends AnimatedOverlayElement {
|
||||||
int width = 0;
|
int width = 0;
|
||||||
int height = 0;
|
int height = 0;
|
||||||
|
|
||||||
int xFade = direction == Pointing.RIGHT ? -1 : direction == Pointing.LEFT ? 1 : 0;
|
float xFade = direction == Pointing.RIGHT ? -1 : direction == Pointing.LEFT ? 1 : 0;
|
||||||
int yFade = direction == Pointing.DOWN ? -1 : direction == Pointing.UP ? 1 : 0;
|
float yFade = direction == Pointing.DOWN ? -1 : direction == Pointing.UP ? 1 : 0;
|
||||||
xFade *= 10 * (1 - fade);
|
xFade *= 10 * (1 - fade);
|
||||||
yFade *= 10 * (1 - fade);
|
yFade *= 10 * (1 - fade);
|
||||||
|
|
||||||
|
|
|
@ -60,11 +60,7 @@ public abstract class InstancedTileRenderer<P extends BasicProgram> {
|
||||||
int dY = pos.getY() - cY;
|
int dY = pos.getY() - cY;
|
||||||
int dZ = pos.getZ() - cZ;
|
int dZ = pos.getZ() - cZ;
|
||||||
|
|
||||||
int dSq = dX * dX + dY * dY + dZ * dZ;
|
if ((frame % getUpdateDivisor(dX, dY, dZ)) == 0)
|
||||||
|
|
||||||
int divisor = (dSq / 1024) + 1;
|
|
||||||
|
|
||||||
if (frame % divisor == 0)
|
|
||||||
instance.tick();
|
instance.tick();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -91,21 +87,7 @@ public abstract class InstancedTileRenderer<P extends BasicProgram> {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
BlockPos pos = dyn.getWorldPosition();
|
if (shouldTick(dyn.getWorldPosition(), lookX, lookY, lookZ, cX, cY, cZ))
|
||||||
|
|
||||||
int dX = pos.getX() - cX;
|
|
||||||
int dY = pos.getY() - cY;
|
|
||||||
int dZ = pos.getZ() - cZ;
|
|
||||||
|
|
||||||
float dot = dX * lookX + dY * lookY + dZ * lookZ;
|
|
||||||
|
|
||||||
if (dot < 0) continue; // is it behind the camera?
|
|
||||||
|
|
||||||
int dSq = dX * dX + dY * dY + dZ * dZ;
|
|
||||||
|
|
||||||
int divisor = (dSq / 1024) + 1; // https://www.desmos.com/calculator/aaycpludsy
|
|
||||||
|
|
||||||
if (frame % divisor == 0)
|
|
||||||
dyn.beginFrame();
|
dyn.beginFrame();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -210,6 +192,24 @@ public abstract class InstancedTileRenderer<P extends BasicProgram> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected boolean shouldTick(BlockPos worldPos, float lookX, float lookY, float lookZ, int cX, int cY, int cZ) {
|
||||||
|
int dX = worldPos.getX() - cX;
|
||||||
|
int dY = worldPos.getY() - cY;
|
||||||
|
int dZ = worldPos.getZ() - cZ;
|
||||||
|
|
||||||
|
float dot = dX * lookX + dY * lookY + dZ * lookZ;
|
||||||
|
|
||||||
|
if (dot < 0) return false; // is it behind the camera?
|
||||||
|
|
||||||
|
return (frame % getUpdateDivisor(dX, dY, dZ)) == 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected int getUpdateDivisor(int dX, int dY, int dZ) {
|
||||||
|
int dSq = dX * dX + dY * dY + dZ * dZ;
|
||||||
|
|
||||||
|
return (dSq / 1024) + 1;
|
||||||
|
}
|
||||||
|
|
||||||
private void addInternal(TileEntity tile) {
|
private void addInternal(TileEntity tile) {
|
||||||
getInstance(tile, true);
|
getInstance(tile, true);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue