mirror of
https://github.com/Creators-of-Create/Create.git
synced 2025-01-26 04:48:22 +01:00
JEI cleanup
- JEI screens render individual widgets instead of the full white background. Adresses #8
This commit is contained in:
parent
fca3b74909
commit
9bd07d4ed0
11 changed files with 119 additions and 54 deletions
|
@ -2,6 +2,7 @@ package com.simibubi.create;
|
||||||
|
|
||||||
import net.minecraft.client.Minecraft;
|
import net.minecraft.client.Minecraft;
|
||||||
import net.minecraft.client.gui.AbstractGui;
|
import net.minecraft.client.gui.AbstractGui;
|
||||||
|
import net.minecraft.client.gui.screen.Screen;
|
||||||
import net.minecraft.util.ResourceLocation;
|
import net.minecraft.util.ResourceLocation;
|
||||||
|
|
||||||
public enum ScreenResources {
|
public enum ScreenResources {
|
||||||
|
@ -62,12 +63,13 @@ public enum ScreenResources {
|
||||||
SELECTED_SLOT_INNER("index.png", 18, 172, 18, 18),
|
SELECTED_SLOT_INNER("index.png", 18, 172, 18, 18),
|
||||||
|
|
||||||
// JEI
|
// JEI
|
||||||
CRUSHING_RECIPE("recipes1.png", 177, 109),
|
JEI_SLOT("jei/widgets.png", 18, 18),
|
||||||
FAN_RECIPE("recipes1.png", 0, 128, 177, 109),
|
JEI_ARROW("jei/widgets.png", 19, 10, 42, 10),
|
||||||
BLOCKZAPPER_UPGRADE_RECIPE("recipes2.png", 144, 66),
|
JEI_LONG_ARROW("jei/widgets.png", 19, 0, 71, 10),
|
||||||
PRESSER_RECIPE("recipes2.png", 0, 108, 177, 109),
|
JEI_DOWN_ARROW("jei/widgets.png", 0, 21, 18, 14),
|
||||||
WASHING_RECIPE("recipes3.png", 177, 109),
|
JEI_LIGHT("jei/widgets.png", 0, 42, 52, 11),
|
||||||
PROCESSING_RECIPE_SLOT("recipes3.png", 177, 0, 20, 20),
|
JEI_SHADOW("jei/widgets.png", 0, 56, 52, 11),
|
||||||
|
BLOCKZAPPER_UPGRADE_RECIPE("jei/widgets.png", 0, 75, 144, 66),
|
||||||
|
|
||||||
// Widgets
|
// Widgets
|
||||||
PALETTE_BUTTON("palette_picker.png", 0, 236, 20, 20),
|
PALETTE_BUTTON("palette_picker.png", 0, 236, 20, 20),
|
||||||
|
@ -136,6 +138,8 @@ public enum ScreenResources {
|
||||||
public final ResourceLocation location;
|
public final ResourceLocation location;
|
||||||
public int width, height;
|
public int width, height;
|
||||||
public int startX, startY;
|
public int startX, startY;
|
||||||
|
static Screen renderer = new Screen(null) {
|
||||||
|
};
|
||||||
|
|
||||||
private ScreenResources(String location, int width, int height) {
|
private ScreenResources(String location, int width, int height) {
|
||||||
this(location, 0, 0, width, height);
|
this(location, 0, 0, width, height);
|
||||||
|
@ -157,9 +161,13 @@ public enum ScreenResources {
|
||||||
Minecraft.getInstance().getTextureManager().bindTexture(location);
|
Minecraft.getInstance().getTextureManager().bindTexture(location);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void draw(AbstractGui screen, int i, int j) {
|
public void draw(AbstractGui screen, int x, int y) {
|
||||||
bind();
|
bind();
|
||||||
screen.blit(i, j, startX, startY, width, height);
|
screen.blit(x, y, startX, startY, width, height);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void draw(int x, int y) {
|
||||||
|
draw(renderer, x, y);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,7 +3,6 @@ package com.simibubi.create.compat.jei;
|
||||||
import com.mojang.blaze3d.platform.GlStateManager;
|
import com.mojang.blaze3d.platform.GlStateManager;
|
||||||
import com.simibubi.create.AllItems;
|
import com.simibubi.create.AllItems;
|
||||||
import com.simibubi.create.Create;
|
import com.simibubi.create.Create;
|
||||||
import com.simibubi.create.ScreenResources;
|
|
||||||
import com.simibubi.create.foundation.gui.ScreenElementRenderer;
|
import com.simibubi.create.foundation.gui.ScreenElementRenderer;
|
||||||
import com.simibubi.create.foundation.utility.Lang;
|
import com.simibubi.create.foundation.utility.Lang;
|
||||||
|
|
||||||
|
@ -46,15 +45,9 @@ public class BlastingViaFanCategory extends ProcessingViaFanCategory<AbstractCoo
|
||||||
return Lang.translate("recipe.blastingViaFan");
|
return Lang.translate("recipe.blastingViaFan");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public IDrawable getBackground() {
|
|
||||||
return new ScreenResourceWrapper(ScreenResources.FAN_RECIPE);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void renderAttachedBlock() {
|
public void renderAttachedBlock() {
|
||||||
BlockState state = Blocks.LAVA.getDefaultState().with(FlowingFluidBlock.LEVEL, 8);
|
BlockState state = Blocks.LAVA.getDefaultState().with(FlowingFluidBlock.LEVEL, 8);
|
||||||
// This is stupid
|
|
||||||
GlStateManager.pushMatrix();
|
GlStateManager.pushMatrix();
|
||||||
GlStateManager.translated(0, 0, 200);
|
GlStateManager.translated(0, 0, 200);
|
||||||
GlStateManager.enableRescaleNormal();
|
GlStateManager.enableRescaleNormal();
|
||||||
|
|
|
@ -26,12 +26,18 @@ public class CrushingCategory implements IRecipeCategory<CrushingRecipe> {
|
||||||
private static ResourceLocation ID = new ResourceLocation(Create.ID, "crushing");
|
private static ResourceLocation ID = new ResourceLocation(Create.ID, "crushing");
|
||||||
private AnimatedCrushingWheels crushingWheels = new AnimatedCrushingWheels();
|
private AnimatedCrushingWheels crushingWheels = new AnimatedCrushingWheels();
|
||||||
private IDrawable icon;
|
private IDrawable icon;
|
||||||
|
private IDrawable background = new EmptyBackground(177, 100);
|
||||||
|
|
||||||
public CrushingCategory() {
|
public CrushingCategory() {
|
||||||
icon = new DoubleItemIcon(() -> new ItemStack(AllBlocks.CRUSHING_WHEEL.get()),
|
icon = new DoubleItemIcon(() -> new ItemStack(AllBlocks.CRUSHING_WHEEL.get()),
|
||||||
() -> new ItemStack(AllItems.FLOUR.get()));
|
() -> new ItemStack(AllItems.FLOUR.get()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public IDrawable getBackground() {
|
||||||
|
return background;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ResourceLocation getUid() {
|
public ResourceLocation getUid() {
|
||||||
return ID;
|
return ID;
|
||||||
|
@ -47,11 +53,6 @@ public class CrushingCategory implements IRecipeCategory<CrushingRecipe> {
|
||||||
return Lang.translate("recipe.crushing");
|
return Lang.translate("recipe.crushing");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public IDrawable getBackground() {
|
|
||||||
return new ScreenResourceWrapper(ScreenResources.CRUSHING_RECIPE);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public IDrawable getIcon() {
|
public IDrawable getIcon() {
|
||||||
return icon;
|
return icon;
|
||||||
|
@ -66,12 +67,14 @@ public class CrushingCategory implements IRecipeCategory<CrushingRecipe> {
|
||||||
@Override
|
@Override
|
||||||
public void setRecipe(IRecipeLayout recipeLayout, CrushingRecipe recipe, IIngredients ingredients) {
|
public void setRecipe(IRecipeLayout recipeLayout, CrushingRecipe recipe, IIngredients ingredients) {
|
||||||
IGuiItemStackGroup itemStacks = recipeLayout.getItemStacks();
|
IGuiItemStackGroup itemStacks = recipeLayout.getItemStacks();
|
||||||
itemStacks.init(0, true, 60, 2);
|
itemStacks.init(0, true, 50, 2);
|
||||||
itemStacks.set(0, Arrays.asList(recipe.getIngredients().get(0).getMatchingStacks()));
|
itemStacks.set(0, Arrays.asList(recipe.getIngredients().get(0).getMatchingStacks()));
|
||||||
|
|
||||||
List<StochasticOutput> results = recipe.getRollableResults();
|
List<StochasticOutput> results = recipe.getRollableResults();
|
||||||
for (int outputIndex = 0; outputIndex < results.size(); outputIndex++) {
|
int size = results.size();
|
||||||
itemStacks.init(outputIndex + 1, false, 60 + 18 * outputIndex, 78);
|
int offset = -size * 19 / 2;
|
||||||
|
for (int outputIndex = 0; outputIndex < size; outputIndex++) {
|
||||||
|
itemStacks.init(outputIndex + 1, false, getBackground().getWidth() / 2 + offset + 19 * outputIndex, 78);
|
||||||
itemStacks.set(outputIndex + 1, results.get(outputIndex).getStack());
|
itemStacks.set(outputIndex + 1, results.get(outputIndex).getStack());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -87,7 +90,16 @@ public class CrushingCategory implements IRecipeCategory<CrushingRecipe> {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void draw(CrushingRecipe recipe, double mouseX, double mouseY) {
|
public void draw(CrushingRecipe recipe, double mouseX, double mouseY) {
|
||||||
crushingWheels.draw(100, 47);
|
List<StochasticOutput> results = recipe.getRollableResults();
|
||||||
|
ScreenResources.JEI_SLOT.draw(50, 2);
|
||||||
|
ScreenResources.JEI_DOWN_ARROW.draw(72, 7);
|
||||||
|
|
||||||
|
int size = results.size();
|
||||||
|
int offset = -size * 19 / 2;
|
||||||
|
for (int outputIndex = 0; outputIndex < results.size(); outputIndex++)
|
||||||
|
ScreenResources.JEI_SLOT.draw(getBackground().getWidth() / 2 + offset + 19 * outputIndex, 78);
|
||||||
|
|
||||||
|
crushingWheels.draw(92, 49);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,29 @@
|
||||||
|
package com.simibubi.create.compat.jei;
|
||||||
|
|
||||||
|
import mezz.jei.api.gui.drawable.IDrawable;
|
||||||
|
|
||||||
|
public class EmptyBackground implements IDrawable {
|
||||||
|
|
||||||
|
private int width;
|
||||||
|
private int height;
|
||||||
|
|
||||||
|
public EmptyBackground(int width, int height) {
|
||||||
|
this.width = width;
|
||||||
|
this.height = height;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getWidth() {
|
||||||
|
return width;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getHeight() {
|
||||||
|
return height;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void draw(int xOffset, int yOffset) {
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -25,6 +25,7 @@ public class PressingCategory implements IRecipeCategory<PressingRecipe> {
|
||||||
private AnimatedPress press;
|
private AnimatedPress press;
|
||||||
private static ResourceLocation ID = new ResourceLocation(Create.ID, "pressing");
|
private static ResourceLocation ID = new ResourceLocation(Create.ID, "pressing");
|
||||||
private IDrawable icon;
|
private IDrawable icon;
|
||||||
|
private IDrawable background = new EmptyBackground(177, 70);
|
||||||
|
|
||||||
public PressingCategory() {
|
public PressingCategory() {
|
||||||
icon = new DoubleItemIcon(() -> new ItemStack(AllBlocks.MECHANICAL_PRESS.get()),
|
icon = new DoubleItemIcon(() -> new ItemStack(AllBlocks.MECHANICAL_PRESS.get()),
|
||||||
|
@ -54,7 +55,7 @@ public class PressingCategory implements IRecipeCategory<PressingRecipe> {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public IDrawable getBackground() {
|
public IDrawable getBackground() {
|
||||||
return new ScreenResourceWrapper(ScreenResources.PRESSER_RECIPE);
|
return background;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -66,20 +67,24 @@ public class PressingCategory implements IRecipeCategory<PressingRecipe> {
|
||||||
@Override
|
@Override
|
||||||
public void setRecipe(IRecipeLayout recipeLayout, PressingRecipe recipe, IIngredients ingredients) {
|
public void setRecipe(IRecipeLayout recipeLayout, PressingRecipe recipe, IIngredients ingredients) {
|
||||||
IGuiItemStackGroup itemStacks = recipeLayout.getItemStacks();
|
IGuiItemStackGroup itemStacks = recipeLayout.getItemStacks();
|
||||||
itemStacks.init(0, true, 27, 60);
|
itemStacks.init(0, true, 26, 50);
|
||||||
itemStacks.set(0, Arrays.asList(recipe.getIngredients().get(0).getMatchingStacks()));
|
itemStacks.set(0, Arrays.asList(recipe.getIngredients().get(0).getMatchingStacks()));
|
||||||
|
|
||||||
List<StochasticOutput> results = recipe.getRollableResults();
|
List<StochasticOutput> results = recipe.getRollableResults();
|
||||||
for (int outputIndex = 0; outputIndex < results.size(); outputIndex++) {
|
for (int outputIndex = 0; outputIndex < results.size(); outputIndex++) {
|
||||||
itemStacks.init(outputIndex + 1, false, 113 + 19 * outputIndex, 60);
|
itemStacks.init(outputIndex + 1, false, 131 + 19 * outputIndex, 50);
|
||||||
itemStacks.set(outputIndex + 1, results.get(outputIndex).getStack());
|
itemStacks.set(outputIndex + 1, results.get(outputIndex).getStack());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void draw(PressingRecipe recipe, double mouseX, double mouseY) {
|
public void draw(PressingRecipe recipe, double mouseX, double mouseY) {
|
||||||
press.draw(ScreenResources.PRESSER_RECIPE.width / 2, 30);
|
ScreenResources.JEI_SLOT.draw(26, 50);
|
||||||
|
ScreenResources.JEI_SLOT.draw(131, 50);
|
||||||
|
if (recipe.getRollableResults().size() > 1)
|
||||||
|
ScreenResources.JEI_SLOT.draw(131 + 19, 50);
|
||||||
|
ScreenResources.JEI_LONG_ARROW.draw(52, 54);
|
||||||
|
press.draw(getBackground().getWidth() / 2, 20);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,9 +20,11 @@ import net.minecraft.util.Direction;
|
||||||
|
|
||||||
public abstract class ProcessingViaFanCategory<T extends IRecipe<?>> implements IRecipeCategory<T> {
|
public abstract class ProcessingViaFanCategory<T extends IRecipe<?>> implements IRecipeCategory<T> {
|
||||||
|
|
||||||
|
private IDrawable background = new EmptyBackground(177, 70);
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public IDrawable getBackground() {
|
public IDrawable getBackground() {
|
||||||
return new ScreenResourceWrapper(ScreenResources.FAN_RECIPE);
|
return background;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -34,20 +36,30 @@ public abstract class ProcessingViaFanCategory<T extends IRecipe<?>> implements
|
||||||
@Override
|
@Override
|
||||||
public void setRecipe(IRecipeLayout recipeLayout, T recipe, IIngredients ingredients) {
|
public void setRecipe(IRecipeLayout recipeLayout, T recipe, IIngredients ingredients) {
|
||||||
IGuiItemStackGroup itemStacks = recipeLayout.getItemStacks();
|
IGuiItemStackGroup itemStacks = recipeLayout.getItemStacks();
|
||||||
itemStacks.init(0, true, 20, 67);
|
itemStacks.init(0, true, 20, 47);
|
||||||
itemStacks.set(0, Arrays.asList(recipe.getIngredients().get(0).getMatchingStacks()));
|
itemStacks.set(0, Arrays.asList(recipe.getIngredients().get(0).getMatchingStacks()));
|
||||||
|
|
||||||
itemStacks.init(1, false, 139, 67);
|
itemStacks.init(1, false, 139, 47);
|
||||||
itemStacks.set(1, recipe.getRecipeOutput());
|
itemStacks.set(1, recipe.getRecipeOutput());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void renderWidgets(T recipe, double mouseX, double mouseY) {
|
||||||
|
ScreenResources.JEI_SLOT.draw(20, 47);
|
||||||
|
ScreenResources.JEI_SLOT.draw(139, 47);
|
||||||
|
ScreenResources.JEI_SHADOW.draw(47, 29);
|
||||||
|
ScreenResources.JEI_LIGHT.draw(66, 39);
|
||||||
|
ScreenResources.JEI_LONG_ARROW.draw(53, 51);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void draw(T recipe, double mouseX, double mouseY) {
|
public void draw(T recipe, double mouseX, double mouseY) {
|
||||||
|
renderWidgets(recipe, mouseX, mouseY);
|
||||||
|
|
||||||
GlStateManager.pushMatrix();
|
GlStateManager.pushMatrix();
|
||||||
GlStateManager.color3f(1, 1, 1);
|
GlStateManager.color3f(1, 1, 1);
|
||||||
GlStateManager.enableDepthTest();
|
GlStateManager.enableDepthTest();
|
||||||
|
|
||||||
GlStateManager.translated(28, 42, 0);
|
GlStateManager.translated(28, 18, 0);
|
||||||
GlStateManager.rotated(10.5, -1f, 0, 0);
|
GlStateManager.rotated(10.5, -1f, 0, 0);
|
||||||
GlStateManager.rotated(15.5, 0, 1, 0);
|
GlStateManager.rotated(15.5, 0, 1, 0);
|
||||||
GlStateManager.scaled(.6f, .6f, .6f);
|
GlStateManager.scaled(.6f, .6f, .6f);
|
||||||
|
@ -71,12 +83,10 @@ public abstract class ProcessingViaFanCategory<T extends IRecipe<?>> implements
|
||||||
}
|
}
|
||||||
|
|
||||||
protected BlockState renderFanCasing() {
|
protected BlockState renderFanCasing() {
|
||||||
|
|
||||||
return AllBlocks.ENCASED_FAN.get().getDefaultState().with(BlockStateProperties.FACING, Direction.WEST);
|
return AllBlocks.ENCASED_FAN.get().getDefaultState().with(BlockStateProperties.FACING, Direction.WEST);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected BlockState renderFanInner() {
|
protected BlockState renderFanInner() {
|
||||||
|
|
||||||
return AllBlocks.ENCASED_FAN_INNER.get().getDefaultState().with(BlockStateProperties.FACING, Direction.WEST);
|
return AllBlocks.ENCASED_FAN_INNER.get().getDefaultState().with(BlockStateProperties.FACING, Direction.WEST);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -29,14 +29,18 @@ public class SplashingCategory extends ProcessingViaFanCategory<SplashingRecipe>
|
||||||
|
|
||||||
private static ResourceLocation ID = new ResourceLocation(Create.ID, "splashing");
|
private static ResourceLocation ID = new ResourceLocation(Create.ID, "splashing");
|
||||||
private IDrawable icon;
|
private IDrawable icon;
|
||||||
private IDrawable slot;
|
private IDrawable background = new EmptyBackground(177, 70);
|
||||||
|
|
||||||
public SplashingCategory() {
|
public SplashingCategory() {
|
||||||
slot = new ScreenResourceWrapper(ScreenResources.PROCESSING_RECIPE_SLOT);
|
|
||||||
icon = new DoubleItemIcon(() -> new ItemStack(AllItems.PROPELLER.get()),
|
icon = new DoubleItemIcon(() -> new ItemStack(AllItems.PROPELLER.get()),
|
||||||
() -> new ItemStack(Items.WATER_BUCKET));
|
() -> new ItemStack(Items.WATER_BUCKET));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public IDrawable getBackground() {
|
||||||
|
return background;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public IDrawable getIcon() {
|
public IDrawable getIcon() {
|
||||||
return icon;
|
return icon;
|
||||||
|
@ -66,15 +70,16 @@ public class SplashingCategory extends ProcessingViaFanCategory<SplashingRecipe>
|
||||||
@Override
|
@Override
|
||||||
public void setRecipe(IRecipeLayout recipeLayout, SplashingRecipe recipe, IIngredients ingredients) {
|
public void setRecipe(IRecipeLayout recipeLayout, SplashingRecipe recipe, IIngredients ingredients) {
|
||||||
IGuiItemStackGroup itemStacks = recipeLayout.getItemStacks();
|
IGuiItemStackGroup itemStacks = recipeLayout.getItemStacks();
|
||||||
itemStacks.init(0, true, 20, 67);
|
itemStacks.init(0, true, 20, 47);
|
||||||
itemStacks.set(0, Arrays.asList(recipe.getIngredients().get(0).getMatchingStacks()));
|
itemStacks.set(0, Arrays.asList(recipe.getIngredients().get(0).getMatchingStacks()));
|
||||||
|
|
||||||
List<StochasticOutput> results = recipe.getRollableResults();
|
List<StochasticOutput> results = recipe.getRollableResults();
|
||||||
|
boolean single = results.size() == 1;
|
||||||
for (int outputIndex = 0; outputIndex < results.size(); outputIndex++) {
|
for (int outputIndex = 0; outputIndex < results.size(); outputIndex++) {
|
||||||
int xOffset = outputIndex % 2 == 0 ? 0 : 19;
|
int xOffset = outputIndex % 2 == 0 ? 0 : 19;
|
||||||
int yOffset = (outputIndex / 2) * -19;
|
int yOffset = (outputIndex / 2) * -19;
|
||||||
|
|
||||||
itemStacks.init(outputIndex + 1, false, 132 + xOffset, 77 + yOffset);
|
itemStacks.init(outputIndex + 1, false, single ? 139 : 133 + xOffset, 47 + yOffset);
|
||||||
itemStacks.set(outputIndex + 1, results.get(outputIndex).getStack());
|
itemStacks.set(outputIndex + 1, results.get(outputIndex).getStack());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -89,25 +94,28 @@ public class SplashingCategory extends ProcessingViaFanCategory<SplashingRecipe>
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public IDrawable getBackground() {
|
protected void renderWidgets(SplashingRecipe recipe, double mouseX, double mouseY) {
|
||||||
return new ScreenResourceWrapper(ScreenResources.WASHING_RECIPE);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void draw(SplashingRecipe recipe, double mouseX, double mouseY) {
|
|
||||||
super.draw(recipe, mouseX, mouseY);
|
|
||||||
int size = recipe.getPossibleOutputs().size();
|
int size = recipe.getPossibleOutputs().size();
|
||||||
for (int i = 4; i < size; i++) {
|
|
||||||
int xOffset = i % 2 == 0 ? 0 : 19;
|
ScreenResources.JEI_SLOT.draw(20, 47);
|
||||||
int yOffset = (i / 2) * -19;
|
ScreenResources.JEI_SHADOW.draw(47, 29);
|
||||||
slot.draw(131 + xOffset, 76 + yOffset);
|
ScreenResources.JEI_SHADOW.draw(66, 39);
|
||||||
|
ScreenResources.JEI_LONG_ARROW.draw(53, 51);
|
||||||
|
|
||||||
|
if (size > 1) {
|
||||||
|
for (int i = 0; i < size; i++) {
|
||||||
|
int xOffset = i % 2 == 0 ? 0 : 19;
|
||||||
|
int yOffset = (i / 2) * -19;
|
||||||
|
ScreenResources.JEI_SLOT.draw(133 + xOffset, 47 + yOffset);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
ScreenResources.JEI_SLOT.draw(139, 47);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void renderAttachedBlock() {
|
public void renderAttachedBlock() {
|
||||||
BlockState state = Blocks.WATER.getDefaultState().with(FlowingFluidBlock.LEVEL, 8);
|
BlockState state = Blocks.WATER.getDefaultState().with(FlowingFluidBlock.LEVEL, 8);
|
||||||
// This is stupid
|
|
||||||
GlStateManager.pushMatrix();
|
GlStateManager.pushMatrix();
|
||||||
GlStateManager.translated(0, 0, 200);
|
GlStateManager.translated(0, 0, 200);
|
||||||
|
|
||||||
|
|
BIN
src/main/resources/assets/create/textures/gui/jei/widgets.png
Normal file
BIN
src/main/resources/assets/create/textures/gui/jei/widgets.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 4.2 KiB |
Binary file not shown.
Before Width: | Height: | Size: 26 KiB |
Binary file not shown.
Before Width: | Height: | Size: 22 KiB |
Binary file not shown.
Before Width: | Height: | Size: 15 KiB |
Loading…
Reference in a new issue