Updates to Logistical Sorter GUI

Add scroll wheel control to scrollbar.
Dim scrollbar when nothing to scroll.
Remove blank space when scrolled to end of list.
Add move filter up/down buttons to GUI (Not yet functional)
This commit is contained in:
TehStoneMan 2015-04-04 23:34:27 +11:00
parent 8d38f63f5f
commit cb9a10cdcf
4 changed files with 413 additions and 348 deletions

View file

@ -29,49 +29,81 @@ import mekanism.common.util.MekanismUtils.ResourceType;
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.minecraft.item.ItemStack;
import cpw.mods.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly;
import org.lwjgl.input.Keyboard; import org.lwjgl.input.Keyboard;
import org.lwjgl.input.Mouse;
import org.lwjgl.opengl.GL11; import org.lwjgl.opengl.GL11;
import org.lwjgl.opengl.GL12; import org.lwjgl.opengl.GL12;
@SideOnly(Side.CLIENT) import cpw.mods.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly;
@SideOnly( Side.CLIENT )
public class GuiLogisticalSorter extends GuiMekanism public class GuiLogisticalSorter extends GuiMekanism
{ {
public TileEntityLogisticalSorter tileEntity; public TileEntityLogisticalSorter tileEntity;
public boolean isDragging = false; /**
* True if the left mouse button was held down last time drawScreen was
* called.
*/
private boolean wasClicking;
public int dragOffset = 0; // Buttons
int BUTTON_NEW = 0;
public int stackSwitch = 0; /** Amount scrolled in filter list (0 = top, 1 = bottom) */
public float scroll;
/** True if the scrollbar is being dragged */
public boolean isDragging = false;
public Map<TOreDictFilter, StackData> oreDictStacks = new HashMap<TOreDictFilter, StackData>(); // Scrollbar dimensions
public Map<TModIDFilter, StackData> modIDStacks = new HashMap<TModIDFilter, StackData>(); private final int scrollX = 154;
private final int scrollY = 18;
private final int scrollW = 12;
private final int scrollH = 138;
public float scroll; // Filter dimensions
private final int filterX = 56;
private final int filterY = 18;
private final int filterW = 96;
private final int filterH = 29;
public GuiLogisticalSorter(EntityPlayer player, TileEntityLogisticalSorter tentity) public int dragOffset = 0;
public int stackSwitch = 0;
public Map< TOreDictFilter, StackData > oreDictStacks = new HashMap< TOreDictFilter, StackData >();
public Map< TModIDFilter, StackData > modIDStacks = new HashMap< TModIDFilter, StackData >();
public GuiLogisticalSorter( EntityPlayer player, TileEntityLogisticalSorter entity )
{ {
super(tentity, new ContainerNull(player, tentity)); super( entity, new ContainerNull( player, entity ) );
tileEntity = tentity; tileEntity = entity;
guiElements.add(new GuiRedstoneControl(this, tileEntity, MekanismUtils.getResource(ResourceType.GUI, "GuiLogisticalSorter.png")));
// Set size of gui
// xSize = 189;
// ySize = 166;
// Add common Mekanism gui elements
guiElements.add( new GuiRedstoneControl( this, tileEntity, MekanismUtils.getResource( ResourceType.GUI, "GuiLogisticalSorter.png" ) ) );
} }
public int getScroll() public int getScroll()
{ {
return Math.max(Math.min((int)(scroll*123), 123), 0); // Calculate thumb position along scrollbar
return Math.max( Math.min( (int)( scroll * 123 ), 123 ), 0 );
} }
// Get index to displayed filters
public int getFilterIndex() public int getFilterIndex()
{ {
if(tileEntity.filters.size() <= 4) if( needsScrollBars() )
{ {
return 0; final int scrollSize = tileEntity.filters.size() - 4;
return (int)( ( scrollSize + 0.5 ) * scroll );
} }
return 0;
return (int)((tileEntity.filters.size()*scroll) - ((4F/(float)tileEntity.filters.size()))*scroll);
} }
@Override @Override
@ -79,482 +111,513 @@ public class GuiLogisticalSorter extends GuiMekanism
{ {
super.updateScreen(); super.updateScreen();
if(stackSwitch > 0) // Decrease timer for stack display rotation
{ if( stackSwitch > 0 )
stackSwitch--; stackSwitch--;
}
if(stackSwitch == 0) // Update displayed stacks
if( stackSwitch == 0 )
{ {
for(Map.Entry<TOreDictFilter, StackData> entry : oreDictStacks.entrySet()) for( final Map.Entry< TOreDictFilter, StackData > entry : oreDictStacks.entrySet() )
{ if( entry.getValue().iterStacks != null && entry.getValue().iterStacks.size() > 0 )
if(entry.getValue().iterStacks != null && entry.getValue().iterStacks.size() > 0)
{ {
if(entry.getValue().stackIndex == -1 || entry.getValue().stackIndex == entry.getValue().iterStacks.size()-1) if( entry.getValue().stackIndex == -1 || entry.getValue().stackIndex == entry.getValue().iterStacks.size() - 1 )
{
entry.getValue().stackIndex = 0; entry.getValue().stackIndex = 0;
} else
else if(entry.getValue().stackIndex < entry.getValue().iterStacks.size()-1) if( entry.getValue().stackIndex < entry.getValue().iterStacks.size() - 1 )
{ entry.getValue().stackIndex++;
entry.getValue().stackIndex++;
}
entry.getValue().renderStack = entry.getValue().iterStacks.get(entry.getValue().stackIndex); entry.getValue().renderStack = entry.getValue().iterStacks.get( entry.getValue().stackIndex );
} }
}
for(Map.Entry<TModIDFilter, StackData> entry : modIDStacks.entrySet()) for( final Map.Entry< TModIDFilter, StackData > entry : modIDStacks.entrySet() )
{ if( entry.getValue().iterStacks != null && entry.getValue().iterStacks.size() > 0 )
if(entry.getValue().iterStacks != null && entry.getValue().iterStacks.size() > 0)
{ {
if(entry.getValue().stackIndex == -1 || entry.getValue().stackIndex == entry.getValue().iterStacks.size()-1) if( entry.getValue().stackIndex == -1 || entry.getValue().stackIndex == entry.getValue().iterStacks.size() - 1 )
{
entry.getValue().stackIndex = 0; entry.getValue().stackIndex = 0;
} else
else if(entry.getValue().stackIndex < entry.getValue().iterStacks.size()-1) if( entry.getValue().stackIndex < entry.getValue().iterStacks.size() - 1 )
{ entry.getValue().stackIndex++;
entry.getValue().stackIndex++;
}
entry.getValue().renderStack = entry.getValue().iterStacks.get(entry.getValue().stackIndex); entry.getValue().renderStack = entry.getValue().iterStacks.get( entry.getValue().stackIndex );
} }
}
stackSwitch = 20; stackSwitch = 20;
} }
else { else
for(Map.Entry<TOreDictFilter, StackData> entry : oreDictStacks.entrySet())
{
if(entry.getValue().iterStacks != null && entry.getValue().iterStacks.size() == 0)
{
entry.getValue().renderStack = null;
}
}
for(Map.Entry<TModIDFilter, StackData> entry : modIDStacks.entrySet())
{
if(entry.getValue().iterStacks != null && entry.getValue().iterStacks.size() == 0)
{
entry.getValue().renderStack = null;
}
}
}
Set<TOreDictFilter> oreDictFilters = new HashSet<TOreDictFilter>();
Set<TModIDFilter> modIDFilters = new HashSet<TModIDFilter>();
for(int i = 0; i < 4; i++)
{ {
if(tileEntity.filters.get(getFilterIndex()+i) instanceof TOreDictFilter) for( final Map.Entry< TOreDictFilter, StackData > entry : oreDictStacks.entrySet() )
{ if( entry.getValue().iterStacks != null && entry.getValue().iterStacks.size() == 0 )
oreDictFilters.add((TOreDictFilter)tileEntity.filters.get(getFilterIndex()+i)); entry.getValue().renderStack = null;
}
else if(tileEntity.filters.get(getFilterIndex()+i) instanceof TModIDFilter) for( final Map.Entry< TModIDFilter, StackData > entry : modIDStacks.entrySet() )
{ if( entry.getValue().iterStacks != null && entry.getValue().iterStacks.size() == 0 )
modIDFilters.add((TModIDFilter)tileEntity.filters.get(getFilterIndex()+i)); entry.getValue().renderStack = null;
}
} }
for(TransporterFilter filter : tileEntity.filters) final Set< TOreDictFilter > oreDictFilters = new HashSet< TOreDictFilter >();
{ final Set< TModIDFilter > modIDFilters = new HashSet< TModIDFilter >();
if(filter instanceof TOreDictFilter && !oreDictFilters.contains(filter))
for( int i = 0; i < 4; i++ )
if( tileEntity.filters.get( getFilterIndex() + i ) instanceof TOreDictFilter )
oreDictFilters.add( (TOreDictFilter)tileEntity.filters.get( getFilterIndex() + i ) );
else
if( tileEntity.filters.get( getFilterIndex() + i ) instanceof TModIDFilter )
modIDFilters.add( (TModIDFilter)tileEntity.filters.get( getFilterIndex() + i ) );
for( final TransporterFilter filter : tileEntity.filters )
if( filter instanceof TOreDictFilter && !oreDictFilters.contains( filter ) )
{ {
if(oreDictStacks.containsKey(filter)) if( oreDictStacks.containsKey( filter ) )
{ oreDictStacks.remove( filter );
oreDictStacks.remove(filter);
}
} }
else if(filter instanceof TModIDFilter && !modIDFilters.contains(filter)) else
{ if( filter instanceof TModIDFilter && !modIDFilters.contains( filter ) )
if(modIDStacks.containsKey(filter)) if( modIDStacks.containsKey( filter ) )
{ modIDStacks.remove( filter );
modIDStacks.remove(filter);
}
}
}
} }
@Override @Override
public void mouseClicked(int mouseX, int mouseY, int button) public void mouseClicked( int mouseX, int mouseY, int mouseBtn )
{ {
super.mouseClicked(mouseX, mouseY, button); super.mouseClicked( mouseX, mouseY, mouseBtn );
int xAxis = (mouseX - (width - xSize) / 2); // Get mouse position relative to gui
int yAxis = (mouseY - (height - ySize) / 2); final int xAxis = mouseX - guiLeft;
final int yAxis = mouseY - guiTop;
if(button == 0) if( mouseBtn == 0 )
{ {
if(xAxis >= 154 && xAxis <= 166 && yAxis >= getScroll()+18 && yAxis <= getScroll()+18+15) // Check for scrollbar interaction
{ if( xAxis >= 154 && xAxis <= 166 && yAxis >= getScroll() + 18 && yAxis <= getScroll() + 18 + 15 )
if(tileEntity.filters.size()>4) if( needsScrollBars() )
{ {
dragOffset = yAxis - (getScroll()+18); dragOffset = yAxis - ( getScroll() + 18 );
isDragging = true; isDragging = true;
} }
else { else
scroll = 0; scroll = 0;
}
}
for(int i = 0; i < 4; i++) // Check for filter interaction
{ for( int i = 0; i < 4; i++ )
if(tileEntity.filters.get(getFilterIndex()+i) != null) if( tileEntity.filters.get( getFilterIndex() + i ) != null )
{ {
int yStart = i*29 + 18; final int yStart = i * 29 + 18;
if(xAxis >= 56 && xAxis <= 152 && yAxis >= yStart && yAxis <= yStart+29) if( xAxis >= 56 && xAxis <= 152 && yAxis >= yStart && yAxis <= yStart + 29 )
{ {
TransporterFilter filter = tileEntity.filters.get(getFilterIndex()+i); // Check for sorting button
final int arrowX = filterX + filterW - 12;
if( getFilterIndex() + i > 0 )
if( xAxis >= arrowX && xAxis <= arrowX + 10 && yAxis >= yStart + 14 && yAxis <= yStart + 20 )
// Process up button click
return;
if( getFilterIndex() + i < tileEntity.filters.size() - 1 )
if( xAxis >= arrowX && xAxis <= arrowX + 10 && yAxis >= yStart + 21 && yAxis <= yStart + 27 )
// Process down button click
return;
if(filter instanceof TItemStackFilter) final TransporterFilter filter = tileEntity.filters.get( getFilterIndex() + i );
if( filter instanceof TItemStackFilter )
{ {
SoundHandler.playSound("gui.button.press"); SoundHandler.playSound( "gui.button.press" );
Mekanism.packetHandler.sendToServer(new LogisticalSorterGuiMessage(SorterGuiPacket.SERVER_INDEX, Coord4D.get(tileEntity), 1, getFilterIndex()+i, 0)); Mekanism.packetHandler.sendToServer( new LogisticalSorterGuiMessage( SorterGuiPacket.SERVER_INDEX, Coord4D
} .get( tileEntity ), 1, getFilterIndex() + i, 0 ) );
else if(filter instanceof TOreDictFilter)
{
SoundHandler.playSound("gui.button.press");
Mekanism.packetHandler.sendToServer(new LogisticalSorterGuiMessage(SorterGuiPacket.SERVER_INDEX, Coord4D.get(tileEntity), 2, getFilterIndex()+i, 0));
}
else if(filter instanceof TMaterialFilter)
{
SoundHandler.playSound("gui.button.press");
Mekanism.packetHandler.sendToServer(new LogisticalSorterGuiMessage(SorterGuiPacket.SERVER_INDEX, Coord4D.get(tileEntity), 3, getFilterIndex()+i, 0));
}
else if(filter instanceof TModIDFilter)
{
SoundHandler.playSound("gui.button.press");
Mekanism.packetHandler.sendToServer(new LogisticalSorterGuiMessage(SorterGuiPacket.SERVER_INDEX, Coord4D.get(tileEntity), 5, getFilterIndex()+i, 0));
} }
else
if( filter instanceof TOreDictFilter )
{
SoundHandler.playSound( "gui.button.press" );
Mekanism.packetHandler.sendToServer( new LogisticalSorterGuiMessage( SorterGuiPacket.SERVER_INDEX, Coord4D
.get( tileEntity ), 2, getFilterIndex() + i, 0 ) );
}
else
if( filter instanceof TMaterialFilter )
{
SoundHandler.playSound( "gui.button.press" );
Mekanism.packetHandler.sendToServer( new LogisticalSorterGuiMessage( SorterGuiPacket.SERVER_INDEX, Coord4D
.get( tileEntity ), 3, getFilterIndex() + i, 0 ) );
}
else
if( filter instanceof TModIDFilter )
{
SoundHandler.playSound( "gui.button.press" );
Mekanism.packetHandler.sendToServer( new LogisticalSorterGuiMessage( SorterGuiPacket.SERVER_INDEX, Coord4D
.get( tileEntity ), 5, getFilterIndex() + i, 0 ) );
}
} }
} }
// Check for auto eject button
if( xAxis >= 12 && xAxis <= 26 && yAxis >= 110 && yAxis <= 124 )
{
final ArrayList data = new ArrayList();
data.add( 1 );
Mekanism.packetHandler.sendToServer( new TileEntityMessage( Coord4D.get( tileEntity ), data ) );
SoundHandler.playSound( "gui.button.press" );
} }
if(xAxis >= 12 && xAxis <= 26 && yAxis >= 110 && yAxis <= 124) // Check for round robin button
if( xAxis >= 12 && xAxis <= 26 && yAxis >= 84 && yAxis <= 98 )
{ {
ArrayList data = new ArrayList(); final ArrayList data = new ArrayList();
data.add(1); data.add( 2 );
Mekanism.packetHandler.sendToServer(new TileEntityMessage(Coord4D.get(tileEntity), data)); Mekanism.packetHandler.sendToServer( new TileEntityMessage( Coord4D.get( tileEntity ), data ) );
SoundHandler.playSound("gui.button.press"); SoundHandler.playSound( "gui.button.press" );
}
if(xAxis >= 12 && xAxis <= 26 && yAxis >= 84 && yAxis <= 98)
{
ArrayList data = new ArrayList();
data.add(2);
Mekanism.packetHandler.sendToServer(new TileEntityMessage(Coord4D.get(tileEntity), data));
SoundHandler.playSound("gui.button.press");
} }
} }
if(Keyboard.isKeyDown(Keyboard.KEY_LSHIFT) && button == 0) if( Keyboard.isKeyDown( Keyboard.KEY_LSHIFT ) && mouseBtn == 0 )
{ mouseBtn = 2;
button = 2;
}
if(xAxis >= 13 && xAxis <= 29 && yAxis >= 137 && yAxis <= 153) // Check for default colour button
if( xAxis >= 13 && xAxis <= 29 && yAxis >= 137 && yAxis <= 153 )
{ {
ArrayList data = new ArrayList(); final ArrayList data = new ArrayList();
data.add(0); data.add( 0 );
data.add(button); data.add( mouseBtn );
Mekanism.packetHandler.sendToServer(new TileEntityMessage(Coord4D.get(tileEntity), data)); Mekanism.packetHandler.sendToServer( new TileEntityMessage( Coord4D.get( tileEntity ), data ) );
SoundHandler.playSound("mekanism:etc.Ding"); SoundHandler.playSound( "mekanism:etc.Ding" );
} }
} }
@Override @Override
protected void mouseClickMove(int mouseX, int mouseY, int button, long ticks) protected void mouseClickMove( int mouseX, int mouseY, int button, long ticks )
{ {
super.mouseClickMove(mouseX, mouseY, button, ticks); super.mouseClickMove( mouseX, mouseY, button, ticks );
int xAxis = (mouseX - (width - xSize) / 2); // Get mouse position relative to gui
int yAxis = (mouseY - (height - ySize) / 2); final int xAxis = mouseX - guiLeft;
final int yAxis = mouseY - guiTop;
if(isDragging) if( isDragging )
{ scroll = Math.min( Math.max( ( yAxis - 18 - dragOffset ) / 123F, 0 ), 1 );
scroll = Math.min(Math.max((float)(yAxis-18-dragOffset)/123F, 0), 1);
}
} }
@Override @Override
protected void mouseMovedOrUp(int mouseX, int mouseY, int type) protected void mouseMovedOrUp( int mouseX, int mouseY, int type )
{ {
super.mouseMovedOrUp(mouseX, mouseY, type); super.mouseMovedOrUp( mouseX, mouseY, type );
if(type == 0 && isDragging) if( type == 0 && isDragging )
{ {
dragOffset = 0; dragOffset = 0;
isDragging = false; isDragging = false;
} }
} }
/**
* Handles mouse input.
*/
@Override
public void handleMouseInput()
{
super.handleMouseInput();
int i = Mouse.getEventDWheel();
if( i != 0 && needsScrollBars() )
{
final int j = tileEntity.filters.size() - 4;
if( i > 0 )
i = 1;
if( i < 0 )
i = -1;
scroll = (float)( scroll - (double)i / (double)j );
if( scroll < 0.0F )
scroll = 0.0F;
if( scroll > 1.0F )
scroll = 1.0F;
}
}
@Override @Override
public void initGui() public void initGui()
{ {
super.initGui(); super.initGui();
int guiWidth = (width - xSize) / 2; // Add buttons to gui
int guiHeight = (height - ySize) / 2;
buttonList.clear(); buttonList.clear();
buttonList.add(new GuiButton(0, guiWidth + 56, guiHeight + 136, 96, 20, MekanismUtils.localize("gui.newFilter"))); buttonList.add( new GuiButton( BUTTON_NEW, guiLeft + 56, guiTop + 136, 96, 20, MekanismUtils.localize( "gui.newFilter" ) ) );
} }
@Override @Override
protected void actionPerformed(GuiButton guibutton) protected void actionPerformed( GuiButton guibutton )
{ {
super.actionPerformed(guibutton); super.actionPerformed( guibutton );
if(guibutton.id == 0) if( guibutton.id == BUTTON_NEW )
{ Mekanism.packetHandler.sendToServer( new LogisticalSorterGuiMessage( SorterGuiPacket.SERVER, Coord4D.get( tileEntity ), 4, 0, 0 ) );
Mekanism.packetHandler.sendToServer(new LogisticalSorterGuiMessage(SorterGuiPacket.SERVER, Coord4D.get(tileEntity), 4, 0, 0));
}
} }
@Override @Override
protected void drawGuiContainerForegroundLayer(int mouseX, int mouseY) protected void drawGuiContainerForegroundLayer( int mouseX, int mouseY )
{ {
int xAxis = (mouseX - (width - xSize) / 2); // Get mouse position relative to gui
int yAxis = (mouseY - (height - ySize) / 2); final int xAxis = mouseX - guiLeft;
final int yAxis = mouseY - guiTop;
fontRendererObj.drawString(tileEntity.getInventoryName(), 43, 6, 0x404040); // Write to info display
fontRendererObj.drawString( tileEntity.getInventoryName(), 43, 6, 0x404040 );
fontRendererObj.drawString(MekanismUtils.localize("gui.filters") + ":", 11, 19, 0x00CD00); fontRendererObj.drawString( MekanismUtils.localize( "gui.filters" ) + ":", 11, 19, 0x00CD00 );
fontRendererObj.drawString("T: " + tileEntity.filters.size(), 11, 28, 0x00CD00); fontRendererObj.drawString( "T: " + tileEntity.filters.size(), 11, 28, 0x00CD00 );
fontRendererObj.drawString("RR:", 12, 74, 0x00CD00); fontRendererObj.drawString( "RR:", 12, 74, 0x00CD00 );
fontRendererObj.drawString(MekanismUtils.localize("gui." + (tileEntity.roundRobin ? "on" : "off")), 27, 86, 0x00CD00); fontRendererObj.drawString( MekanismUtils.localize( "gui." + ( tileEntity.roundRobin ? "on" : "off" ) ), 27, 86, 0x00CD00 );
fontRendererObj.drawString(MekanismUtils.localize("gui.logisticalSorter.auto") + ":", 12, 100, 0x00CD00); fontRendererObj.drawString( MekanismUtils.localize( "gui.logisticalSorter.auto" ) + ":", 12, 100, 0x00CD00 );
fontRendererObj.drawString(MekanismUtils.localize("gui." + (tileEntity.autoEject ? "on" : "off")), 27, 112, 0x00CD00); fontRendererObj.drawString( MekanismUtils.localize( "gui." + ( tileEntity.autoEject ? "on" : "off" ) ), 27, 112, 0x00CD00 );
fontRendererObj.drawString(MekanismUtils.localize("gui.logisticalSorter.default") + ":", 12, 126, 0x00CD00); fontRendererObj.drawString( MekanismUtils.localize( "gui.logisticalSorter.default" ) + ":", 12, 126, 0x00CD00 );
for(int i = 0; i < 4; i++) // Draw filters
{ for( int i = 0; i < 4; i++ )
if(tileEntity.filters.get(getFilterIndex()+i) != null) if( tileEntity.filters.get( getFilterIndex() + i ) != null )
{ {
TransporterFilter filter = tileEntity.filters.get(getFilterIndex()+i); final TransporterFilter filter = tileEntity.filters.get( getFilterIndex() + i );
int yStart = i*29 + 18; final int yStart = i * filterH + filterY;
if(filter instanceof TItemStackFilter) if( filter instanceof TItemStackFilter )
{ {
TItemStackFilter itemFilter = (TItemStackFilter)filter; final TItemStackFilter itemFilter = (TItemStackFilter)filter;
if(itemFilter.itemType != null) if( itemFilter.itemType != null )
{ {
GL11.glPushMatrix(); GL11.glPushMatrix();
GL11.glEnable(GL11.GL_LIGHTING); GL11.glEnable( GL11.GL_LIGHTING );
itemRender.renderItemAndEffectIntoGUI(fontRendererObj, mc.getTextureManager(), itemFilter.itemType, 59, yStart + 3); itemRender.renderItemAndEffectIntoGUI( fontRendererObj, mc.getTextureManager(), itemFilter.itemType, 59, yStart + 3 );
GL11.glDisable(GL11.GL_LIGHTING); GL11.glDisable( GL11.GL_LIGHTING );
GL11.glPopMatrix(); GL11.glPopMatrix();
} }
fontRendererObj.drawString(MekanismUtils.localize("gui.itemFilter"), 78, yStart + 2, 0x404040); fontRendererObj.drawString( MekanismUtils.localize( "gui.itemFilter" ), 78, yStart + 2, 0x404040 );
fontRendererObj.drawString(filter.color != null ? filter.color.getName() : MekanismUtils.localize("gui.none"), 78, yStart + 11, 0x404040); fontRendererObj.drawString( filter.color != null ? filter.color.getName() : MekanismUtils.localize( "gui.none" ), 78,
yStart + 11, 0x404040 );
} }
else if(filter instanceof TOreDictFilter) else
{ if( filter instanceof TOreDictFilter )
TOreDictFilter oreFilter = (TOreDictFilter)filter;
if(!oreDictStacks.containsKey(oreFilter))
{ {
updateStackList(oreFilter); final TOreDictFilter oreFilter = (TOreDictFilter)filter;
if( !oreDictStacks.containsKey( oreFilter ) )
updateStackList( oreFilter );
if( oreDictStacks.get( filter ).renderStack != null )
try
{
GL11.glPushMatrix();
GL11.glEnable( GL11.GL_LIGHTING );
itemRender.renderItemAndEffectIntoGUI( fontRendererObj, mc.getTextureManager(),
oreDictStacks.get( filter ).renderStack, 59, yStart + 3 );
GL11.glDisable( GL11.GL_LIGHTING );
GL11.glPopMatrix();
}
catch( final Exception e )
{}
fontRendererObj.drawString( MekanismUtils.localize( "gui.oredictFilter" ), 78, yStart + 2, 0x404040 );
fontRendererObj.drawString( filter.color != null ? filter.color.getName() : MekanismUtils.localize( "gui.none" ), 78,
yStart + 11, 0x404040 );
} }
else
if( filter instanceof TMaterialFilter )
{
final TMaterialFilter itemFilter = (TMaterialFilter)filter;
if(oreDictStacks.get(filter).renderStack != null) if( itemFilter.materialItem != null )
{ {
try { GL11.glPushMatrix();
GL11.glPushMatrix(); GL11.glEnable( GL11.GL_LIGHTING );
GL11.glEnable(GL11.GL_LIGHTING); itemRender.renderItemAndEffectIntoGUI( fontRendererObj, mc.getTextureManager(), itemFilter.materialItem, 59,
itemRender.renderItemAndEffectIntoGUI(fontRendererObj, mc.getTextureManager(), oreDictStacks.get(filter).renderStack, 59, yStart + 3); yStart + 3 );
GL11.glDisable(GL11.GL_LIGHTING); GL11.glDisable( GL11.GL_LIGHTING );
GL11.glPopMatrix(); GL11.glPopMatrix();
} catch(Exception e) {} }
}
fontRendererObj.drawString(MekanismUtils.localize("gui.oredictFilter"), 78, yStart + 2, 0x404040); fontRendererObj.drawString( MekanismUtils.localize( "gui.materialFilter" ), 78, yStart + 2, 0x404040 );
fontRendererObj.drawString(filter.color != null ? filter.color.getName() : MekanismUtils.localize("gui.none"), 78, yStart + 11, 0x404040); fontRendererObj.drawString( filter.color != null ? filter.color.getName() : MekanismUtils.localize( "gui.none" ), 78,
} yStart + 11, 0x404040 );
else if(filter instanceof TMaterialFilter) }
{ else
TMaterialFilter itemFilter = (TMaterialFilter)filter; if( filter instanceof TModIDFilter )
{
final TModIDFilter modFilter = (TModIDFilter)filter;
if(itemFilter.materialItem != null) if( !modIDStacks.containsKey( modFilter ) )
{ updateStackList( modFilter );
GL11.glPushMatrix();
GL11.glEnable(GL11.GL_LIGHTING);
itemRender.renderItemAndEffectIntoGUI(fontRendererObj, mc.getTextureManager(), itemFilter.materialItem, 59, yStart + 3);
GL11.glDisable(GL11.GL_LIGHTING);
GL11.glPopMatrix();
}
fontRendererObj.drawString(MekanismUtils.localize("gui.materialFilter"), 78, yStart + 2, 0x404040); if( modIDStacks.get( filter ).renderStack != null )
fontRendererObj.drawString(filter.color != null ? filter.color.getName() : MekanismUtils.localize("gui.none"), 78, yStart + 11, 0x404040); try
} {
else if(filter instanceof TModIDFilter) GL11.glPushMatrix();
{ GL11.glEnable( GL11.GL_LIGHTING );
TModIDFilter modFilter = (TModIDFilter)filter; itemRender.renderItemAndEffectIntoGUI( fontRendererObj, mc.getTextureManager(),
modIDStacks.get( filter ).renderStack, 59, yStart + 3 );
GL11.glDisable( GL11.GL_LIGHTING );
GL11.glPopMatrix();
}
catch( final Exception e )
{}
if(!modIDStacks.containsKey(modFilter)) fontRendererObj.drawString( MekanismUtils.localize( "gui.modIDFilter" ), 78, yStart + 2, 0x404040 );
{ fontRendererObj.drawString( filter.color != null ? filter.color.getName() : MekanismUtils.localize( "gui.none" ), 78,
updateStackList(modFilter); yStart + 11, 0x404040 );
} }
if(modIDStacks.get(filter).renderStack != null) // Draw hovertext for sorting buttons
{ final int arrowX = filterX + filterW - 12;
try { if( getFilterIndex() + i > 0 )
GL11.glPushMatrix(); if( xAxis >= arrowX && xAxis <= arrowX + 10 && yAxis >= yStart + 14 && yAxis <= yStart + 20 )
GL11.glEnable(GL11.GL_LIGHTING); drawCreativeTabHoveringText( MekanismUtils.localize( "gui.moveUp" ), xAxis, yAxis );
itemRender.renderItemAndEffectIntoGUI(fontRendererObj, mc.getTextureManager(), modIDStacks.get(filter).renderStack, 59, yStart + 3); if( getFilterIndex() + i < tileEntity.filters.size() - 1 )
GL11.glDisable(GL11.GL_LIGHTING); if( xAxis >= arrowX && xAxis <= arrowX + 10 && yAxis >= yStart + 21 && yAxis <= yStart + 27 )
GL11.glPopMatrix(); drawCreativeTabHoveringText( MekanismUtils.localize( "gui.moveDown" ), xAxis, yAxis );
} catch(Exception e) {}
}
fontRendererObj.drawString(MekanismUtils.localize("gui.modIDFilter"), 78, yStart + 2, 0x404040);
fontRendererObj.drawString(filter.color != null ? filter.color.getName() : MekanismUtils.localize("gui.none"), 78, yStart + 11, 0x404040);
}
} }
}
if(tileEntity.color != null) if( tileEntity.color != null )
{ {
GL11.glPushMatrix(); GL11.glPushMatrix();
GL11.glColor4f(1, 1, 1, 1); GL11.glColor4f( 1, 1, 1, 1 );
GL11.glEnable(GL11.GL_LIGHTING); GL11.glEnable( GL11.GL_LIGHTING );
GL11.glEnable(GL12.GL_RESCALE_NORMAL); GL11.glEnable( GL12.GL_RESCALE_NORMAL );
mc.getTextureManager().bindTexture(MekanismRenderer.getBlocksTexture()); mc.getTextureManager().bindTexture( MekanismRenderer.getBlocksTexture() );
itemRender.renderIcon(13, 137, MekanismRenderer.getColorIcon(tileEntity.color), 16, 16); itemRender.renderIcon( 13, 137, MekanismRenderer.getColorIcon( tileEntity.color ), 16, 16 );
GL11.glDisable(GL11.GL_LIGHTING); GL11.glDisable( GL11.GL_LIGHTING );
GL11.glPopMatrix(); GL11.glPopMatrix();
} }
if(xAxis >= 13 && xAxis <= 29 && yAxis >= 137 && yAxis <= 153) // Draw tooltips for buttons
{ if( xAxis >= 13 && xAxis <= 29 && yAxis >= 137 && yAxis <= 153 )
if(tileEntity.color != null) if( tileEntity.color != null )
{ drawCreativeTabHoveringText( tileEntity.color.getName(), xAxis, yAxis );
drawCreativeTabHoveringText(tileEntity.color.getName(), xAxis, yAxis); else
} drawCreativeTabHoveringText( MekanismUtils.localize( "gui.none" ), xAxis, yAxis );
else {
drawCreativeTabHoveringText(MekanismUtils.localize("gui.none"), xAxis, yAxis);
}
}
if(xAxis >= 12 && xAxis <= 26 && yAxis >= 110 && yAxis <= 124) if( xAxis >= 12 && xAxis <= 26 && yAxis >= 110 && yAxis <= 124 )
{ drawCreativeTabHoveringText( MekanismUtils.localize( "gui.autoEject" ), xAxis, yAxis );
drawCreativeTabHoveringText(MekanismUtils.localize("gui.autoEject"), xAxis, yAxis);
}
if(xAxis >= 12 && xAxis <= 26 && yAxis >= 84 && yAxis <= 98) if( xAxis >= 12 && xAxis <= 26 && yAxis >= 84 && yAxis <= 98 )
{ drawCreativeTabHoveringText( MekanismUtils.localize( "gui.logisticalSorter.roundRobin" ), xAxis, yAxis );
drawCreativeTabHoveringText(MekanismUtils.localize("gui.logisticalSorter.roundRobin"), xAxis, yAxis);
}
super.drawGuiContainerForegroundLayer(mouseX, mouseY); super.drawGuiContainerForegroundLayer( mouseX, mouseY );
} }
@Override @Override
protected void drawGuiContainerBackgroundLayer(float partialTick, int mouseX, int mouseY) protected void drawGuiContainerBackgroundLayer( float partialTick, int mouseX, int mouseY )
{ {
super.drawGuiContainerBackgroundLayer(partialTick, mouseX, mouseY); super.drawGuiContainerBackgroundLayer( partialTick, mouseX, mouseY );
mc.renderEngine.bindTexture(MekanismUtils.getResource(ResourceType.GUI, "GuiLogisticalSorter.png")); // Draw main gui background
GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F); mc.renderEngine.bindTexture( MekanismUtils.getResource( ResourceType.GUI, "GuiLogisticalSorter.png" ) );
int guiWidth = (width - xSize) / 2; GL11.glColor4f( 1.0F, 1.0F, 1.0F, 1.0F );
int guiHeight = (height - ySize) / 2; drawTexturedModalRect( guiLeft, guiTop, 0, 0, xSize, ySize );
drawTexturedModalRect(guiWidth, guiHeight, 0, 0, xSize, ySize);
drawTexturedModalRect(guiWidth + 154, guiHeight + 18 + getScroll(), 232, 0, 12, 15); // Draw scrollbar
drawTexturedModalRect( guiLeft + scrollX, guiTop + scrollY + getScroll(), 232 + ( needsScrollBars() ? 0 : 12 ), 0, 12, 15 );
int xAxis = (mouseX - (width - xSize) / 2); // Get mouse position relative to gui
int yAxis = (mouseY - (height - ySize) / 2); final int xAxis = mouseX - guiLeft;
final int yAxis = mouseY - guiTop;
for(int i = 0; i < 4; i++) // Draw filter backgrounds
{ for( int i = 0; i < 4; i++ )
if(tileEntity.filters.get(getFilterIndex()+i) != null) if( tileEntity.filters.get( getFilterIndex() + i ) != null )
{ {
TransporterFilter filter = tileEntity.filters.get(getFilterIndex()+i); final TransporterFilter filter = tileEntity.filters.get( getFilterIndex() + i );
int yStart = i*29 + 18; final int yStart = i * filterH + filterY;
boolean mouseOver = xAxis >= 56 && xAxis <= 152 && yAxis >= yStart && yAxis <= yStart+29; // Flag for mouse over this filter
boolean mouseOver = xAxis >= filterX && xAxis <= filterX + filterW && yAxis >= yStart && yAxis <= yStart + filterH;
if(filter instanceof TItemStackFilter) // Change colour based on filter type
{ if( filter instanceof TItemStackFilter )
MekanismRenderer.color(EnumColor.INDIGO, 1.0F, 2.5F); MekanismRenderer.color( EnumColor.INDIGO, 1.0F, 2.5F );
} else
else if(filter instanceof TOreDictFilter) if( filter instanceof TOreDictFilter )
{ MekanismRenderer.color( EnumColor.BRIGHT_GREEN, 1.0F, 2.5F );
MekanismRenderer.color(EnumColor.BRIGHT_GREEN, 1.0F, 2.5F); else
} if( filter instanceof TMaterialFilter )
else if(filter instanceof TMaterialFilter) MekanismRenderer.color( EnumColor.PURPLE, 1.0F, 4F );
{ else
MekanismRenderer.color(EnumColor.PURPLE, 1.0F, 4F); if( filter instanceof TModIDFilter )
} MekanismRenderer.color( EnumColor.PINK, 1.0F, 2.5F );
else if(filter instanceof TModIDFilter)
{
MekanismRenderer.color(EnumColor.PINK, 1.0F, 2.5F);
}
drawTexturedModalRect(guiWidth + 56, guiHeight + yStart, mouseOver ? 0 : 96, 166, 96, 29); drawTexturedModalRect( guiLeft + filterX, guiTop + yStart, mouseOver ? 0 : filterW, 166, filterW, filterH );
MekanismRenderer.resetColor(); MekanismRenderer.resetColor();
// Draw sort buttons
final int arrowX = filterX + filterW - 12;
if( getFilterIndex() + i > 0 )
{
mouseOver = xAxis >= arrowX && xAxis <= arrowX + 10 && yAxis >= yStart + 14 && yAxis <= yStart + 20;
drawTexturedModalRect( guiLeft + arrowX, guiTop + yStart + 14, 190, mouseOver ? 143 : 115, 11, 7 );
}
if( getFilterIndex() + i < tileEntity.filters.size() - 1 )
{
mouseOver = xAxis >= arrowX && xAxis <= arrowX + 10 && yAxis >= yStart + 21 && yAxis <= yStart + 27;
drawTexturedModalRect( guiLeft + arrowX, guiTop + yStart + 21, 190, mouseOver ? 157 : 129, 11, 7 );
}
} }
}
if(xAxis >= 12 && xAxis <= 26 && yAxis >= 110 && yAxis <= 124) // Draw gui buttons
{ if( xAxis >= 12 && xAxis <= 26 && yAxis >= 110 && yAxis <= 124 )
drawTexturedModalRect(guiWidth + 12, guiHeight + 110, 176, 0, 14, 14); drawTexturedModalRect( guiLeft + 12, guiTop + 110, 176, 0, 14, 14 );
} else
else { drawTexturedModalRect( guiLeft + 12, guiTop + 110, 176, 14, 14, 14 );
drawTexturedModalRect(guiWidth + 12, guiHeight + 110, 176, 14, 14, 14);
}
if(xAxis >= 12 && xAxis <= 26 && yAxis >= 84 && yAxis <= 98) if( xAxis >= 12 && xAxis <= 26 && yAxis >= 84 && yAxis <= 98 )
{ drawTexturedModalRect( guiLeft + 12, guiTop + 84, 176 + 14, 0, 14, 14 );
drawTexturedModalRect(guiWidth + 12, guiHeight + 84, 176 + 14, 0, 14, 14); else
} drawTexturedModalRect( guiLeft + 12, guiTop + 84, 176 + 14, 14, 14, 14 );
else {
drawTexturedModalRect(guiWidth + 12, guiHeight + 84, 176 + 14, 14, 14, 14);
}
} }
private void updateStackList(TOreDictFilter filter) private void updateStackList( TOreDictFilter filter )
{ {
if(!oreDictStacks.containsKey(filter)) if( !oreDictStacks.containsKey( filter ) )
{ oreDictStacks.put( filter, new StackData() );
oreDictStacks.put(filter, new StackData());
}
oreDictStacks.get(filter).iterStacks = OreDictCache.getOreDictStacks(filter.oreDictName, false); oreDictStacks.get( filter ).iterStacks = OreDictCache.getOreDictStacks( filter.oreDictName, false );
stackSwitch = 0; stackSwitch = 0;
updateScreen(); updateScreen();
oreDictStacks.get(filter).stackIndex = -1; oreDictStacks.get( filter ).stackIndex = -1;
} }
private void updateStackList(TModIDFilter filter) private void updateStackList( TModIDFilter filter )
{ {
if(!modIDStacks.containsKey(filter)) if( !modIDStacks.containsKey( filter ) )
{ modIDStacks.put( filter, new StackData() );
modIDStacks.put(filter, new StackData());
}
modIDStacks.get(filter).iterStacks = OreDictCache.getModIDStacks(filter.modID, false); modIDStacks.get( filter ).iterStacks = OreDictCache.getModIDStacks( filter.modID, false );
stackSwitch = 0; stackSwitch = 0;
updateScreen(); updateScreen();
modIDStacks.get(filter).stackIndex = -1; modIDStacks.get( filter ).stackIndex = -1;
} }
public static class StackData public static class StackData
{ {
public List<ItemStack> iterStacks; public List< ItemStack > iterStacks;
public int stackIndex; public int stackIndex;
public ItemStack renderStack; public ItemStack renderStack;
}
/**
* returns true if there are more filters than can fit in the gui
*/
private boolean needsScrollBars()
{
return tileEntity.filters.size() > 4;
} }
} }

Binary file not shown.

Before

Width:  |  Height:  |  Size: 4.7 KiB

After

Width:  |  Height:  |  Size: 2.5 KiB

View file

@ -477,6 +477,8 @@ gui.toggleCooling=Toggle Cooling Measurements
gui.coolingMeasurements=Active cooling gui.coolingMeasurements=Active cooling
gui.redstoneOutputMode=Redstone mode gui.redstoneOutputMode=Redstone mode
gui.entityDetection=Entity Detection gui.entityDetection=Entity Detection
gui.moveUp=Move Up
gui.moveDown=Move Down
gui.reactor.injectionRate=Injection Rate gui.reactor.injectionRate=Injection Rate