mirror of
https://github.com/Creators-of-Create/Create.git
synced 2025-01-03 19:06:39 +01:00
The one in orange
- Blueprint overlay now renders a '1' for single missing items - Dough can now be created in the mixer without the need of buckets - JEI no longer shows all available machines as catalysts for sequenced assembly recipes
This commit is contained in:
parent
b5ff93cff0
commit
c6fa055d9b
12 changed files with 85 additions and 11 deletions
|
@ -3391,6 +3391,7 @@ ab602a53a5d8d057aad910dd1c5529cde2d587ab data/create/recipes/mixing/chocolate.js
|
||||||
d3bf74bb3826cf2dccaf7377b8b3e0fdaa38f1aa data/create/recipes/mixing/chocolate_melting.json
|
d3bf74bb3826cf2dccaf7377b8b3e0fdaa38f1aa data/create/recipes/mixing/chocolate_melting.json
|
||||||
0e29b4ce13750aab5a60ae54cbec8776569b35e0 data/create/recipes/mixing/chromatic_compound.json
|
0e29b4ce13750aab5a60ae54cbec8776569b35e0 data/create/recipes/mixing/chromatic_compound.json
|
||||||
d9a3dff1288d675ab812eef1eb73cb27dcc71bd2 data/create/recipes/mixing/crushed_brass.json
|
d9a3dff1288d675ab812eef1eb73cb27dcc71bd2 data/create/recipes/mixing/crushed_brass.json
|
||||||
|
ec331b1de31bbe2795aec729e931726ec4f4534f data/create/recipes/mixing/dough_by_mixing.json
|
||||||
ffba306dbb52e4d7afeaec183b92821dbc402a7c data/create/recipes/mixing/honey.json
|
ffba306dbb52e4d7afeaec183b92821dbc402a7c data/create/recipes/mixing/honey.json
|
||||||
cd9a78454bce20cf3557f5c44febae77ebd43e54 data/create/recipes/mixing/lava_from_cobble.json
|
cd9a78454bce20cf3557f5c44febae77ebd43e54 data/create/recipes/mixing/lava_from_cobble.json
|
||||||
0f89b3f2d81585591513619b8d1e8694eb874316 data/create/recipes/mixing/tea.json
|
0f89b3f2d81585591513619b8d1e8694eb874316 data/create/recipes/mixing/tea.json
|
||||||
|
|
|
@ -0,0 +1,18 @@
|
||||||
|
{
|
||||||
|
"type": "create:mixing",
|
||||||
|
"ingredients": [
|
||||||
|
{
|
||||||
|
"item": "create:wheat_flour"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"fluid": "minecraft:water",
|
||||||
|
"nbt": {},
|
||||||
|
"amount": 1000
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"results": [
|
||||||
|
{
|
||||||
|
"item": "create:dough"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
|
@ -124,10 +124,6 @@ public class CreateJEI implements IModPlugin {
|
||||||
|
|
||||||
seqAssembly = register("sequenced_assembly", SequencedAssemblyCategory::new)
|
seqAssembly = register("sequenced_assembly", SequencedAssemblyCategory::new)
|
||||||
.recipes(AllRecipeTypes.SEQUENCED_ASSEMBLY::getType)
|
.recipes(AllRecipeTypes.SEQUENCED_ASSEMBLY::getType)
|
||||||
.catalyst(AllBlocks.MECHANICAL_PRESS::get)
|
|
||||||
.catalyst(AllBlocks.MECHANICAL_SAW::get)
|
|
||||||
.catalyst(AllBlocks.DEPLOYER::get)
|
|
||||||
.catalyst(AllBlocks.SPOUT::get)
|
|
||||||
.build(),
|
.build(),
|
||||||
|
|
||||||
autoShapeless = register("automatic_shapeless", MixingCategory::autoShapeless)
|
autoShapeless = register("automatic_shapeless", MixingCategory::autoShapeless)
|
||||||
|
|
|
@ -90,6 +90,17 @@ public class SequencedAssemblyCategory extends CreateRecipeCategory<SequencedAss
|
||||||
x += subCategory.getWidth() + margin;
|
x += subCategory.getWidth() + margin;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// In case machines should be displayed as ingredients
|
||||||
|
|
||||||
|
// List<List<ItemStack>> inputs = ingredients.getInputs(VanillaTypes.ITEM);
|
||||||
|
// int catalystX = -2;
|
||||||
|
// int catalystY = 14;
|
||||||
|
// for (; index < inputs.size(); index++) {
|
||||||
|
// itemStacks.init(index, true, catalystX, catalystY);
|
||||||
|
// itemStacks.set(index, inputs.get(index));
|
||||||
|
// catalystY += 19;
|
||||||
|
// }
|
||||||
|
|
||||||
itemStacks.addTooltipCallback((slotIndex, input, ingredient, tooltip) -> {
|
itemStacks.addTooltipCallback((slotIndex, input, ingredient, tooltip) -> {
|
||||||
if (slotIndex != 1)
|
if (slotIndex != 1)
|
||||||
return;
|
return;
|
||||||
|
@ -234,7 +245,7 @@ public class SequencedAssemblyCategory extends CreateRecipeCategory<SequencedAss
|
||||||
List<Ingredient> assemblyIngredients = new ArrayList<>();
|
List<Ingredient> assemblyIngredients = new ArrayList<>();
|
||||||
assemblyIngredients.add(recipe.getIngredient());
|
assemblyIngredients.add(recipe.getIngredient());
|
||||||
assemblyIngredients.add(Ingredient.fromStacks(recipe.getTransitionalItem()));
|
assemblyIngredients.add(Ingredient.fromStacks(recipe.getTransitionalItem()));
|
||||||
recipe.addAdditionalIngredients(assemblyIngredients);
|
recipe.addAdditionalIngredientsAndMachines(assemblyIngredients);
|
||||||
return assemblyIngredients;
|
return assemblyIngredients;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
package com.simibubi.create.content.contraptions.components.deployer;
|
package com.simibubi.create.content.contraptions.components.deployer;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
import java.util.function.Supplier;
|
import java.util.function.Supplier;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
import com.simibubi.create.AllBlocks;
|
||||||
import com.simibubi.create.AllItems;
|
import com.simibubi.create.AllItems;
|
||||||
import com.simibubi.create.AllRecipeTypes;
|
import com.simibubi.create.AllRecipeTypes;
|
||||||
import com.simibubi.create.Create;
|
import com.simibubi.create.Create;
|
||||||
|
@ -17,6 +19,7 @@ import com.simibubi.create.foundation.utility.Lang;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.item.crafting.IRecipe;
|
import net.minecraft.item.crafting.IRecipe;
|
||||||
import net.minecraft.item.crafting.Ingredient;
|
import net.minecraft.item.crafting.Ingredient;
|
||||||
|
import net.minecraft.util.IItemProvider;
|
||||||
import net.minecraft.util.text.ITextComponent;
|
import net.minecraft.util.text.ITextComponent;
|
||||||
import net.minecraft.util.text.StringTextComponent;
|
import net.minecraft.util.text.StringTextComponent;
|
||||||
import net.minecraft.util.text.TranslationTextComponent;
|
import net.minecraft.util.text.TranslationTextComponent;
|
||||||
|
@ -88,6 +91,11 @@ public class DeployerApplicationRecipe extends ProcessingRecipe<RecipeWrapper> i
|
||||||
new TranslationTextComponent(matchingStacks[0].getTranslationKey()).getString());
|
new TranslationTextComponent(matchingStacks[0].getTranslationKey()).getString());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void addRequiredMachines(Set<IItemProvider> list) {
|
||||||
|
list.add(AllBlocks.DEPLOYER.get());
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Supplier<Supplier<SequencedAssemblySubCategory>> getJEISubCategory() {
|
public Supplier<Supplier<SequencedAssemblySubCategory>> getJEISubCategory() {
|
||||||
return () -> SequencedAssemblySubCategory.AssemblyDeploying::new;
|
return () -> SequencedAssemblySubCategory.AssemblyDeploying::new;
|
||||||
|
|
|
@ -1,10 +1,12 @@
|
||||||
package com.simibubi.create.content.contraptions.components.press;
|
package com.simibubi.create.content.contraptions.components.press;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
import java.util.function.Supplier;
|
import java.util.function.Supplier;
|
||||||
|
|
||||||
import javax.annotation.ParametersAreNonnullByDefault;
|
import javax.annotation.ParametersAreNonnullByDefault;
|
||||||
|
|
||||||
|
import com.simibubi.create.AllBlocks;
|
||||||
import com.simibubi.create.AllRecipeTypes;
|
import com.simibubi.create.AllRecipeTypes;
|
||||||
import com.simibubi.create.compat.jei.category.sequencedAssembly.SequencedAssemblySubCategory;
|
import com.simibubi.create.compat.jei.category.sequencedAssembly.SequencedAssemblySubCategory;
|
||||||
import com.simibubi.create.content.contraptions.itemAssembly.IAssemblyRecipe;
|
import com.simibubi.create.content.contraptions.itemAssembly.IAssemblyRecipe;
|
||||||
|
@ -13,6 +15,7 @@ import com.simibubi.create.content.contraptions.processing.ProcessingRecipeBuild
|
||||||
import com.simibubi.create.foundation.utility.Lang;
|
import com.simibubi.create.foundation.utility.Lang;
|
||||||
|
|
||||||
import net.minecraft.item.crafting.Ingredient;
|
import net.minecraft.item.crafting.Ingredient;
|
||||||
|
import net.minecraft.util.IItemProvider;
|
||||||
import net.minecraft.util.text.ITextComponent;
|
import net.minecraft.util.text.ITextComponent;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
import net.minecraftforge.api.distmarker.Dist;
|
import net.minecraftforge.api.distmarker.Dist;
|
||||||
|
@ -53,6 +56,11 @@ public class PressingRecipe extends ProcessingRecipe<RecipeWrapper> implements I
|
||||||
return Lang.translate("recipe.assembly.pressing");
|
return Lang.translate("recipe.assembly.pressing");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void addRequiredMachines(Set<IItemProvider> list) {
|
||||||
|
list.add(AllBlocks.MECHANICAL_PRESS.get());
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Supplier<Supplier<SequencedAssemblySubCategory>> getJEISubCategory() {
|
public Supplier<Supplier<SequencedAssemblySubCategory>> getJEISubCategory() {
|
||||||
return () -> SequencedAssemblySubCategory.AssemblyPressing::new;
|
return () -> SequencedAssemblySubCategory.AssemblyPressing::new;
|
||||||
|
|
|
@ -1,10 +1,12 @@
|
||||||
package com.simibubi.create.content.contraptions.components.saw;
|
package com.simibubi.create.content.contraptions.components.saw;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
import java.util.function.Supplier;
|
import java.util.function.Supplier;
|
||||||
|
|
||||||
import javax.annotation.ParametersAreNonnullByDefault;
|
import javax.annotation.ParametersAreNonnullByDefault;
|
||||||
|
|
||||||
|
import com.simibubi.create.AllBlocks;
|
||||||
import com.simibubi.create.AllRecipeTypes;
|
import com.simibubi.create.AllRecipeTypes;
|
||||||
import com.simibubi.create.compat.jei.category.sequencedAssembly.SequencedAssemblySubCategory;
|
import com.simibubi.create.compat.jei.category.sequencedAssembly.SequencedAssemblySubCategory;
|
||||||
import com.simibubi.create.content.contraptions.itemAssembly.IAssemblyRecipe;
|
import com.simibubi.create.content.contraptions.itemAssembly.IAssemblyRecipe;
|
||||||
|
@ -13,6 +15,7 @@ import com.simibubi.create.content.contraptions.processing.ProcessingRecipeBuild
|
||||||
import com.simibubi.create.foundation.utility.Lang;
|
import com.simibubi.create.foundation.utility.Lang;
|
||||||
|
|
||||||
import net.minecraft.item.crafting.Ingredient;
|
import net.minecraft.item.crafting.Ingredient;
|
||||||
|
import net.minecraft.util.IItemProvider;
|
||||||
import net.minecraft.util.text.ITextComponent;
|
import net.minecraft.util.text.ITextComponent;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
import net.minecraftforge.api.distmarker.Dist;
|
import net.minecraftforge.api.distmarker.Dist;
|
||||||
|
@ -53,6 +56,11 @@ public class CuttingRecipe extends ProcessingRecipe<RecipeWrapper> implements IA
|
||||||
return Lang.translate("recipe.assembly.cutting");
|
return Lang.translate("recipe.assembly.cutting");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void addRequiredMachines(Set<IItemProvider> list) {
|
||||||
|
list.add(AllBlocks.MECHANICAL_SAW.get());
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Supplier<Supplier<SequencedAssemblySubCategory>> getJEISubCategory() {
|
public Supplier<Supplier<SequencedAssemblySubCategory>> getJEISubCategory() {
|
||||||
return () -> SequencedAssemblySubCategory.AssemblyCutting::new;
|
return () -> SequencedAssemblySubCategory.AssemblyCutting::new;
|
||||||
|
|
|
@ -1,8 +1,10 @@
|
||||||
package com.simibubi.create.content.contraptions.fluids.actors;
|
package com.simibubi.create.content.contraptions.fluids.actors;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
import java.util.function.Supplier;
|
import java.util.function.Supplier;
|
||||||
|
|
||||||
|
import com.simibubi.create.AllBlocks;
|
||||||
import com.simibubi.create.AllRecipeTypes;
|
import com.simibubi.create.AllRecipeTypes;
|
||||||
import com.simibubi.create.compat.jei.category.sequencedAssembly.SequencedAssemblySubCategory;
|
import com.simibubi.create.compat.jei.category.sequencedAssembly.SequencedAssemblySubCategory;
|
||||||
import com.simibubi.create.content.contraptions.itemAssembly.IAssemblyRecipe;
|
import com.simibubi.create.content.contraptions.itemAssembly.IAssemblyRecipe;
|
||||||
|
@ -12,6 +14,7 @@ import com.simibubi.create.foundation.fluid.FluidIngredient;
|
||||||
import com.simibubi.create.foundation.utility.Lang;
|
import com.simibubi.create.foundation.utility.Lang;
|
||||||
|
|
||||||
import net.minecraft.item.crafting.Ingredient;
|
import net.minecraft.item.crafting.Ingredient;
|
||||||
|
import net.minecraft.util.IItemProvider;
|
||||||
import net.minecraft.util.text.ITextComponent;
|
import net.minecraft.util.text.ITextComponent;
|
||||||
import net.minecraft.util.text.StringTextComponent;
|
import net.minecraft.util.text.StringTextComponent;
|
||||||
import net.minecraft.util.text.TranslationTextComponent;
|
import net.minecraft.util.text.TranslationTextComponent;
|
||||||
|
@ -74,6 +77,11 @@ public class FillingRecipe extends ProcessingRecipe<RecipeWrapper> implements IA
|
||||||
.getTranslationKey()).getString());
|
.getTranslationKey()).getString());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void addRequiredMachines(Set<IItemProvider> list) {
|
||||||
|
list.add(AllBlocks.SPOUT.get());
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Supplier<Supplier<SequencedAssemblySubCategory>> getJEISubCategory() {
|
public Supplier<Supplier<SequencedAssemblySubCategory>> getJEISubCategory() {
|
||||||
return () -> SequencedAssemblySubCategory.AssemblySpouting::new;
|
return () -> SequencedAssemblySubCategory.AssemblySpouting::new;
|
||||||
|
|
|
@ -1,12 +1,14 @@
|
||||||
package com.simibubi.create.content.contraptions.itemAssembly;
|
package com.simibubi.create.content.contraptions.itemAssembly;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
import java.util.function.Supplier;
|
import java.util.function.Supplier;
|
||||||
|
|
||||||
import com.simibubi.create.compat.jei.category.sequencedAssembly.SequencedAssemblySubCategory;
|
import com.simibubi.create.compat.jei.category.sequencedAssembly.SequencedAssemblySubCategory;
|
||||||
import com.simibubi.create.foundation.fluid.FluidIngredient;
|
import com.simibubi.create.foundation.fluid.FluidIngredient;
|
||||||
|
|
||||||
import net.minecraft.item.crafting.Ingredient;
|
import net.minecraft.item.crafting.Ingredient;
|
||||||
|
import net.minecraft.util.IItemProvider;
|
||||||
import net.minecraft.util.text.ITextComponent;
|
import net.minecraft.util.text.ITextComponent;
|
||||||
import net.minecraftforge.api.distmarker.Dist;
|
import net.minecraftforge.api.distmarker.Dist;
|
||||||
import net.minecraftforge.api.distmarker.OnlyIn;
|
import net.minecraftforge.api.distmarker.OnlyIn;
|
||||||
|
@ -20,6 +22,8 @@ public interface IAssemblyRecipe {
|
||||||
@OnlyIn(Dist.CLIENT)
|
@OnlyIn(Dist.CLIENT)
|
||||||
public ITextComponent getDescriptionForAssembly();
|
public ITextComponent getDescriptionForAssembly();
|
||||||
|
|
||||||
|
public void addRequiredMachines(Set<IItemProvider> list);
|
||||||
|
|
||||||
public void addAssemblyIngredients(List<Ingredient> list);
|
public void addAssemblyIngredients(List<Ingredient> list);
|
||||||
|
|
||||||
default void addAssemblyFluidIngredients(List<FluidIngredient> list) {}
|
default void addAssemblyFluidIngredients(List<FluidIngredient> list) {}
|
||||||
|
|
|
@ -1,8 +1,10 @@
|
||||||
package com.simibubi.create.content.contraptions.itemAssembly;
|
package com.simibubi.create.content.contraptions.itemAssembly;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
import com.simibubi.create.AllRecipeTypes;
|
import com.simibubi.create.AllRecipeTypes;
|
||||||
import com.simibubi.create.Create;
|
import com.simibubi.create.Create;
|
||||||
|
@ -19,6 +21,7 @@ import net.minecraft.item.crafting.IRecipeSerializer;
|
||||||
import net.minecraft.item.crafting.IRecipeType;
|
import net.minecraft.item.crafting.IRecipeType;
|
||||||
import net.minecraft.item.crafting.Ingredient;
|
import net.minecraft.item.crafting.Ingredient;
|
||||||
import net.minecraft.nbt.CompoundNBT;
|
import net.minecraft.nbt.CompoundNBT;
|
||||||
|
import net.minecraft.util.IItemProvider;
|
||||||
import net.minecraft.util.ResourceLocation;
|
import net.minecraft.util.ResourceLocation;
|
||||||
import net.minecraft.util.text.ITextComponent;
|
import net.minecraft.util.text.ITextComponent;
|
||||||
import net.minecraft.util.text.StringTextComponent;
|
import net.minecraft.util.text.StringTextComponent;
|
||||||
|
@ -90,9 +93,15 @@ public class SequencedAssemblyRecipe implements IRecipe<RecipeWrapper> {
|
||||||
return loops;
|
return loops;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addAdditionalIngredients(List<Ingredient> list) {
|
public void addAdditionalIngredientsAndMachines(List<Ingredient> list) {
|
||||||
sequence.forEach(sr -> sr.getAsAssemblyRecipe()
|
sequence.forEach(sr -> sr.getAsAssemblyRecipe()
|
||||||
.addAssemblyIngredients(list));
|
.addAssemblyIngredients(list));
|
||||||
|
Set<IItemProvider> machines = new HashSet<>();
|
||||||
|
sequence.forEach(sr -> sr.getAsAssemblyRecipe()
|
||||||
|
.addRequiredMachines(machines));
|
||||||
|
machines.stream()
|
||||||
|
.map(Ingredient::fromItems)
|
||||||
|
.forEach(list::add);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addAdditionalFluidIngredients(List<FluidIngredient> list) {
|
public void addAdditionalFluidIngredients(List<FluidIngredient> list) {
|
||||||
|
|
|
@ -219,8 +219,7 @@ public class BlueprintOverlayRenderer {
|
||||||
RenderSystem.enableBlend();
|
RenderSystem.enableBlend();
|
||||||
(pair.getSecond() ? AllGuiTextures.HOTSLOT_ACTIVE : AllGuiTextures.HOTSLOT).draw(ms, x, y);
|
(pair.getSecond() ? AllGuiTextures.HOTSLOT_ACTIVE : AllGuiTextures.HOTSLOT).draw(ms, x, y);
|
||||||
ItemStack itemStack = pair.getFirst();
|
ItemStack itemStack = pair.getFirst();
|
||||||
String count = pair.getSecond() || itemStack.getCount() == 1 ? null
|
String count = pair.getSecond() ? null : TextFormatting.GOLD.toString() + itemStack.getCount();
|
||||||
: TextFormatting.GOLD.toString() + itemStack.getCount();
|
|
||||||
drawItemStack(ms, mc, x, y, itemStack, count);
|
drawItemStack(ms, mc, x, y, itemStack, count);
|
||||||
x += 21;
|
x += 21;
|
||||||
}
|
}
|
||||||
|
|
|
@ -41,6 +41,10 @@ public class MixingRecipeGen extends ProcessingRecipeGen {
|
||||||
.output(AllFluids.HONEY.get(), 1000)
|
.output(AllFluids.HONEY.get(), 1000)
|
||||||
.requiresHeat(HeatCondition.HEATED)),
|
.requiresHeat(HeatCondition.HEATED)),
|
||||||
|
|
||||||
|
DOUGH = create("dough_by_mixing", b -> b.require(AllItems.WHEAT_FLOUR.get())
|
||||||
|
.require(Fluids.WATER, 1000)
|
||||||
|
.output(AllItems.DOUGH.get(), 1)),
|
||||||
|
|
||||||
BRASS_INGOT = create("brass_ingot", b -> b.require(I.copper())
|
BRASS_INGOT = create("brass_ingot", b -> b.require(I.copper())
|
||||||
.require(I.zinc())
|
.require(I.zinc())
|
||||||
.output(AllItems.BRASS_INGOT.get(), 2)
|
.output(AllItems.BRASS_INGOT.get(), 2)
|
||||||
|
|
Loading…
Reference in a new issue