made progress for science book, for

This commit is contained in:
SpaceToad 2014-08-03 11:38:35 +02:00
parent 23e841f323
commit 0e408c5538
20 changed files with 167 additions and 163 deletions

View file

@ -160,6 +160,7 @@ item.redstone_red_chipset.name=Redstone Chipset
item.redstone_iron_chipset.name=Iron Chipset item.redstone_iron_chipset.name=Iron Chipset
item.redstone_gold_chipset.name=Golden Chipset item.redstone_gold_chipset.name=Golden Chipset
item.redstone_diamond_chipset.name=Diamond Chipset item.redstone_diamond_chipset.name=Diamond Chipset
item.redstone_emerald_chipset.name=Emerald Chipset
item.redstone_pulsating_chipset.name=Pulsating Chipset item.redstone_pulsating_chipset.name=Pulsating Chipset
item.redstone_quartz_chipset.name=Quartz Chipset item.redstone_quartz_chipset.name=Quartz Chipset
item.redstone_comp_chipset.name=Redstone Comp Chipset item.redstone_comp_chipset.name=Redstone Comp Chipset
@ -248,6 +249,7 @@ tile.spring.water.name=Water Spring
tile.tankBlock.name=Tank tile.tankBlock.name=Tank
tile.energyConverter.name=Energy Converter tile.energyConverter.name=Energy Converter
tile.energyConverter.tooltip=Convert BC energy between old and new power API|Added for compatibility with other mods|while they not migrated to new power API.|Could be removed in the future. tile.energyConverter.tooltip=Convert BC energy between old and new power API|Added for compatibility with other mods|while they not migrated to new power API.|Could be removed in the future.
tile.zonePlan.name=Zone Planner
tile.architect.rotate=Rotate: On tile.architect.rotate=Rotate: On
tile.architect.norotate=Rotate: Off tile.architect.norotate=Rotate: Off

Binary file not shown.

After

(image error) Size: 1.3 KiB

Binary file not shown.

Before

(image error) Size: 1.6 KiB

After

(image error) Size: 1.6 KiB

Binary file not shown.

Before

(image error) Size: 1.6 KiB

After

(image error) Size: 1.6 KiB

Binary file not shown.

After

(image error) Size: 1.6 KiB

View file

@ -133,11 +133,19 @@ public class BuildCraftTransport extends BuildCraftMod {
@Mod.Instance("BuildCraft|Transport") @Mod.Instance("BuildCraft|Transport")
public static BuildCraftTransport instance; public static BuildCraftTransport instance;
public static BlockGenericPipe genericPipeBlock;
public static float pipeDurability; public static float pipeDurability;
public static BlockGenericPipe genericPipeBlock;
public static BlockFilteredBuffer filteredBufferBlock;
public static Item pipeWaterproof; public static Item pipeWaterproof;
public static Item pipeGate; public static Item pipeGate;
public static Item pipeWire; public static Item pipeWire;
public static Item plugItem;
public static Item robotStationItem;
public static Item pipeStructureCobblestone;
public static ItemFacade facadeItem;
public static Item pipeItemsWood; public static Item pipeItemsWood;
public static Item pipeItemsEmerald; public static Item pipeItemsEmerald;
public static Item pipeItemsStone; public static Item pipeItemsStone;
@ -168,11 +176,7 @@ public class BuildCraftTransport extends BuildCraftMod {
public static Item pipePowerIron; public static Item pipePowerIron;
public static Item pipePowerGold; public static Item pipePowerGold;
public static Item pipePowerDiamond; public static Item pipePowerDiamond;
public static ItemFacade facadeItem;
public static Item plugItem;
public static Item robotStationItem;
public static BlockFilteredBuffer filteredBufferBlock;
public static Item pipeStructureCobblestone;
public static int groupItemsTrigger; public static int groupItemsTrigger;
public static String[] facadeBlacklist; public static String[] facadeBlacklist;

View file

@ -41,11 +41,11 @@ public class GuiBuilder extends GuiAdvancedInterface {
xSize = 176; xSize = 176;
ySize = 225; ySize = 225;
slots = new AdvancedSlot[6 * 4]; resetNullSlots(6 * 4);
for (int i = 0; i < 6; ++i) { for (int i = 0; i < 6; ++i) {
for (int j = 0; j < 4; ++j) { for (int j = 0; j < 4; ++j) {
slots[i * 4 + j] = new ItemSlot(this, 179 + j * 18, 18 + i * 18); slots.set(i * 4 + j, new ItemSlot(this, 179 + j * 18, 18 + i * 18));
} }
} }
} }
@ -70,8 +70,8 @@ public class GuiBuilder extends GuiAdvancedInterface {
mc.renderEngine.bindTexture(BLUEPRINT_TEXTURE); mc.renderEngine.bindTexture(BLUEPRINT_TEXTURE);
drawTexturedModalRect(guiLeft, guiTop, 0, 0, 256, ySize); drawTexturedModalRect(guiLeft, guiTop, 0, 0, 256, ySize);
for (int s = 0; s < slots.length; ++s) { for (AdvancedSlot s : slots) {
((ItemSlot) slots[s]).stack = null; ((ItemSlot) s).stack = null;
} }
Collection<ItemStack> needs = builder.getNeededItems(); Collection<ItemStack> needs = builder.getNeededItems();
@ -80,11 +80,11 @@ public class GuiBuilder extends GuiAdvancedInterface {
int s = 0; int s = 0;
for (ItemStack stack : needs) { for (ItemStack stack : needs) {
if (s >= slots.length) { if (s >= slots.size()) {
break; break;
} }
((ItemSlot) slots[s]).stack = stack.copy(); ((ItemSlot) slots.get(s)).stack = stack.copy();
s++; s++;
} }
} }

View file

@ -8,8 +8,6 @@
*/ */
package buildcraft.builders.urbanism; package buildcraft.builders.urbanism;
import java.util.LinkedList;
import org.lwjgl.input.Mouse; import org.lwjgl.input.Mouse;
import org.lwjgl.opengl.GL11; import org.lwjgl.opengl.GL11;
@ -67,8 +65,6 @@ public class GuiUrbanist extends GuiAdvancedInterface {
this.playerInventory = playerInventory; this.playerInventory = playerInventory;
this.urbanist = urbanist; this.urbanist = urbanist;
slots = new AdvancedSlot[0];
urbanist.createUrbanistEntity(); urbanist.createUrbanistEntity();
tools [0] = new UrbanistToolBlock(); tools [0] = new UrbanistToolBlock();
@ -82,17 +78,13 @@ public class GuiUrbanist extends GuiAdvancedInterface {
tools [8] = new UrbanistTool(); tools [8] = new UrbanistTool();
tools [9] = new UrbanistTool(); tools [9] = new UrbanistTool();
LinkedList<AdvancedSlot> tmpSlots = new LinkedList<AdvancedSlot>();
for (int i = 0; i < 10; ++i) { for (int i = 0; i < 10; ++i) {
tmpSlots.add(new ToolSlot(tools [i])); slots.add(new ToolSlot(tools[i]));
} }
for (UrbanistTool t : tools) { for (UrbanistTool t : tools) {
t.createSlots(this, tmpSlots); t.createSlots(this, slots);
} }
slots = tmpSlots.toArray(new AdvancedSlot [tmpSlots.size()]);
} }
@Override @Override
@ -131,8 +123,8 @@ public class GuiUrbanist extends GuiAdvancedInterface {
drawTexturedModalRect(cornerX, cornerY, 0, 0, TOOLBAR_TEXTURE_WIDTH, TOOLBAR_TEXTURE_HEIGHT); drawTexturedModalRect(cornerX, cornerY, 0, 0, TOOLBAR_TEXTURE_WIDTH, TOOLBAR_TEXTURE_HEIGHT);
for (int i = 0; i < 10; ++i) { for (int i = 0; i < 10; ++i) {
slots [i].x = cornerX + 8 + i * 18; slots.get(i).x = cornerX + 8 + i * 18;
slots [i].y = cornerY + 8; slots.get(i).y = cornerY + 8;
} }
if (selectedTool != -1) { if (selectedTool != -1) {
@ -185,7 +177,7 @@ public class GuiUrbanist extends GuiAdvancedInterface {
return; return;
} }
int clicked = getSlotAtLocation(mouseX, mouseY); int clicked = getSlotIndexAtLocation(mouseX, mouseY);
if (clicked != -1 && clicked < 10) { if (clicked != -1 && clicked < 10) {
if (clicked != selectedTool) { if (clicked != selectedTool) {
@ -199,7 +191,7 @@ public class GuiUrbanist extends GuiAdvancedInterface {
} }
if (clicked != -1) { if (clicked != -1) {
slots [clicked].selected(); slots.get(clicked).selected();
} }
} }

View file

@ -8,7 +8,7 @@
*/ */
package buildcraft.builders.urbanism; package buildcraft.builders.urbanism;
import java.util.LinkedList; import java.util.ArrayList;
import net.minecraft.util.IIcon; import net.minecraft.util.IIcon;
import net.minecraft.util.MovingObjectPosition; import net.minecraft.util.MovingObjectPosition;
@ -49,7 +49,7 @@ class UrbanistTool {
} }
public void createSlots(GuiUrbanist gui, LinkedList<AdvancedSlot> slots) { public void createSlots(GuiUrbanist gui, ArrayList<AdvancedSlot> slots) {
} }

View file

@ -131,7 +131,7 @@ class UrbanistToolFiller extends UrbanistToolArea {
} }
@Override @Override
public void createSlots(GuiUrbanist gui, LinkedList<AdvancedSlot> slots) { public void createSlots(GuiUrbanist gui, ArrayList<AdvancedSlot> slots) {
for (int i = 0; i < 8; ++i) { for (int i = 0; i < 8; ++i) {
FillerSlot slot = new FillerSlot(gui, i); FillerSlot slot = new FillerSlot(gui, i);
fillerSlots.add(slot); fillerSlots.add(slot);

View file

@ -107,15 +107,15 @@ public class GuiZonePlan extends GuiAdvancedInterface {
cx = zonePlan.xCoord; cx = zonePlan.xCoord;
cz = zonePlan.zCoord; cz = zonePlan.zCoord;
slots = new AdvancedSlot[16]; resetNullSlots(16);
for (int i = 0; i < 4; ++i) { for (int i = 0; i < 4; ++i) {
for (int j = 0; j < 4; ++j) { for (int j = 0; j < 4; ++j) {
slots[i * 4 + j] = new AreaSlot(this, 8 + 18 * i, 138 + 18 * j, EnumColor.values()[i * 4 + j]); slots.set(i * 4 + j, new AreaSlot(this, 8 + 18 * i, 138 + 18 * j, EnumColor.values()[i * 4 + j]));
} }
} }
colorSelected = (AreaSlot) slots[0]; colorSelected = (AreaSlot) slots.get(0);
newSelection.setColor(0, 0, colorSelected.color.getDarkHex(), alpha); newSelection.setColor(0, 0, colorSelected.color.getDarkHex(), alpha);
@ -225,15 +225,7 @@ public class GuiZonePlan extends GuiAdvancedInterface {
int cornerX = (width - xSize) / 2; int cornerX = (width - xSize) / 2;
int cornerY = (height - ySize) / 2; int cornerY = (height - ySize) / 2;
int position = getSlotAtLocation(mouseX - cornerX, mouseY - cornerY); AdvancedSlot slot = getSlotAtLocation(mouseX - cornerX, mouseY - cornerY);
AdvancedSlot slot = null;
if (position < 0) {
return;
}
slot = slots[position];
if (slot instanceof AreaSlot) { if (slot instanceof AreaSlot) {
colorSelected = (AreaSlot) slot; colorSelected = (AreaSlot) slot;
@ -379,7 +371,7 @@ public class GuiZonePlan extends GuiAdvancedInterface {
} }
@Override @Override
protected ContainerZonePlan getContainer() { public ContainerZonePlan getContainer() {
return (ContainerZonePlan) super.getContainer(); return (ContainerZonePlan) super.getContainer();
} }

View file

@ -14,7 +14,7 @@ import net.minecraft.world.World;
import cpw.mods.fml.common.network.IGuiHandler; import cpw.mods.fml.common.network.IGuiHandler;
import buildcraft.core.gui.ContainerScienceBook; import buildcraft.core.gui.ContainerScienceBook;
import buildcraft.core.gui.GuiScienceBook; import buildcraft.core.science.GuiScienceBook;
public class GuiHandler implements IGuiHandler { public class GuiHandler implements IGuiHandler {

View file

@ -8,6 +8,8 @@
*/ */
package buildcraft.core.gui; package buildcraft.core.gui;
import java.util.ArrayList;
import org.lwjgl.opengl.GL11; import org.lwjgl.opengl.GL11;
import net.minecraft.client.Minecraft; import net.minecraft.client.Minecraft;
@ -20,15 +22,15 @@ import net.minecraft.util.ResourceLocation;
public abstract class GuiAdvancedInterface extends GuiBuildCraft { public abstract class GuiAdvancedInterface extends GuiBuildCraft {
public AdvancedSlot[] slots; public ArrayList<AdvancedSlot> slots = new ArrayList<AdvancedSlot>();
public GuiAdvancedInterface(BuildCraftContainer container, IInventory inventory, ResourceLocation texture) { public GuiAdvancedInterface(BuildCraftContainer container, IInventory inventory, ResourceLocation texture) {
super(container, inventory, texture); super(container, inventory, texture);
} }
public int getSlotAtLocation(int i, int j) { public int getSlotIndexAtLocation(int i, int j) {
for (int position = 0; position < slots.length; ++position) { for (int position = 0; position < slots.size(); ++position) {
AdvancedSlot s = slots[position]; AdvancedSlot s = slots.get(position);
if (s != null && i >= s.x && i <= s.x + 16 && j >= s.y && j <= s.y + 16) { if (s != null && i >= s.x && i <= s.x + 16 && j >= s.y && j <= s.y + 16) {
return position; return position;
@ -37,6 +39,16 @@ public abstract class GuiAdvancedInterface extends GuiBuildCraft {
return -1; return -1;
} }
public AdvancedSlot getSlotAtLocation(int i, int j) {
int id = getSlotIndexAtLocation(i, j);
if (id != -1) {
return slots.get(id);
} else {
return null;
}
}
protected void drawBackgroundSlots() { protected void drawBackgroundSlots() {
int cornerX = (width - xSize) / 2; int cornerX = (width - xSize) / 2;
int cornerY = (height - ySize) / 2; int cornerY = (height - ySize) / 2;
@ -65,16 +77,12 @@ public abstract class GuiAdvancedInterface extends GuiBuildCraft {
int cornerX = (width - xSize) / 2; int cornerX = (width - xSize) / 2;
int cornerY = (height - ySize) / 2; int cornerY = (height - ySize) / 2;
int position = getSlotAtLocation(mouseX - cornerX, mouseY - cornerY); AdvancedSlot slot = getSlotAtLocation(mouseX - cornerX, mouseY - cornerY);
if (position != -1) {
AdvancedSlot slot = slots[position];
if (slot != null) { if (slot != null) {
slot.drawTooltip(this, mouseX, mouseY); slot.drawTooltip(this, mouseX, mouseY);
} }
} }
}
public void drawTooltip(String caption, int mouseX, int mouseY) { public void drawTooltip(String caption, int mouseX, int mouseY) {
int cornerX = (width - xSize) / 2; int cornerX = (width - xSize) / 2;
@ -126,16 +134,18 @@ public abstract class GuiAdvancedInterface extends GuiBuildCraft {
int cornerX = (width - xSize) / 2; int cornerX = (width - xSize) / 2;
int cornerY = (height - ySize) / 2; int cornerY = (height - ySize) / 2;
int position = getSlotAtLocation(mouseX - cornerX, mouseY - cornerY); AdvancedSlot slot = getSlotAtLocation(mouseX - cornerX, mouseY - cornerY);
AdvancedSlot slot = null; if (slot != null && slot.isDefined()) {
slotClicked(slot);
if (position < 0) { }
return;
} }
if (slots[position].isDefined()) { public void resetNullSlots(int size) {
slotClicked(slots[position]); slots.clear();
for (int i = 0; i < size; ++i) {
slots.add(null);
} }
} }

View file

@ -537,7 +537,7 @@ public abstract class GuiBuildCraft extends GuiContainer {
} }
} }
protected BuildCraftContainer getContainer() { public BuildCraftContainer getContainer() {
return container; return container;
} }
} }

View file

@ -6,8 +6,10 @@
* License 1.0, or MMPL. Please check the contents of the license located in * License 1.0, or MMPL. Please check the contents of the license located in
* http://www.mod-buildcraft.com/MMPL-1.0.txt * http://www.mod-buildcraft.com/MMPL-1.0.txt
*/ */
package buildcraft.core.gui; package buildcraft.core.science;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
import org.lwjgl.opengl.GL11; import org.lwjgl.opengl.GL11;
@ -19,10 +21,11 @@ import net.minecraft.util.IIcon;
import net.minecraft.util.ResourceLocation; import net.minecraft.util.ResourceLocation;
import buildcraft.core.DefaultProps; import buildcraft.core.DefaultProps;
import buildcraft.core.gui.AdvancedSlot;
import buildcraft.core.gui.ContainerScienceBook;
import buildcraft.core.gui.GuiAdvancedInterface;
import buildcraft.core.gui.ItemSlot;
import buildcraft.core.gui.slots.SlotHidden; import buildcraft.core.gui.slots.SlotHidden;
import buildcraft.core.science.Technology;
import buildcraft.core.science.TechnologyNBT;
import buildcraft.core.science.Tier;
public class GuiScienceBook extends GuiAdvancedInterface { public class GuiScienceBook extends GuiAdvancedInterface {
@ -30,8 +33,13 @@ public class GuiScienceBook extends GuiAdvancedInterface {
"buildcraft", DefaultProps.TEXTURE_PATH_GUI + "/science_gui.png"); "buildcraft", DefaultProps.TEXTURE_PATH_GUI + "/science_gui.png");
private static final ResourceLocation TEXTURE_FOCUS = new ResourceLocation( private static final ResourceLocation TEXTURE_FOCUS = new ResourceLocation(
"buildcraft", DefaultProps.TEXTURE_PATH_GUI + "/science_focus_gui.png"); "buildcraft", DefaultProps.TEXTURE_PATH_GUI + "/science_focus_gui.png");
private static final ResourceLocation TEXTURE_INFO = new ResourceLocation(
"buildcraft", DefaultProps.TEXTURE_PATH_GUI + "/science_blank.png");
private static final ResourceLocation TEXTURE_ICONS = new ResourceLocation( private static final ResourceLocation TEXTURE_ICONS = new ResourceLocation(
"buildcraft", DefaultProps.TEXTURE_PATH_GUI + "/science_icons.png"); "buildcraft", DefaultProps.TEXTURE_PATH_GUI + "/science_icons.png");
private static final ResourceLocation TEXTURE_TAB = new ResourceLocation(
"buildcraft", DefaultProps.TEXTURE_PATH_GUI + "/science_tab.png");
private static final int EXTRA_ADVANCED_SLOTS = 1; private static final int EXTRA_ADVANCED_SLOTS = 1;
@ -40,6 +48,8 @@ public class GuiScienceBook extends GuiAdvancedInterface {
private Technology inFocus = null; private Technology inFocus = null;
private GuiButton startResearch; private GuiButton startResearch;
private GuiButton wiki;
private ArrayList<String> infoText = new ArrayList<String>();
static class EmptySlot extends AdvancedSlot { static class EmptySlot extends AdvancedSlot {
public EmptySlot(GuiAdvancedInterface gui, int x, int y) { public EmptySlot(GuiAdvancedInterface gui, int x, int y) {
@ -152,7 +162,7 @@ public class GuiScienceBook extends GuiAdvancedInterface {
xSize = 256; xSize = 256;
ySize = 181; ySize = 181;
slots = new AdvancedSlot[50]; resetNullSlots(50);
setTier(Tier.WoodenGear); setTier(Tier.WoodenGear);
} }
@ -165,6 +175,7 @@ public class GuiScienceBook extends GuiAdvancedInterface {
int j = (width - xSize) / 2; int j = (width - xSize) / 2;
int k = (height - ySize) / 2; int k = (height - ySize) / 2;
startResearch = new GuiButton(0, j + 10, k + 145, 70, 20, "Start"); startResearch = new GuiButton(0, j + 10, k + 145, 70, 20, "Start");
wiki = new GuiButton(0, j + 115, k + 145, 70, 20, "Wiki");
} }
@Override @Override
@ -184,11 +195,8 @@ public class GuiScienceBook extends GuiAdvancedInterface {
} }
} }
if (inFocus == null) { bindTexture(TEXTURE_TAB);
texture = TEXTURE_BASE; drawTexturedModalRect(cornerX, cornerY, 0, 0, xSize, ySize);
} else {
texture = TEXTURE_FOCUS;
}
super.drawGuiContainerBackgroundLayer(f, mouseX, mouseY); super.drawGuiContainerBackgroundLayer(f, mouseX, mouseY);
@ -226,6 +234,12 @@ public class GuiScienceBook extends GuiAdvancedInterface {
protected void drawGuiContainerForegroundLayer(int par1, int par2) { protected void drawGuiContainerForegroundLayer(int par1, int par2) {
super.drawGuiContainerForegroundLayer(par1, par2); super.drawGuiContainerForegroundLayer(par1, par2);
if (infoText != null) {
for (int i = 0; i < infoText.size(); ++i) {
fontRendererObj.drawString(infoText.get(i), 10, 25 + i * 10, 0x404040);
}
}
drawTooltipForSlotAt(par1, par2); drawTooltipForSlotAt(par1, par2);
} }
@ -233,6 +247,13 @@ public class GuiScienceBook extends GuiAdvancedInterface {
protected void actionPerformed(GuiButton button) { protected void actionPerformed(GuiButton button) {
if (button == startResearch) { if (button == startResearch) {
getContainer().startResearch(inFocus); getContainer().startResearch(inFocus);
} else if (button == wiki) {
try {
java.awt.Desktop.getDesktop().browse(
java.net.URI.create(inFocus.getWikiLink()));
} catch (IOException e) {
e.printStackTrace();
}
} }
} }
@ -274,8 +295,11 @@ public class GuiScienceBook extends GuiAdvancedInterface {
} }
private void setTier(Tier newTier) { private void setTier(Tier newTier) {
texture = TEXTURE_BASE;
if (inFocus != null || newTier != currentTier) { if (inFocus != null || newTier != currentTier) {
slots = new AdvancedSlot[50 + EXTRA_ADVANCED_SLOTS]; resetNullSlots(50);
currentTier = newTier; currentTier = newTier;
int id = 0; int id = 0;
@ -286,7 +310,7 @@ public class GuiScienceBook extends GuiAdvancedInterface {
int j = id / 10; int j = id / 10;
int i = id - j * 10; int i = id - j * 10;
slots[id] = new TechnologySlot(this, 9 + i * 18, 7 + j * 18, t); slots.set(id, new TechnologySlot(this, 9 + i * 18, 7 + j * 18, t));
id++; id++;
} }
@ -294,7 +318,7 @@ public class GuiScienceBook extends GuiAdvancedInterface {
int j = id / 10; int j = id / 10;
int i = id - j * 10; int i = id - j * 10;
slots[id] = new EmptySlot(this, 9 + i * 18, 7 + j * 18); slots.set(id, new EmptySlot(this, 9 + i * 18, 7 + j * 18));
id++; id++;
} }
} }
@ -316,6 +340,7 @@ public class GuiScienceBook extends GuiAdvancedInterface {
private void setFocus(Technology techno) { private void setFocus(Technology techno) {
inFocus = techno; inFocus = techno;
texture = TEXTURE_FOCUS;
for (Object s : container.inventorySlots) { for (Object s : container.inventorySlots) {
if (s instanceof SlotHidden) { if (s instanceof SlotHidden) {
@ -325,38 +350,36 @@ public class GuiScienceBook extends GuiAdvancedInterface {
} }
} }
slots = new AdvancedSlot[5 + 3 + 1 + 10 + EXTRA_ADVANCED_SLOTS]; slots.clear();
int id = 0;
for (int i = 0; i < 5; ++i) { for (int i = 0; i < 5; ++i) {
if (techno.getPrerequisites().size() > i if (techno.getPrerequisites().size() > i
&& techno.getPrerequisites().get(i) != null) { && techno.getPrerequisites().get(i) != null) {
slots[id++] = new TechnologySlot(this, 33, 43 + 18 * i, techno.getPrerequisites().get(i)); slots.add(new TechnologySlot(this, 33, 43 + 18 * i, techno.getPrerequisites().get(i)));
} else { } else {
id++; slots.add(null);
} }
} }
for (int i = 0; i < 3; ++i) { for (int i = 0; i < 3; ++i) {
if (techno.getRequirements() != null) { if (techno.getRequirements() != null) {
slots[id++] = new ItemSlot(this, 71 + 18 * i, 115, techno.getRequirements()[i]); slots.add(new ItemSlot(this, 71 + 18 * i, 115, techno.getRequirements()[i]));
} else { } else {
id++; slots.add(null);
} }
} }
slots[id++] = new TechnologySlot(this, 89, 79, techno); slots.add(new TechnologySlot(this, 89, 79, techno));
for (int i = 0; i < 5; ++i) { for (int i = 0; i < 5; ++i) {
for (int j = 0; j < 2; ++j) { for (int j = 0; j < 2; ++j) {
int followupId = i * 2 + j; int followupId = i * 2 + j;
if (techno.getFollowups().size() > followupId if (techno.getFollowups().size() > followupId
&& techno.getFollowups().get(followupId) != null) { && techno.getFollowups().get(followupId) != null) {
slots[id++] = new TechnologySlot(this, 145 + 18 * j, 43 + 18 * i, techno.getFollowups().get( slots.add(new TechnologySlot(this, 145 + 18 * j, 43 + 18 * i, techno.getFollowups().get(
followupId)); followupId)));
} else { } else {
id++; slots.add(null);
} }
} }
} }
@ -367,16 +390,20 @@ public class GuiScienceBook extends GuiAdvancedInterface {
buttonList.add(startResearch); buttonList.add(startResearch);
} }
if (wiki != null) {
buttonList.add(wiki);
}
setExtraAdvancedSlots(); setExtraAdvancedSlots();
} }
@Override @Override
protected ContainerScienceBook getContainer() { public ContainerScienceBook getContainer() {
return (ContainerScienceBook) super.getContainer(); return (ContainerScienceBook) super.getContainer();
} }
public void setExtraAdvancedSlots() { public void setExtraAdvancedSlots() {
slots[slots.length - 1] = new ResearchedSlot(this, 216, 28); slots.add(new ResearchedSlot(this, 216, 28));
} }
@Override @Override

View file

@ -121,4 +121,8 @@ public abstract class Technology {
public void registerIcons(IIconRegister par1IconRegister) { public void registerIcons(IIconRegister par1IconRegister) {
} }
public String getWikiLink() {
return "http://www.mod-buildcraft.com/wiki/doku.php?id=techno:" + getID().replaceAll(":", "_");
}
} }

View file

@ -19,7 +19,6 @@ import net.minecraftforge.fluids.FluidStack;
import buildcraft.api.recipes.CraftingResult; import buildcraft.api.recipes.CraftingResult;
import buildcraft.core.DefaultProps; import buildcraft.core.DefaultProps;
import buildcraft.core.gui.AdvancedSlot;
import buildcraft.core.gui.FluidSlot; import buildcraft.core.gui.FluidSlot;
import buildcraft.core.gui.GuiAdvancedInterface; import buildcraft.core.gui.GuiAdvancedInterface;
import buildcraft.core.utils.StringUtils; import buildcraft.core.utils.StringUtils;
@ -38,11 +37,9 @@ public class GuiRefinery extends GuiAdvancedInterface {
this.container = (ContainerRefinery) this.inventorySlots; this.container = (ContainerRefinery) this.inventorySlots;
this.slots = new AdvancedSlot[3]; this.slots.add(new FluidSlot(this, 38, 54));
this.slots.add(new FluidSlot(this, 126, 54));
this.slots[0] = new FluidSlot(this, 38, 54); this.slots.add(new FluidSlot(this, 82, 54));
this.slots[1] = new FluidSlot(this, 126, 54);
this.slots[2] = new FluidSlot(this, 82, 54);
} }
@Override @Override
@ -75,7 +72,7 @@ public class GuiRefinery extends GuiAdvancedInterface {
int cornerX = (width - xSize) / 2; int cornerX = (width - xSize) / 2;
int cornerY = (height - ySize) / 2; int cornerY = (height - ySize) / 2;
int position = getSlotAtLocation(i - cornerX, j - cornerY); int position = getSlotIndexAtLocation(i - cornerX, j - cornerY);
if (position >= 0 && position < 2) { if (position >= 0 && position < 2) {
if (k == 0) { if (k == 0) {
@ -108,18 +105,18 @@ public class GuiRefinery extends GuiAdvancedInterface {
Fluid filter0 = container.getFilter(0); Fluid filter0 = container.getFilter(0);
Fluid filter1 = container.getFilter(1); Fluid filter1 = container.getFilter(1);
((FluidSlot) slots[0]).fluid = filter0; ((FluidSlot) slots.get(0)).fluid = filter0;
((FluidSlot) slots[0]).colorRenderCache = container.refinery.tanks[0].colorRenderCache; ((FluidSlot) slots.get(0)).colorRenderCache = container.refinery.tanks[0].colorRenderCache;
((FluidSlot) slots[1]).fluid = filter1; ((FluidSlot) slots.get(1)).fluid = filter1;
((FluidSlot) slots[1]).colorRenderCache = container.refinery.tanks[1].colorRenderCache; ((FluidSlot) slots.get(1)).colorRenderCache = container.refinery.tanks[1].colorRenderCache;
CraftingResult<FluidStack> crafting = container.refinery.craftingResult; CraftingResult<FluidStack> crafting = container.refinery.craftingResult;
if (crafting != null) { if (crafting != null) {
((FluidSlot) slots[2]).fluid = crafting.crafted.getFluid(); ((FluidSlot) slots.get(2)).fluid = crafting.crafted.getFluid();
((FluidSlot) slots[2]).colorRenderCache = crafting.crafted.getFluid().getColor(crafting.crafted); ((FluidSlot) slots.get(2)).colorRenderCache = crafting.crafted.getFluid().getColor(crafting.crafted);
} else { } else {
((FluidSlot) slots[2]).fluid = null; ((FluidSlot) slots.get(2)).fluid = null;
} }
} }
} }

View file

@ -98,14 +98,9 @@ public class GuiAssemblyTable extends GuiAdvancedInterface {
xSize = 175; xSize = 175;
ySize = 207; ySize = 207;
slots = new AdvancedSlot[8];
int p = 0;
for (int j = 0; j < 2; ++j) { for (int j = 0; j < 2; ++j) {
for (int i = 0; i < 4; ++i) { for (int i = 0; i < 4; ++i) {
slots[p] = new RecipeSlot(134 + 18 * j, 36 + 18 * i); slots.add(new RecipeSlot(134 + 18 * j, 36 + 18 * i));
p++;
} }
} }
@ -116,11 +111,11 @@ public class GuiAssemblyTable extends GuiAdvancedInterface {
List<CraftingResult<ItemStack>> potentialRecipes = table.getPotentialOutputs(); List<CraftingResult<ItemStack>> potentialRecipes = table.getPotentialOutputs();
Iterator<CraftingResult<ItemStack>> cur = potentialRecipes.iterator(); Iterator<CraftingResult<ItemStack>> cur = potentialRecipes.iterator();
for (int p = 0; p < 8; ++p) { for (AdvancedSlot s : slots) {
if (cur.hasNext()) { if (cur.hasNext()) {
((RecipeSlot) slots[p]).crafting = cur.next(); ((RecipeSlot) s).crafting = cur.next();
} else { } else {
((RecipeSlot) slots[p]).crafting = null; ((RecipeSlot) s).crafting = null;
} }
} }
} }
@ -170,11 +165,9 @@ public class GuiAssemblyTable extends GuiAdvancedInterface {
int cornerX = (width - xSize) / 2; int cornerX = (width - xSize) / 2;
int cornerY = (height - ySize) / 2; int cornerY = (height - ySize) / 2;
int position = getSlotAtLocation(i - cornerX, j - cornerY); RecipeSlot slot = (RecipeSlot) getSlotAtLocation(i - cornerX, j - cornerY);
if (position != -1) {
RecipeSlot slot = (RecipeSlot) slots[position];
if (slot != null) {
if (slot.crafting == null) { if (slot.crafting == null) {
return; return;
} }

View file

@ -51,12 +51,11 @@ public class GuiRedstoneBoard extends GuiAdvancedInterface {
board = RedstoneBoardRegistry.instance.getRedstoneBoard(boardNBT); board = RedstoneBoardRegistry.instance.getRedstoneBoard(boardNBT);
params = board.getParameters(boardNBT); params = board.getParameters(boardNBT);
slots = new AdvancedSlot[params.length];
for (int i = 0; i < params.length; ++i) { for (int i = 0; i < params.length; ++i) {
slots[i] = new ItemSlot(this, 10, 10 + i * 20); ItemSlot s = new ItemSlot(this, 10, 10 + i * 20);
slots[i].drawBackround = true; slots.add(s);
((ItemSlot) slots[i]).stack = ((IBoardParameterStack) params[i]).getStack(); s.drawBackround = true;
s.stack = ((IBoardParameterStack) params[i]).getStack();
} }
} }
@ -90,7 +89,7 @@ public class GuiRedstoneBoard extends GuiAdvancedInterface {
int cornerX = (width - xSize) / 2; int cornerX = (width - xSize) / 2;
int cornerY = (height - ySize) / 2; int cornerY = (height - ySize) / 2;
int position = getSlotAtLocation(i - cornerX, j - cornerY); int position = getSlotIndexAtLocation(i - cornerX, j - cornerY);
AdvancedSlot slot = null; AdvancedSlot slot = null;
@ -98,7 +97,7 @@ public class GuiRedstoneBoard extends GuiAdvancedInterface {
return; return;
} }
slot = slots[position]; slot = slots.get(position);
if (slot instanceof ItemSlot) { if (slot instanceof ItemSlot) {
ItemStack stackCopy = mc.thePlayer.inventory.getItemStack().copy(); ItemStack stackCopy = mc.thePlayer.inventory.getItemStack().copy();

View file

@ -216,91 +216,82 @@ public class GuiGateInterface extends GuiAdvancedInterface {
int position = 0; int position = 0;
if (gate.material == GateMaterial.REDSTONE) { if (gate.material == GateMaterial.REDSTONE) {
slots = new AdvancedSlot[2]; slots.add(new TriggerSlot(62, 26, pipe, 0));
slots.add(new ActionSlot(98, 26, pipe, 0));
slots[0] = new TriggerSlot(62, 26, pipe, 0);
slots[1] = new ActionSlot(98, 26, pipe, 0);
} else if (gate.material == GateMaterial.IRON) { } else if (gate.material == GateMaterial.IRON) {
slots = new AdvancedSlot[4]; slots.add(new TriggerSlot(62, 26, pipe, 0));
slots.add(new TriggerSlot(62, 44, pipe, 1));
slots[0] = new TriggerSlot(62, 26, pipe, 0); slots.add(new ActionSlot(98, 26, pipe, 0));
slots[1] = new TriggerSlot(62, 44, pipe, 1); slots.add(new ActionSlot(98, 44, pipe, 1));
slots[2] = new ActionSlot(98, 26, pipe, 0);
slots[3] = new ActionSlot(98, 44, pipe, 1);
} else if (gate.material == GateMaterial.GOLD) { } else if (gate.material == GateMaterial.GOLD) {
slots = new AdvancedSlot[12];
for (int k = 0; k < 4; ++k) { for (int k = 0; k < 4; ++k) {
slots[position] = new TriggerSlot(53, 26 + 18 * k, pipe, position); slots.add(new TriggerSlot(53, 26 + 18 * k, pipe, position));
position++; position++;
} }
for (int k = 0; k < 4; ++k) { for (int k = 0; k < 4; ++k) {
slots[position] = new ActionSlot(107, 26 + 18 * k, pipe, position - 4); slots.add(new ActionSlot(107, 26 + 18 * k, pipe, position - 4));
position++; position++;
} }
for (int k = 0; k < 4; ++k) { for (int k = 0; k < 4; ++k) {
slots[position] = new TriggerParameterSlot(71, 26 + 18 * k, pipe, 0, (TriggerSlot) slots[k]); slots.add(new TriggerParameterSlot(71, 26 + 18 * k, pipe, 0, (TriggerSlot) slots.get(k)));
position++; position++;
} }
} else if (gate.material == GateMaterial.DIAMOND) { } else if (gate.material == GateMaterial.DIAMOND) {
slots = new AdvancedSlot[24];
for (int k = 0; k < 4; ++k) { for (int k = 0; k < 4; ++k) {
slots[position] = new TriggerSlot(8, 26 + 18 * k, pipe, position); slots.add(new TriggerSlot(8, 26 + 18 * k, pipe, position));
position++; position++;
slots[position] = new TriggerSlot(98, 26 + 18 * k, pipe, position); slots.add(new TriggerSlot(98, 26 + 18 * k, pipe, position));
position++; position++;
} }
for (int k = 0; k < 4; ++k) { for (int k = 0; k < 4; ++k) {
slots[position] = new ActionSlot(62, 26 + 18 * k, pipe, position - 8); slots.add(new ActionSlot(62, 26 + 18 * k, pipe, position - 8));
position++; position++;
slots[position] = new ActionSlot(152, 26 + 18 * k, pipe, position - 8); slots.add(new ActionSlot(152, 26 + 18 * k, pipe, position - 8));
position++; position++;
} }
for (int k = 0; k < 4; ++k) { for (int k = 0; k < 4; ++k) {
slots[position] = new TriggerParameterSlot(26, 26 + 18 * k, pipe, 0, slots.add(new TriggerParameterSlot(26, 26 + 18 * k, pipe, 0,
(TriggerSlot) slots[k]); (TriggerSlot) slots.get(k)));
position++; position++;
slots[position] = new TriggerParameterSlot(116, 26 + 18 * k, pipe, 0, slots.add(new TriggerParameterSlot(116, 26 + 18 * k, pipe, 0,
(TriggerSlot) slots[k + 4]); (TriggerSlot) slots.get(k + 4)));
position++; position++;
} }
} else if (gate.material == GateMaterial.EMERALD) { } else if (gate.material == GateMaterial.EMERALD) {
slots = new AdvancedSlot[32];
int lastPos; int lastPos;
for (int y = 0; y < 4; ++y) { for (int y = 0; y < 4; ++y) {
slots[position] = new TriggerSlot(8, 26 + 18 * y, pipe, y); slots.add(new TriggerSlot(8, 26 + 18 * y, pipe, y));
lastPos = position; lastPos = position;
position++; position++;
for (int x = 0; x < 3; ++x) { for (int x = 0; x < 3; ++x) {
slots[position] = new TriggerParameterSlot( slots.add(new TriggerParameterSlot(
8 + 18 * (x + 1), 8 + 18 * (x + 1),
26 + 18 * y, 26 + 18 * y,
pipe, pipe,
x, x,
(TriggerSlot) slots[lastPos]); (TriggerSlot) slots.get(lastPos)));
position++; position++;
} }
slots[position] = new ActionSlot(98, 26 + 18 * y, pipe, y); slots.add(new ActionSlot(98, 26 + 18 * y, pipe, y));
lastPos = position; lastPos = position;
position++; position++;
for (int x = 0; x < 3; ++x) { for (int x = 0; x < 3; ++x) {
slots[position] = new ActionParameterSlot( slots.add(new ActionParameterSlot(
98 + 18 * (x + 1), 98 + 18 * (x + 1),
26 + 18 * y, 26 + 18 * y,
pipe, pipe,
x, x,
(ActionSlot) slots[lastPos]); (ActionSlot) slots.get(lastPos)));
position++; position++;
} }
} }
@ -384,15 +375,8 @@ public class GuiGateInterface extends GuiAdvancedInterface {
int cornerX = (width - xSize) / 2; int cornerX = (width - xSize) / 2;
int cornerY = (height - ySize) / 2; int cornerY = (height - ySize) / 2;
int position = getSlotAtLocation(i - cornerX, j - cornerY);
AdvancedSlot slot = null; AdvancedSlot slot = getSlotAtLocation(i - cornerX, j - cornerY);
if (position < 0) {
return;
}
slot = slots[position];
if (slot instanceof TriggerSlot && container.hasTriggers()) { if (slot instanceof TriggerSlot && container.hasTriggers()) {
TriggerSlot triggerSlot = (TriggerSlot) slot; TriggerSlot triggerSlot = (TriggerSlot) slot;