From 4368fe33a3627cab93a5b8d51dbfea40b2b2607a Mon Sep 17 00:00:00 2001 From: OmdaCZ <140348253+OmdaCZ@users.noreply.github.com> Date: Fri, 6 Sep 2024 11:11:05 +0200 Subject: [PATCH] Multiblock machine for Fluid Solidifier (#2808) Co-authored-by: Mary Hopson Co-authored-by: GDCloud Co-authored-by: Dream Master Co-authored-by: Caedis Co-authored-by: NotAPenguin --- .../java/gregtech/api/enums/GTValues.java | 5 +- .../java/gregtech/api/enums/ItemList.java | 4 + .../gregtech/api/enums/MetaTileEntityIDs.java | 1 + .../java/gregtech/api/enums/Textures.java | 3 + .../common/blocks/BlockCasings10.java | 7 + .../machines/multi/MTEMultiSolidifier.java | 692 ++++++++++++++++++ .../preload/LoaderMetaTileEntities.java | 6 + .../blocks/iconsets/MACHINE_CASING_MS160.png | Bin 0 -> 616 bytes .../blocks/iconsets/RADIATOR_MS160.png | Bin 0 -> 2207 bytes 9 files changed, 717 insertions(+), 1 deletion(-) create mode 100644 src/main/java/gregtech/common/tileentities/machines/multi/MTEMultiSolidifier.java create mode 100644 src/main/resources/assets/gregtech/textures/blocks/iconsets/MACHINE_CASING_MS160.png create mode 100644 src/main/resources/assets/gregtech/textures/blocks/iconsets/RADIATOR_MS160.png diff --git a/src/main/java/gregtech/api/enums/GTValues.java b/src/main/java/gregtech/api/enums/GTValues.java index eaca14b3eec..69df9c25a6b 100644 --- a/src/main/java/gregtech/api/enums/GTValues.java +++ b/src/main/java/gregtech/api/enums/GTValues.java @@ -32,7 +32,6 @@ import gregtech.api.interfaces.internal.IGTMod; import gregtech.api.interfaces.internal.IGTRecipeAdder; import gregtech.api.net.IGT_NetworkHandler; -import gregtech.api.util.GTChunkAssociatedData; /** * Made for static imports, this Class is just a Helper. @@ -657,6 +656,10 @@ public static final class NBT { + "Ba" + EnumChatFormatting.LIGHT_PURPLE + "ps"; + public static final String AuthorOmdaCZ = "Author: " + EnumChatFormatting.BLUE + + "Omda" + + EnumChatFormatting.RED + + "CZ"; public static final String AuthorEvgenWarGold = "" + EnumChatFormatting.RED + EnumChatFormatting.BOLD diff --git a/src/main/java/gregtech/api/enums/ItemList.java b/src/main/java/gregtech/api/enums/ItemList.java index dba8f510b9e..f995de50327 100644 --- a/src/main/java/gregtech/api/enums/ItemList.java +++ b/src/main/java/gregtech/api/enums/ItemList.java @@ -1476,6 +1476,10 @@ public enum ItemList implements IItemContainer { Electromagnet_Tengam, Machine_Multi_Canner, + Machine_Multi_Solidifier, + + Casing_Fluid_Solidifier, + Radiator_Fluid_Solidifier, Machine_Multi_IndustrialCompressor, Machine_Multi_HIPCompressor, diff --git a/src/main/java/gregtech/api/enums/MetaTileEntityIDs.java b/src/main/java/gregtech/api/enums/MetaTileEntityIDs.java index 7dc79d44ca3..12ecb96155e 100644 --- a/src/main/java/gregtech/api/enums/MetaTileEntityIDs.java +++ b/src/main/java/gregtech/api/enums/MetaTileEntityIDs.java @@ -335,6 +335,7 @@ public enum MetaTileEntityIDs { CENTRIFUGE_HV(363), CENTRIFUGE_EV(364), CENTRIFUGE_IV(365), + MULTI_SOLIDIFIER_CONTROLLER(366), ELECTROLYSER_LV(371), ELECTROLYSER_MV(372), ELECTROLYSER_HV(373), diff --git a/src/main/java/gregtech/api/enums/Textures.java b/src/main/java/gregtech/api/enums/Textures.java index 9b621059aa2..bd90cfe8aba 100644 --- a/src/main/java/gregtech/api/enums/Textures.java +++ b/src/main/java/gregtech/api/enums/Textures.java @@ -331,6 +331,9 @@ public enum BlockIcons implements IIconContainer, Runnable { OVERLAY_FRONT_EMS_GLOW, MACHINE_CASING_EMS, + MACHINE_CASING_MS160, + RADIATOR_MS160, + OVERLAY_FRONT_MULTI_CANNER, OVERLAY_FRONT_MULTI_CANNER_ACTIVE, OVERLAY_FRONT_MULTI_CANNER_ACTIVE_GLOW, diff --git a/src/main/java/gregtech/common/blocks/BlockCasings10.java b/src/main/java/gregtech/common/blocks/BlockCasings10.java index 11c3f81f01c..e5c2e96f32c 100644 --- a/src/main/java/gregtech/common/blocks/BlockCasings10.java +++ b/src/main/java/gregtech/common/blocks/BlockCasings10.java @@ -33,6 +33,9 @@ public BlockCasings10() { GTLanguageManager .addStringLocalization(getUnlocalizedName() + ".12.name", "Background Radiation Absorbent Casing"); + GTLanguageManager.addStringLocalization(getUnlocalizedName() + ".13.name", "Solidifier Casing"); + GTLanguageManager.addStringLocalization(getUnlocalizedName() + ".14.name", "Solidifier Radiator"); + ItemList.Casing_Electromagnetic_Separator.set(new ItemStack(this, 1, 0)); ItemList.Casing_Laser.set(new ItemStack(this, 1, 1)); ItemList.BlockQuarkContainmentCasing.set(new ItemStack(this, 1, 2)); @@ -46,6 +49,8 @@ public BlockCasings10() { ItemList.Heating_Duct_Casing.set(new ItemStack(this, 1, 10)); ItemList.Extreme_Density_Casing.set(new ItemStack(this, 1, 11)); ItemList.Background_Radiation_Casing.set(new ItemStack(this, 1, 12)); + ItemList.Casing_Fluid_Solidifier.set(new ItemStack(this, 1, 13)); + ItemList.Radiator_Fluid_Solidifier.set(new ItemStack(this, 1, 14)); } @Override @@ -70,6 +75,8 @@ public IIcon getIcon(int ordinalSide, int aMeta) { case 10 -> Textures.BlockIcons.MACHINE_CASING_PIPE_BRONZE.getIcon(); case 11 -> Textures.BlockIcons.EXTREME_DENSITY_CASING.getIcon(); case 12 -> Textures.BlockIcons.RADIATION_ABSORBENT_CASING.getIcon(); + case 13 -> Textures.BlockIcons.MACHINE_CASING_MS160.getIcon(); + case 14 -> Textures.BlockIcons.RADIATOR_MS160.getIcon(); default -> Textures.BlockIcons.MACHINE_CASING_ROBUST_TUNGSTENSTEEL.getIcon(); }; } diff --git a/src/main/java/gregtech/common/tileentities/machines/multi/MTEMultiSolidifier.java b/src/main/java/gregtech/common/tileentities/machines/multi/MTEMultiSolidifier.java new file mode 100644 index 00000000000..471815f1f97 --- /dev/null +++ b/src/main/java/gregtech/common/tileentities/machines/multi/MTEMultiSolidifier.java @@ -0,0 +1,692 @@ +package gregtech.common.tileentities.machines.multi; + +import static com.gtnewhorizon.structurelib.structure.StructureUtility.ofBlock; +import static com.gtnewhorizon.structurelib.structure.StructureUtility.ofBlocksTiered; +import static com.gtnewhorizon.structurelib.structure.StructureUtility.onElementPass; +import static com.gtnewhorizon.structurelib.structure.StructureUtility.transpose; +import static com.gtnewhorizon.structurelib.structure.StructureUtility.withChannel; +import static gregtech.api.enums.GTValues.AuthorFourIsTheNumber; +import static gregtech.api.enums.GTValues.AuthorOmdaCZ; +import static gregtech.api.enums.GTValues.authorBaps; +import static gregtech.api.enums.HatchElement.Energy; +import static gregtech.api.enums.HatchElement.InputBus; +import static gregtech.api.enums.HatchElement.InputHatch; +import static gregtech.api.enums.HatchElement.Maintenance; +import static gregtech.api.enums.HatchElement.OutputBus; +import static gregtech.api.enums.Textures.BlockIcons.OVERLAY_FRONT_MULTI_CANNER; +import static gregtech.api.enums.Textures.BlockIcons.OVERLAY_FRONT_MULTI_CANNER_ACTIVE; +import static gregtech.api.enums.Textures.BlockIcons.OVERLAY_FRONT_MULTI_CANNER_ACTIVE_GLOW; +import static gregtech.api.enums.Textures.BlockIcons.OVERLAY_FRONT_MULTI_CANNER_GLOW; +import static gregtech.api.util.GTUtility.filterValidMTEs; + +import java.util.ArrayList; +import java.util.Arrays; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +import net.minecraft.block.Block; +import net.minecraft.item.ItemStack; +import net.minecraft.nbt.NBTTagCompound; +import net.minecraft.util.EnumChatFormatting; +import net.minecraftforge.common.util.ForgeDirection; +import net.minecraftforge.fluids.FluidStack; + +import org.apache.commons.lang3.tuple.Pair; +import org.jetbrains.annotations.NotNull; + +import com.google.common.collect.ImmutableList; +import com.gtnewhorizon.structurelib.alignment.constructable.ISurvivalConstructable; +import com.gtnewhorizon.structurelib.structure.IStructureDefinition; +import com.gtnewhorizon.structurelib.structure.ISurvivalBuildEnvironment; +import com.gtnewhorizon.structurelib.structure.StructureDefinition; + +import gregtech.api.GregTechAPI; +import gregtech.api.enums.Textures; +import gregtech.api.interfaces.ITexture; +import gregtech.api.interfaces.metatileentity.IMetaTileEntity; +import gregtech.api.interfaces.tileentity.IGregTechTileEntity; +import gregtech.api.logic.ProcessingLogic; +import gregtech.api.metatileentity.GregTechTileClientEvents; +import gregtech.api.metatileentity.MetaTileEntity; +import gregtech.api.metatileentity.implementations.MTEExtendedPowerMultiBlockBase; +import gregtech.api.metatileentity.implementations.MTEHatch; +import gregtech.api.metatileentity.implementations.MTEHatchEnergy; +import gregtech.api.metatileentity.implementations.MTEHatchInput; +import gregtech.api.metatileentity.implementations.MTEHatchInputBus; +import gregtech.api.metatileentity.implementations.MTEHatchMaintenance; +import gregtech.api.metatileentity.implementations.MTEHatchMuffler; +import gregtech.api.metatileentity.implementations.MTEHatchOutput; +import gregtech.api.metatileentity.implementations.MTEHatchOutputBus; +import gregtech.api.multitileentity.multiblock.casing.Glasses; +import gregtech.api.recipe.RecipeMap; +import gregtech.api.recipe.RecipeMaps; +import gregtech.api.recipe.check.CheckRecipeResult; +import gregtech.api.recipe.check.CheckRecipeResultRegistry; +import gregtech.api.render.TextureFactory; +import gregtech.api.util.GTRecipe; +import gregtech.api.util.GTUtility; +import gregtech.api.util.HatchElementBuilder; +import gregtech.api.util.MultiblockTooltipBuilder; +import gregtech.common.blocks.BlockCasings1; +import gregtech.common.blocks.BlockCasings10; +import gregtech.common.tileentities.machines.IDualInputHatch; +import gregtech.common.tileentities.machines.IDualInputInventory; +import gregtech.common.tileentities.machines.MTEHatchCraftingInputME; +import gtPlusPlus.core.block.ModBlocks; +import gtPlusPlus.xmod.gregtech.api.metatileentity.implementations.MTEHatchSolidifier; +import mcp.mobius.waila.api.IWailaConfigHandler; +import mcp.mobius.waila.api.IWailaDataAccessor; +import tectech.thing.metaTileEntity.hatch.MTEHatchEnergyMulti; + +public class MTEMultiSolidifier extends MTEExtendedPowerMultiBlockBase + implements ISurvivalConstructable { + + protected final String MS_LEFT_MID = mName + "leftmid"; + protected final String MS_RIGHT_MID = mName + "rightmid"; + protected final String MS_END = mName + "end"; + + protected int casingAmount = 0; + protected int pipeCasingAmount = 0; + protected int Width = 0; + protected int eV = 0, mCeil = 0, mFloor = 0; + private int casingTier = -1; + private int pipeCasingTier = -1; + private int pipeMeta = -1; + private int machineTier = 0; + private static final int SOLIDIFIER_CASING_INDEX = ((BlockCasings10) GregTechAPI.sBlockCasings10) + .getTextureIndex(13); + private static final int DTPF_CASING_INDEX = ((BlockCasings1) GregTechAPI.sBlockCasings1).getTextureIndex(12); + + private final Map> tieredFluidSolidifierCasings = new HashMap<>() { + + { + // Solidifier Casing + put(13, Pair.of(GregTechAPI.sBlockCasings10, 0)); + // Laurenium Casing + put(2, Pair.of(ModBlocks.blockCustomMachineCasings, 1)); + // Dimensionally Transcendent Casing + put(12, Pair.of(GregTechAPI.sBlockCasings1, 2)); + + } + }; + + private final Map> tieredPipeCasings = new HashMap<>() { + + { + // Solidifier Radiator + put(14, Pair.of(GregTechAPI.sBlockCasings10, 0)); + // Cinobite Pipe Casing + put(13, Pair.of(ModBlocks.blockCustomPipeGearCasings, 1)); + // Abyssal Pipe Casing + put(15, Pair.of(ModBlocks.blockCustomPipeGearCasings, 2)); + + } + }; + + private final List casingIndices = new ArrayList<>( + Arrays.asList(SOLIDIFIER_CASING_INDEX, 84, DTPF_CASING_INDEX)); + + private final String STRUCTURE_PIECE_MAIN = "main"; + private final IStructureDefinition STRUCTURE_DEFINITION = StructureDefinition + .builder() + .addShape( + MS_LEFT_MID, + (transpose( + new String[][] { { " ", "BB", "BB", "BB", }, { " ", "AA", "D ", "AA", }, { " ", "AA", " ", "AA", }, + { " ", "CC", "FC", "CC", }, { " ", "BB", "BB", "BB", } }))) + .addShape( + MS_RIGHT_MID, + (transpose( + new String[][] { { " ", "BB", "BB", "BB" }, { " ", "AA", " D", "AA" }, { " ", "AA", " ", "AA" }, + { " ", "CC", "CF", "CC" }, { " ", "BB", "BB", "BB" } }))) + .addShape( + MS_END, + (transpose( + new String[][] { { "B", "B", "B", "B", "B" }, { "B", "B", "B", "B", "B" }, { "B", "B", "B", "B", "B" }, + { "B", "B", "B", "B", "B" }, { "B", "B", "B", "B", "B" } }))) + .addShape( + STRUCTURE_PIECE_MAIN, + (transpose( + new String[][] { { " ", "BBBBBBB", "BBBBBBB", "BBBBBBB", " " }, + { "BBBBBBB", " ", "D D D D", " ", "AAAAAAA" }, + { "AAAAAAA", " ", " ", " ", "AAAAAAA" }, + { "CCCBCCC", " ", "F F F F", " ", "CCCCCCC" }, + { "BBB~BBB", "BBBBBBB", "BBBBBBB", "BBBBBBB", "BBBBBBB" } }))) + .addElement('A', Glasses.chainAllGlasses()) + .addElement( + 'B', + HatchElementBuilder.builder() + .atLeast(InputBus, OutputBus, Maintenance, Energy, InputHatch) + .adder(MTEMultiSolidifier::addToSolidifierList) + .casingIndex(SOLIDIFIER_CASING_INDEX) + .dot(1) + .buildAndChain( + withChannel( + "casing", + onElementPass( + x -> x.casingAmount++, + ofBlocksTiered( + this::casingTierExtractor, + ImmutableList.of( + Pair.of(GregTechAPI.sBlockCasings10, 13), + Pair.of(ModBlocks.blockCustomMachineCasings, 2), + Pair.of(GregTechAPI.sBlockCasings1, 12)), + -1, + MTEMultiSolidifier::setCasingTier, + MTEMultiSolidifier::getCasingTier))))) + .addElement( + 'C', + onElementPass( + x -> x.pipeCasingAmount++, + ofBlocksTiered( + this::pipeTierExtractor, + ImmutableList.of( + Pair.of(GregTechAPI.sBlockCasings10, 14), + Pair.of(ModBlocks.blockCustomPipeGearCasings, 13), + Pair.of(ModBlocks.blockCustomPipeGearCasings, 15)), + -1, + MTEMultiSolidifier::setPipeCasingTier, + MTEMultiSolidifier::getPipeCasingTier))) + .addElement('F', ofBlock(GregTechAPI.sBlockCasings1, 11)) + /* + * TinkerConstruct.isModLoaded()// maybe temporary if someone makes textures for new special decorative block + * ? ofChain(ofBlock(Block.getBlockFromName("TConstruct:SearedBlock"), 0)) + * : ofChain(ofBlock(Blocks.cauldron, 0))) + */ + .addElement('D', ofBlock(GregTechAPI.sBlockCasings4, 1)) + /* + * BuildCraftFactory.isModLoaded()// maybe temporary if someone makes textures for new special decorative block + * ? ofChain(ofBlock(Block.getBlockFromName("BuildCraft|Factory:blockHopper"), 10)) + * : ofChain(ofBlock(Blocks.hopper, 0))) + */ + .build(); + + public MTEMultiSolidifier(final int aID, final String aName, final String aNameRegional) { + super(aID, aName, aNameRegional); + } + + public MTEMultiSolidifier(String aName) { + super(aName); + } + + @Override + public IMetaTileEntity newMetaEntity(IGregTechTileEntity aTileEntity) { + return new MTEMultiSolidifier(this.mName); + } + + @Override + public boolean isCorrectMachinePart(ItemStack aStack) { + return true; + } + + @Override + public ITexture[] getTexture(IGregTechTileEntity baseMetaTileEntity, ForgeDirection side, ForgeDirection aFacing, + int colorIndex, boolean aActive, boolean redstoneLevel) { + ITexture[] rTexture; + int casingIndex = casingTier > -1 ? casingIndices.get(casingTier) : SOLIDIFIER_CASING_INDEX; + if (side == aFacing) { + if (aActive) { + rTexture = new ITexture[] { Textures.BlockIcons.getCasingTextureForId(casingIndex), + TextureFactory.builder() + .addIcon(OVERLAY_FRONT_MULTI_CANNER_ACTIVE) + .extFacing() + .build(), + TextureFactory.builder() + .addIcon(OVERLAY_FRONT_MULTI_CANNER_ACTIVE_GLOW) + .extFacing() + .glow() + .build() }; + } else { + rTexture = new ITexture[] { Textures.BlockIcons.getCasingTextureForId(casingIndex), + TextureFactory.builder() + .addIcon(OVERLAY_FRONT_MULTI_CANNER) + .extFacing() + .build(), + TextureFactory.builder() + .addIcon(OVERLAY_FRONT_MULTI_CANNER_GLOW) + .extFacing() + .glow() + .build() }; + } + } else { + rTexture = new ITexture[] { Textures.BlockIcons + .getCasingTextureForId(GTUtility.getCasingTextureIndex(GregTechAPI.sBlockCasings10, 13)) }; + } + return rTexture; + } + + @Override + protected MultiblockTooltipBuilder createTooltip() { + MultiblockTooltipBuilder tt = new MultiblockTooltipBuilder(); + tt.addMachineType("Fluid Solidifier") + .addInfo("Controller Block for the Fluid Shaper") + .addInfo("Speeds up to a maximum of 300% faster than singleblock machines while running") + .addInfo("Has 4 parallels by default") + .addInfo("Gains an additional 10 parallels per width expansion") + .addInfo(EnumChatFormatting.BLUE + "Pretty Ⱄⱁⰾⰻⰴ, isn't it") + .addInfo( + AuthorOmdaCZ + " with help of " + + AuthorFourIsTheNumber + + EnumChatFormatting.AQUA + + ", GDCloud " + + "& " + + authorBaps) + .addSeparator() + .beginVariableStructureBlock(17, 33, 5, 5, 5, 5, true) + .addController("Front Center bottom") + .addCasingInfoMin("Tier 1: Solidifier Casing", 146, true) + .addCasingInfoMin("Tier 2: Laurenium Casing", 146, true) + .addCasingInfoMin("Tier 3: DTPF Casing", 146, true) + .addCasingInfoMin("Tier 1: Radiator Casing", 18, true) + .addCasingInfoMin("Tier 2: Cinobite Pipe Casing", 18, true) + .addCasingInfoMin("Tier 3: Abyssal Alloy Pipe Casing", 18, true) + .addCasingInfoMin("Heat Proof Casing", 4, false) + .addCasingInfoMin("Solid Steel Casing", 4, false) + .addInfo("Tier limits maximal width 2; 4; 6") + .addInputBus("Any Tiered Casing", 1) + .addOutputBus("Any Tiered Casing", 1) + .addInputHatch("Any Tiered Casing", 1) + .addEnergyHatch("Any Tiered Casing", 1) + .addMaintenanceHatch("Any Tiered Casing", 1) + .toolTipFinisher("GregTech"); + return tt; + } + + @Override + public void construct(ItemStack stackSize, boolean hintsOnly) { + buildPiece(STRUCTURE_PIECE_MAIN, stackSize, hintsOnly, 3, 4, 0); + // max Width, minimal mid pieces to build on each side + int tTotalWidth = Math.min(6, stackSize.stackSize + 3); + for (int i = 1; i < tTotalWidth - 1; i++) { + // horizontal offset 3 from controller and number of pieces times width of each piece + buildPiece(MS_LEFT_MID, stackSize, hintsOnly, 3 + 2 * i, 4, 0); + // the same but on other side of controller, for some reason -2 works right but -3 is weird + buildPiece(MS_RIGHT_MID, stackSize, hintsOnly, -2 - 2 * i, 4, 0); + } + // trial and error numbers that work + buildPiece(MS_END, stackSize, hintsOnly, (tTotalWidth + 2) * 2 - 4, 4, 0); + buildPiece(MS_END, stackSize, hintsOnly, (-tTotalWidth - 2) * 2 + 4, 4, 0); + } + + protected final List> mOutputHatchesByLayer = new ArrayList<>(); + protected int mWidth; + protected int nWidth; + + @Override + public int survivalConstruct(ItemStack stackSize, int elementBudget, ISurvivalBuildEnvironment env) { + if (mMachine) return -1; + mWidth = 0; + nWidth = 0; + int built = survivialBuildPiece(STRUCTURE_PIECE_MAIN, stackSize, 3, 4, 0, elementBudget, env, false, true); + if (built >= 0) return built; + int tTotalWidth = Math.min(3 + machineTier, stackSize.stackSize + 3); + for (int i = 1; i < tTotalWidth - 1; i++) { + mWidth = i; + nWidth = i; + built = survivialBuildPiece(MS_LEFT_MID, stackSize, 3 + 2 * i, 4, 0, elementBudget, env, false, true); + if (built >= 0) return built; + built = survivialBuildPiece(MS_RIGHT_MID, stackSize, -2 - 2 * i, 4, 0, elementBudget, env, false, true); + if (built >= 0) return built; + } + if (mWidth == tTotalWidth - 2) return survivialBuildPiece( + MS_END, + stackSize, + (2 + tTotalWidth) * 2 - 4, + 4, + 0, + elementBudget, + env, + false, + true); + else return survivialBuildPiece( + MS_END, + stackSize, + (-2 - tTotalWidth) * 2 + 4, + 4, + 0, + elementBudget, + env, + false, + true); + } + + private int mCasingAmount; + + int mTier; + { + if (casingTier > pipeCasingTier) { + mTier = pipeCasingTier; + } else if (casingTier <= pipeCasingTier) { + mTier = casingTier; + } + + } + + private void onCasingAdded() { + mCasingAmount++; + } + + @Override + public IStructureDefinition getStructureDefinition() { + return STRUCTURE_DEFINITION; + } + + protected boolean mTopLayerFound; + protected int mCasing; + + protected void onCasingFound() { + mCasing++; + } + + protected void onTopLayerFound(boolean aIsCasing) { + mTopLayerFound = true; + if (aIsCasing) onCasingFound(); + } + + @Override + public boolean checkMachine(IGregTechTileEntity aBaseMetaTileEntity, ItemStack aStack) { + mWidth = 0; + casingTier = -1; + pipeCasingTier = -1; + if (checkPiece(STRUCTURE_PIECE_MAIN, 3, 4, 0)) { + while (mWidth < (6)) { + if (checkPiece(MS_RIGHT_MID, (-2 * (mWidth + 1)) - 2, 4, 0) + && checkPiece(MS_LEFT_MID, (2 * (mWidth + 1)) + 3, 4, 0)) { + mWidth++; + } else break; + } + } else return false; + if (!checkPiece(MS_END, (-2 * mWidth) - 4, 4, 0) || !checkPiece(MS_END, (mWidth * 2) + 4, 4, 0)) { + return false; + } + if (casingAmount < (100 + mWidth * 23)) { + casingAmount = 0; + return false; + } else casingAmount = 0; + machineTier = Math.min(pipeCasingTier, casingTier); + if (mWidth > (2 * (machineTier + 1))) { + return false; + } + if (casingTier > -1) { + updateHatchTextures(casingIndices.get(casingTier)); + getBaseMetaTileEntity().sendBlockEvent(GregTechTileClientEvents.CHANGE_CUSTOM_DATA, getUpdateData()); + } + return true; + + } + + @Override + protected ProcessingLogic createProcessingLogic() { + return new ProcessingLogic() { + + @NotNull + @Override + protected CheckRecipeResult validateRecipe(@NotNull GTRecipe recipe) { + setSpeedBonus(1F / speedup); + return super.validateRecipe(recipe); + } + }.setMaxParallelSupplier(this::getMaxParallelRecipes); + } + + private float speedup = 1; + + @Override + public void onPostTick(IGregTechTileEntity aBaseMetaTileEntity, long aTick) { + if (aTick % 20 == 0) { + if (this.maxProgresstime() != 0 && speedup <= 3) { + speedup += 0.2F; + } else speedup = 1; + } + super.onPostTick(aBaseMetaTileEntity, aTick); + } + + public int getMaxParallelRecipes() { + return 4 + (mWidth * 10); + } + + private void setCasingTier(int tier) { + casingTier = tier; + } + + private int getCasingTier() { + return casingTier; + } + + private void setPipeCasingTier(int tier) { + pipeCasingTier = tier; + } + + private int getPipeCasingTier() { + return pipeCasingTier; + } + + @Override + public byte getUpdateData() { + return (byte) casingTier; + } + + @Override + public void receiveClientEvent(byte aEventID, byte aValue) { + super.receiveClientEvent(aEventID, aValue); + if (aEventID == GregTechTileClientEvents.CHANGE_CUSTOM_DATA) { + casingTier = aValue; + } + } + + private int casingTierExtractor(Block block, int meta) { + if (!tieredFluidSolidifierCasings.containsKey(meta) || !(tieredFluidSolidifierCasings.get(meta) + .getLeft() == block)) { + return -1; + } + return tieredFluidSolidifierCasings.get(meta) + .getRight(); + } + + private int pipeTierExtractor(Block block, int meta) { + if (!tieredPipeCasings.containsKey(meta) || !(tieredPipeCasings.get(meta) + .getLeft() == block)) { + return -1; + } + return tieredPipeCasings.get(meta) + .getRight(); + } + + private boolean addToSolidifierList(IGregTechTileEntity aTileEntity, int aBaseCasingIndex) { + if (aTileEntity == null) { + return false; + } + IMetaTileEntity aMetaTileEntity = aTileEntity.getMetaTileEntity(); + if (aMetaTileEntity instanceof MTEHatchInput hatch) { + return mInputHatches.add(hatch); + } + if (aMetaTileEntity instanceof IDualInputHatch hatch) { + return mDualInputHatches.add(hatch); + } + if (aMetaTileEntity instanceof MTEHatchInputBus hatch) { + return mInputBusses.add(hatch); + } + if (aMetaTileEntity instanceof MTEHatchOutput hatch) { + return mOutputHatches.add(hatch); + } + if (aMetaTileEntity instanceof MTEHatchOutputBus hatch) { + return mOutputBusses.add(hatch); + } + if (aMetaTileEntity instanceof MTEHatchEnergy hatch) { + return mEnergyHatches.add(hatch); + } + if (aMetaTileEntity instanceof MTEHatchMaintenance hatch) { + return mMaintenanceHatches.add(hatch); + } + if (aMetaTileEntity instanceof MTEHatchMuffler hatch) { + return mMufflerHatches.add(hatch); + } + if (aMetaTileEntity instanceof MTEHatchEnergyMulti hatch) { + return mExoticEnergyHatches.add(hatch); + } + return false; + } + + private void updateHatchTextures(int texture) { + for (IDualInputHatch hatch : mDualInputHatches) { + if (((MetaTileEntity) hatch).isValid()) { + hatch.updateTexture(texture); + } + } + for (MTEHatch hatch : filterValidMTEs(mInputHatches)) { + hatch.updateTexture(texture); + } + for (MTEHatch hatch : filterValidMTEs(mInputBusses)) { + hatch.updateTexture(texture); + } + for (MTEHatch hatch : filterValidMTEs(mOutputHatches)) { + hatch.updateTexture(texture); + } + for (MTEHatch hatch : filterValidMTEs(mOutputBusses)) { + hatch.updateTexture(texture); + } + for (MTEHatch hatch : filterValidMTEs(mEnergyHatches)) { + hatch.updateTexture(texture); + } + for (MTEHatch hatch : filterValidMTEs(mMaintenanceHatches)) { + hatch.updateTexture(texture); + } + for (MTEHatch hatch : filterValidMTEs(mMufflerHatches)) { + hatch.updateTexture(texture); + } + for (MTEHatch hatch : filterValidMTEs(mExoticEnergyHatches)) { + hatch.updateTexture(texture); + } + } + + @Override + public RecipeMap getRecipeMap() { + return RecipeMaps.fluidSolidifierRecipes; + } + + @Override + public int getRecipeCatalystPriority() { + return -10; + } + + @Override + public void getWailaBody(ItemStack itemStack, List currentTip, IWailaDataAccessor accessor, + IWailaConfigHandler config) { + super.getWailaBody(itemStack, currentTip, accessor, config); + final NBTTagCompound tag = accessor.getNBTData(); + } + + @Override + public int getMaxEfficiency(ItemStack aStack) { + return 10000; + } + + @Override + public int getDamageToComponent(ItemStack aStack) { + return 0; + } + + @Override + public boolean explodesOnComponentBreak(ItemStack aStack) { + return false; + } + + @Override + public boolean supportsVoidProtection() { + return true; + } + + @Override + public boolean supportsBatchMode() { + return true; + } + + @NotNull + @Override + protected CheckRecipeResult doCheckRecipe() { + CheckRecipeResult result = CheckRecipeResultRegistry.NO_RECIPE; + + // Copied all of this from LPF. Surely it works fine + // check crafting input hatches first + if (supportsCraftingMEBuffer()) { + for (IDualInputHatch dualInputHatch : mDualInputHatches) { + for (var it = dualInputHatch.inventories(); it.hasNext();) { + IDualInputInventory slot = it.next(); + processingLogic.setInputItems(slot.getItemInputs()); + processingLogic.setInputFluids(slot.getFluidInputs()); + CheckRecipeResult foundResult = processingLogic.process(); + if (foundResult.wasSuccessful()) { + return foundResult; + } + if (foundResult != CheckRecipeResultRegistry.NO_RECIPE) { + // Recipe failed in interesting way, so remember that and continue searching + result = foundResult; + } + } + } + } + + // Logic for GT_MetaTileEntity_Hatch_Solidifier + for (MTEHatchInput solidifierHatch : mInputHatches) { + if (solidifierHatch instanceof MTEHatchSolidifier hatch) { + ItemStack mold = hatch.getMold(); + FluidStack fluid = solidifierHatch.getFluid(); + + if (mold != null && fluid != null) { + List inputItems = new ArrayList<>(); + inputItems.add(mold); + + processingLogic.setInputItems(inputItems.toArray(new ItemStack[0])); + processingLogic.setInputFluids(fluid); + + CheckRecipeResult foundResult = processingLogic.process(); + if (foundResult.wasSuccessful()) { + return foundResult; + } + if (foundResult != CheckRecipeResultRegistry.NO_RECIPE) { + // Recipe failed in interesting way, so remember that and continue searching + result = foundResult; + } + } + } + } + processingLogic.clear(); + processingLogic.setInputFluids(getStoredFluids()); + // Default logic + for (MTEHatchInputBus bus : mInputBusses) { + if (bus instanceof MTEHatchCraftingInputME) { + continue; + } + List inputItems = new ArrayList<>(); + for (int i = bus.getSizeInventory() - 1; i >= 0; i--) { + ItemStack stored = bus.getStackInSlot(i); + if (stored != null) { + inputItems.add(stored); + } + } + if (canUseControllerSlotForRecipe() && getControllerSlot() != null) { + inputItems.add(getControllerSlot()); + } + processingLogic.setInputItems(inputItems.toArray(new ItemStack[0])); + CheckRecipeResult foundResult = processingLogic.process(); + if (foundResult.wasSuccessful()) { + return foundResult; + } + if (foundResult != CheckRecipeResultRegistry.NO_RECIPE) { + // Recipe failed in interesting way, so remember that and continue searching + result = foundResult; + } + } + return result; + } + + @Override + public boolean isInputSeparationEnabled() { + return true; + } + + @Override + public boolean supportsSingleRecipeLocking() { + return true; + } +} diff --git a/src/main/java/gregtech/loaders/preload/LoaderMetaTileEntities.java b/src/main/java/gregtech/loaders/preload/LoaderMetaTileEntities.java index b462e065cdc..71a9750c612 100644 --- a/src/main/java/gregtech/loaders/preload/LoaderMetaTileEntities.java +++ b/src/main/java/gregtech/loaders/preload/LoaderMetaTileEntities.java @@ -1058,6 +1058,7 @@ import gregtech.common.tileentities.machines.multi.MTEMultiCanner; import gregtech.common.tileentities.machines.multi.MTEMultiFurnace; import gregtech.common.tileentities.machines.multi.MTEMultiLathe; +import gregtech.common.tileentities.machines.multi.MTEMultiSolidifier; import gregtech.common.tileentities.machines.multi.MTENanoForge; import gregtech.common.tileentities.machines.multi.MTEOilCracker; import gregtech.common.tileentities.machines.multi.MTEOilDrill1; @@ -1570,9 +1571,14 @@ private static void registerMultiblockControllers() { INDUSTRIAL_ELECTROMAGNETIC_SEPARATOR_CONTROLLER.ID, "multimachine.electromagneticseparator", "Magnetic Flux Exhibitor").getStackForm(1)); + ItemList.Machine_Multi_Canner .set(new MTEMultiCanner(MULTI_CANNER_CONTROLLER.ID, "multimachine.canner", "TurboCan Pro").getStackForm(1)); + ItemList.Machine_Multi_Solidifier.set( + new MTEMultiSolidifier(MULTI_SOLIDIFIER_CONTROLLER.ID, "multimachine.solidifier", "Fluid Shaper") + .getStackForm(1)); + ItemList.WormholeGenerator.set( new MTEWormholeGenerator( WORMHOLE_GENERATOR_CONTROLLER.ID, diff --git a/src/main/resources/assets/gregtech/textures/blocks/iconsets/MACHINE_CASING_MS160.png b/src/main/resources/assets/gregtech/textures/blocks/iconsets/MACHINE_CASING_MS160.png new file mode 100644 index 0000000000000000000000000000000000000000..06a828a66f478c01f995240eebe3f326fe0b57a4 GIT binary patch literal 616 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 literal 0 HcmV?d00001