Started some work on more filter tab information.
This commit is contained in:
parent
f9350c40f8
commit
abe549bf13
3 changed files with 175 additions and 6 deletions
|
@ -108,7 +108,7 @@ public class GuiItemStackFilter extends GuiMekanism
|
||||||
int xAxis = (mouseX - (width - xSize) / 2);
|
int xAxis = (mouseX - (width - xSize) / 2);
|
||||||
int yAxis = (mouseY - (height - ySize) / 2);
|
int yAxis = (mouseY - (height - ySize) / 2);
|
||||||
|
|
||||||
fontRenderer.drawString((isNew ? "New" : "Edit") + " ItemStack Filter", 43, 6, 0x404040);
|
fontRenderer.drawString((isNew ? "New" : "Edit") + " Item Filter", 43, 6, 0x404040);
|
||||||
fontRenderer.drawString("Status: " + status, 35, 20, 0x00CD00);
|
fontRenderer.drawString("Status: " + status, 35, 20, 0x00CD00);
|
||||||
fontRenderer.drawString("ItemStack Details:", 35, 32, 0x00CD00);
|
fontRenderer.drawString("ItemStack Details:", 35, 32, 0x00CD00);
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,11 @@
|
||||||
package mekanism.client.gui;
|
package mekanism.client.gui;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
import mekanism.api.Object3D;
|
import mekanism.api.Object3D;
|
||||||
import mekanism.client.render.MekanismRenderer;
|
import mekanism.client.render.MekanismRenderer;
|
||||||
|
@ -16,9 +21,10 @@ import mekanism.common.transporter.OreDictFilter;
|
||||||
import mekanism.common.transporter.TransporterFilter;
|
import mekanism.common.transporter.TransporterFilter;
|
||||||
import mekanism.common.util.MekanismUtils;
|
import mekanism.common.util.MekanismUtils;
|
||||||
import mekanism.common.util.MekanismUtils.ResourceType;
|
import mekanism.common.util.MekanismUtils.ResourceType;
|
||||||
import mekanism.common.util.TransporterUtils;
|
|
||||||
import net.minecraft.client.gui.GuiButton;
|
import net.minecraft.client.gui.GuiButton;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
|
import net.minecraft.item.ItemStack;
|
||||||
|
import net.minecraftforge.oredict.OreDictionary;
|
||||||
|
|
||||||
import org.lwjgl.opengl.GL11;
|
import org.lwjgl.opengl.GL11;
|
||||||
import org.lwjgl.opengl.GL12;
|
import org.lwjgl.opengl.GL12;
|
||||||
|
@ -35,6 +41,10 @@ public class GuiLogisticalSorter extends GuiMekanism
|
||||||
|
|
||||||
public int dragOffset = 0;
|
public int dragOffset = 0;
|
||||||
|
|
||||||
|
public int stackSwitch = 0;
|
||||||
|
|
||||||
|
public Map<OreDictFilter, StackData> oreDictStacks = new HashMap<OreDictFilter, StackData>();
|
||||||
|
|
||||||
public float scroll;
|
public float scroll;
|
||||||
|
|
||||||
public GuiLogisticalSorter(EntityPlayer player, TileEntityLogisticalSorter tentity)
|
public GuiLogisticalSorter(EntityPlayer player, TileEntityLogisticalSorter tentity)
|
||||||
|
@ -59,6 +69,69 @@ public class GuiLogisticalSorter extends GuiMekanism
|
||||||
return (int)((tileEntity.filters.size()*scroll) - ((4F/(float)tileEntity.filters.size()))*scroll);
|
return (int)((tileEntity.filters.size()*scroll) - ((4F/(float)tileEntity.filters.size()))*scroll);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void updateScreen()
|
||||||
|
{
|
||||||
|
super.updateScreen();
|
||||||
|
|
||||||
|
if(stackSwitch > 0)
|
||||||
|
{
|
||||||
|
stackSwitch--;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(stackSwitch == 0)
|
||||||
|
{
|
||||||
|
for(Map.Entry<OreDictFilter, StackData> entry : oreDictStacks.entrySet())
|
||||||
|
{
|
||||||
|
if(entry.getValue().iterStacks != null && entry.getValue().iterStacks.size() > 0)
|
||||||
|
{
|
||||||
|
if(entry.getValue().stackIndex == -1 || entry.getValue().stackIndex == entry.getValue().iterStacks.size()-1)
|
||||||
|
{
|
||||||
|
entry.getValue().stackIndex = 0;
|
||||||
|
}
|
||||||
|
else if(entry.getValue().stackIndex < entry.getValue().iterStacks.size()-1)
|
||||||
|
{
|
||||||
|
entry.getValue().stackIndex++;
|
||||||
|
}
|
||||||
|
|
||||||
|
entry.getValue().renderStack = entry.getValue().iterStacks.get(entry.getValue().stackIndex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
stackSwitch = 20;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
for(Map.Entry<OreDictFilter, StackData> entry : oreDictStacks.entrySet())
|
||||||
|
{
|
||||||
|
if(entry.getValue().iterStacks != null && entry.getValue().iterStacks.size() == 0)
|
||||||
|
{
|
||||||
|
entry.getValue().renderStack = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Set<OreDictFilter> filtersVisible = new HashSet<OreDictFilter>();
|
||||||
|
|
||||||
|
for(int i = 0; i < 4; i++)
|
||||||
|
{
|
||||||
|
if(tileEntity.filters.get(getFilterIndex()+i) instanceof OreDictFilter)
|
||||||
|
{
|
||||||
|
filtersVisible.add((OreDictFilter)tileEntity.filters.get(getFilterIndex()+i));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for(TransporterFilter filter : tileEntity.filters)
|
||||||
|
{
|
||||||
|
if(filter instanceof OreDictFilter && !filtersVisible.contains(filter))
|
||||||
|
{
|
||||||
|
if(oreDictStacks.containsKey(filter))
|
||||||
|
{
|
||||||
|
oreDictStacks.remove(filter);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void mouseClicked(int mouseX, int mouseY, int button)
|
public void mouseClicked(int mouseX, int mouseY, int button)
|
||||||
{
|
{
|
||||||
|
@ -190,13 +263,40 @@ public class GuiLogisticalSorter extends GuiMekanism
|
||||||
|
|
||||||
if(filter instanceof ItemStackFilter)
|
if(filter instanceof ItemStackFilter)
|
||||||
{
|
{
|
||||||
fontRenderer.drawString("ItemStack Filter", 58, yStart + 2, 0x404040);
|
ItemStackFilter itemFilter = (ItemStackFilter)filter;
|
||||||
fontRenderer.drawString("Color: " + (filter.color != null ? filter.color.getName() : "None"), 58, yStart + 11, 0x404040);
|
|
||||||
|
if(itemFilter.itemType != null)
|
||||||
|
{
|
||||||
|
GL11.glPushMatrix();
|
||||||
|
GL11.glEnable(GL11.GL_LIGHTING);
|
||||||
|
itemRenderer.renderItemAndEffectIntoGUI(fontRenderer, mc.getTextureManager(), itemFilter.itemType, 59, yStart + 3);
|
||||||
|
GL11.glDisable(GL11.GL_LIGHTING);
|
||||||
|
GL11.glPopMatrix();
|
||||||
|
}
|
||||||
|
|
||||||
|
fontRenderer.drawString("Item Filter", 78, yStart + 2, 0x404040);
|
||||||
|
fontRenderer.drawString(filter.color != null ? filter.color.getName() : "None", 78, yStart + 11, 0x404040);
|
||||||
}
|
}
|
||||||
else if(filter instanceof OreDictFilter)
|
else if(filter instanceof OreDictFilter)
|
||||||
{
|
{
|
||||||
fontRenderer.drawString("OreDict Filter", 58, yStart + 2, 0x404040);
|
OreDictFilter oreFilter = (OreDictFilter)filter;
|
||||||
fontRenderer.drawString("Color: " + (filter.color != null ? filter.color.getName() : "None"), 58, yStart + 11, 0x404040);
|
|
||||||
|
fontRenderer.drawString("OreDict Filter", 78, yStart + 2, 0x404040);
|
||||||
|
fontRenderer.drawString(filter.color != null ? filter.color.getName() : "None", 78, yStart + 11, 0x404040);
|
||||||
|
|
||||||
|
if(!oreDictStacks.containsKey(oreFilter))
|
||||||
|
{
|
||||||
|
updateStackList(oreFilter);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(oreDictStacks.get(filter).renderStack != null)
|
||||||
|
{
|
||||||
|
GL11.glPushMatrix();
|
||||||
|
GL11.glEnable(GL11.GL_LIGHTING);
|
||||||
|
itemRenderer.renderItemAndEffectIntoGUI(fontRenderer, mc.getTextureManager(), oreDictStacks.get(filter).renderStack, 59, yStart + 3);
|
||||||
|
GL11.glDisable(GL11.GL_LIGHTING);
|
||||||
|
GL11.glPopMatrix();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -295,4 +395,73 @@ public class GuiLogisticalSorter extends GuiMekanism
|
||||||
|
|
||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void updateStackList(OreDictFilter filter)
|
||||||
|
{
|
||||||
|
if(!oreDictStacks.containsKey(filter))
|
||||||
|
{
|
||||||
|
oreDictStacks.put(filter, new StackData());
|
||||||
|
}
|
||||||
|
|
||||||
|
if(oreDictStacks.get(filter).iterStacks == null)
|
||||||
|
{
|
||||||
|
oreDictStacks.get(filter).iterStacks = new ArrayList<ItemStack>();
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
oreDictStacks.get(filter).iterStacks.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
List<String> keys = new ArrayList<String>();
|
||||||
|
|
||||||
|
for(String s : OreDictionary.getOreNames())
|
||||||
|
{
|
||||||
|
if(filter.oreDictName.equals(s) || filter.oreDictName.equals("*"))
|
||||||
|
{
|
||||||
|
keys.add(s);
|
||||||
|
}
|
||||||
|
else if(filter.oreDictName.endsWith("*") && !filter.oreDictName.startsWith("*"))
|
||||||
|
{
|
||||||
|
if(s.startsWith(filter.oreDictName.substring(0, filter.oreDictName.length()-1)))
|
||||||
|
{
|
||||||
|
keys.add(s);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(filter.oreDictName.startsWith("*") && !filter.oreDictName.endsWith("*"))
|
||||||
|
{
|
||||||
|
if(s.endsWith(filter.oreDictName.substring(1)))
|
||||||
|
{
|
||||||
|
keys.add(s);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(filter.oreDictName.startsWith("*") && filter.oreDictName.endsWith("*"))
|
||||||
|
{
|
||||||
|
if(s.contains(filter.oreDictName.substring(1, filter.oreDictName.length()-1)))
|
||||||
|
{
|
||||||
|
keys.add(s);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for(String key : keys)
|
||||||
|
{
|
||||||
|
for(ItemStack stack : OreDictionary.getOres(key))
|
||||||
|
{
|
||||||
|
ItemStack toAdd = stack.copy();
|
||||||
|
|
||||||
|
if(!oreDictStacks.get(filter).iterStacks.contains(stack))
|
||||||
|
{
|
||||||
|
oreDictStacks.get(filter).iterStacks.add(stack.copy());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
oreDictStacks.get(filter).stackIndex = -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static class StackData
|
||||||
|
{
|
||||||
|
public List<ItemStack> iterStacks;
|
||||||
|
public int stackIndex;
|
||||||
|
public ItemStack renderStack;
|
||||||
|
}
|
||||||
}
|
}
|
Binary file not shown.
Before Width: | Height: | Size: 3.6 KiB After Width: | Height: | Size: 3.8 KiB |
Loading…
Reference in a new issue