Commit 176016aebb5ad215f056093a9ef741034b409667
1 parent
ad12632b
LiteLoader 1.6.4_02 - experimental - "Configurable" interface for mods that want…
… to provide a config panel in the mod info GUI
Showing
9 changed files
with
763 additions
and
54 deletions
java/com/mumfrey/liteloader/Configurable.java
0 → 100644
1 | +package com.mumfrey.liteloader; | ||
2 | + | ||
3 | +import com.mumfrey.liteloader.modconfig.ConfigPanel; | ||
4 | + | ||
5 | +/** | ||
6 | + * Interface for mods which want to provide a configuration panel inside the "mod info" screen | ||
7 | + * | ||
8 | + * @author Adam Mummery-Smith | ||
9 | + */ | ||
10 | +public interface Configurable | ||
11 | +{ | ||
12 | + /** | ||
13 | + * Get the class of the configuration panel to use, the returned class must have a | ||
14 | + * default (no-arg) constructor | ||
15 | + * | ||
16 | + * @return configuration panel class | ||
17 | + */ | ||
18 | + public abstract Class<? extends ConfigPanel> getConfigPanelClass(); | ||
19 | +} |
java/com/mumfrey/liteloader/core/LiteLoader.java
@@ -39,6 +39,7 @@ import com.mumfrey.liteloader.crashreport.CallableLiteLoaderBrand; | @@ -39,6 +39,7 @@ import com.mumfrey.liteloader.crashreport.CallableLiteLoaderBrand; | ||
39 | import com.mumfrey.liteloader.crashreport.CallableLiteLoaderMods; | 39 | import com.mumfrey.liteloader.crashreport.CallableLiteLoaderMods; |
40 | import com.mumfrey.liteloader.gui.GuiControlsPaginated; | 40 | import com.mumfrey.liteloader.gui.GuiControlsPaginated; |
41 | import com.mumfrey.liteloader.gui.GuiScreenModInfo; | 41 | import com.mumfrey.liteloader.gui.GuiScreenModInfo; |
42 | +import com.mumfrey.liteloader.modconfig.ConfigPanelManager; | ||
42 | import com.mumfrey.liteloader.permissions.PermissionsManagerClient; | 43 | import com.mumfrey.liteloader.permissions.PermissionsManagerClient; |
43 | import com.mumfrey.liteloader.util.PrivateFields; | 44 | import com.mumfrey.liteloader.util.PrivateFields; |
44 | 45 | ||
@@ -163,6 +164,11 @@ public final class LiteLoader | @@ -163,6 +164,11 @@ public final class LiteLoader | ||
163 | private final PermissionsManagerClient permissionsManager = PermissionsManagerClient.getInstance(); | 164 | private final PermissionsManagerClient permissionsManager = PermissionsManagerClient.getInstance(); |
164 | 165 | ||
165 | /** | 166 | /** |
167 | + * Configuration panel manager/registry | ||
168 | + */ | ||
169 | + private final ConfigPanelManager configPanelManager; | ||
170 | + | ||
171 | + /** | ||
166 | * Flag which keeps track of whether late initialisation has been done | 172 | * Flag which keeps track of whether late initialisation has been done |
167 | */ | 173 | */ |
168 | private boolean postInitStarted, startupComplete; | 174 | private boolean postInitStarted, startupComplete; |
@@ -266,6 +272,8 @@ public final class LiteLoader | @@ -266,6 +272,8 @@ public final class LiteLoader | ||
266 | 272 | ||
267 | this.enabledModsList = EnabledModsList.createFrom(this.enabledModsFile); | 273 | this.enabledModsList = EnabledModsList.createFrom(this.enabledModsFile); |
268 | this.enabledModsList.processModsList(bootstrap.getProfile(), modNameFilter); | 274 | this.enabledModsList.processModsList(bootstrap.getProfile(), modNameFilter); |
275 | + | ||
276 | + this.configPanelManager = new ConfigPanelManager(); | ||
269 | } | 277 | } |
270 | 278 | ||
271 | /** | 279 | /** |
@@ -899,10 +907,11 @@ public final class LiteLoader | @@ -899,10 +907,11 @@ public final class LiteLoader | ||
899 | // add the mod to all relevant listener queues | 907 | // add the mod to all relevant listener queues |
900 | this.events.addListener(mod); | 908 | this.events.addListener(mod); |
901 | 909 | ||
902 | - if (mod instanceof Permissible) | ||
903 | - { | ||
904 | - this.permissionsManager.registerPermissible((Permissible)mod); | ||
905 | - } | 910 | + // add mod to permissions manager if permissible |
911 | + this.permissionsManager.registerMod(mod); | ||
912 | + | ||
913 | + // register mod config panel if configurable | ||
914 | + this.configPanelManager.registerMod(mod); | ||
906 | 915 | ||
907 | this.loadedMods.add(mod); | 916 | this.loadedMods.add(mod); |
908 | this.loadedModsList += String.format("\n - %s version %s", mod.getName(), mod.getVersion()); | 917 | this.loadedModsList += String.format("\n - %s version %s", mod.getName(), mod.getVersion()); |
@@ -1023,7 +1032,7 @@ public final class LiteLoader | @@ -1023,7 +1032,7 @@ public final class LiteLoader | ||
1023 | // If we're at the main menu, prepare the overlay | 1032 | // If we're at the main menu, prepare the overlay |
1024 | if (this.modInfoScreen == null || this.modInfoScreen.getMenu() != this.minecraft.currentScreen) | 1033 | if (this.modInfoScreen == null || this.modInfoScreen.getMenu() != this.minecraft.currentScreen) |
1025 | { | 1034 | { |
1026 | - this.modInfoScreen = new GuiScreenModInfo(this.minecraft, (GuiMainMenu)this.minecraft.currentScreen, this, this.enabledModsList); | 1035 | + this.modInfoScreen = new GuiScreenModInfo(this.minecraft, (GuiMainMenu)this.minecraft.currentScreen, this, this.enabledModsList, this.configPanelManager); |
1027 | } | 1036 | } |
1028 | 1037 | ||
1029 | this.modInfoScreen.drawScreen(mouseX, mouseY, partialTicks); | 1038 | this.modInfoScreen.drawScreen(mouseX, mouseY, partialTicks); |
@@ -1036,7 +1045,7 @@ public final class LiteLoader | @@ -1036,7 +1045,7 @@ public final class LiteLoader | ||
1036 | } | 1045 | } |
1037 | else if (this.minecraft.currentScreen instanceof GuiMainMenu && Keyboard.isKeyDown(Keyboard.KEY_LCONTROL) && Keyboard.isKeyDown(Keyboard.KEY_LSHIFT) && Keyboard.isKeyDown(Keyboard.KEY_TAB)) | 1046 | else if (this.minecraft.currentScreen instanceof GuiMainMenu && Keyboard.isKeyDown(Keyboard.KEY_LCONTROL) && Keyboard.isKeyDown(Keyboard.KEY_LSHIFT) && Keyboard.isKeyDown(Keyboard.KEY_TAB)) |
1038 | { | 1047 | { |
1039 | - this.minecraft.displayGuiScreen(new GuiScreenModInfo(this.minecraft, (GuiMainMenu)this.minecraft.currentScreen, this, this.enabledModsList)); | 1048 | + this.minecraft.displayGuiScreen(new GuiScreenModInfo(this.minecraft, (GuiMainMenu)this.minecraft.currentScreen, this, this.enabledModsList, this.configPanelManager)); |
1040 | } | 1049 | } |
1041 | } | 1050 | } |
1042 | 1051 |
java/com/mumfrey/liteloader/gui/GuiConfigPanelContainer.java
0 → 100644
1 | +package com.mumfrey.liteloader.gui; | ||
2 | + | ||
3 | +import static org.lwjgl.opengl.GL11.*; | ||
4 | +import static com.mumfrey.liteloader.gui.GuiScreenModInfo.glEnableClipping; | ||
5 | +import static com.mumfrey.liteloader.gui.GuiScreenModInfo.glDisableClipping; | ||
6 | + | ||
7 | +import java.util.LinkedList; | ||
8 | +import java.util.List; | ||
9 | + | ||
10 | +import net.minecraft.src.Gui; | ||
11 | +import net.minecraft.src.GuiButton; | ||
12 | +import net.minecraft.src.Minecraft; | ||
13 | + | ||
14 | +import com.mumfrey.liteloader.LiteMod; | ||
15 | +import com.mumfrey.liteloader.modconfig.ConfigPanel; | ||
16 | +import com.mumfrey.liteloader.modconfig.ConfigPanelHost; | ||
17 | + | ||
18 | +/** | ||
19 | + * Config panel container, this handles drawing the configuration panel chrome and also hosts the | ||
20 | + * configuration panels themselves to support scrolling and stuff | ||
21 | + * | ||
22 | + * @author Adam Mummery-Smith | ||
23 | + */ | ||
24 | +public class GuiConfigPanelContainer extends Gui implements ConfigPanelHost | ||
25 | +{ | ||
26 | + private static final int TOP = 26; | ||
27 | + private static final int BOTTOM = 40; | ||
28 | + private static final int MARGIN = 12; | ||
29 | + | ||
30 | + /** | ||
31 | + * Parent screen | ||
32 | + */ | ||
33 | + private GuiScreenModInfo parent; | ||
34 | + | ||
35 | + /** | ||
36 | + * Minecraft | ||
37 | + */ | ||
38 | + private Minecraft mc; | ||
39 | + | ||
40 | + /** | ||
41 | + * Panel we are hosting | ||
42 | + */ | ||
43 | + private ConfigPanel panel; | ||
44 | + | ||
45 | + /** | ||
46 | + * Mod being configured, the panel may want a reference to it | ||
47 | + */ | ||
48 | + private LiteMod mod; | ||
49 | + | ||
50 | + /** | ||
51 | + * Buttons | ||
52 | + */ | ||
53 | + private List<GuiButton> controls = new LinkedList<GuiButton>(); | ||
54 | + | ||
55 | + /** | ||
56 | + * Scroll bar for the panel | ||
57 | + */ | ||
58 | + private GuiSimpleScrollBar scrollBar = new GuiSimpleScrollBar(); | ||
59 | + | ||
60 | + /** | ||
61 | + * Current available width | ||
62 | + */ | ||
63 | + private int width = 0; | ||
64 | + | ||
65 | + /** | ||
66 | + * Current available height | ||
67 | + */ | ||
68 | + private int height = 0; | ||
69 | + | ||
70 | + /** | ||
71 | + * Current panel width (width - margins) | ||
72 | + */ | ||
73 | + private int panelWidth = 0; | ||
74 | + | ||
75 | + /** | ||
76 | + * Current panel visible height (height - chrome) | ||
77 | + */ | ||
78 | + private int panelHeight = 0; | ||
79 | + | ||
80 | + /** | ||
81 | + * Panel's internal height (for scrolling) | ||
82 | + */ | ||
83 | + private int totalHeight = -1; | ||
84 | + | ||
85 | + /** | ||
86 | + * Panel Y position (for scroll) | ||
87 | + */ | ||
88 | + private int panelTop = TOP; | ||
89 | + | ||
90 | + /** | ||
91 | + * @param parent | ||
92 | + * @param minecraft | ||
93 | + * @param panel | ||
94 | + * @param mod | ||
95 | + */ | ||
96 | + GuiConfigPanelContainer(GuiScreenModInfo parent, Minecraft minecraft, ConfigPanel panel, LiteMod mod) | ||
97 | + { | ||
98 | + this.parent = parent; | ||
99 | + this.mc = minecraft; | ||
100 | + this.panel = panel; | ||
101 | + this.mod = mod; | ||
102 | + } | ||
103 | + | ||
104 | + /* (non-Javadoc) | ||
105 | + * @see com.mumfrey.liteloader.modconfig.ConfigPanelHost#getMod() | ||
106 | + */ | ||
107 | + @SuppressWarnings("unchecked") | ||
108 | + @Override | ||
109 | + public <ModClass extends LiteMod> ModClass getMod() | ||
110 | + { | ||
111 | + return (ModClass)this.mod; | ||
112 | + } | ||
113 | + | ||
114 | + /* (non-Javadoc) | ||
115 | + * @see com.mumfrey.liteloader.modconfig.ConfigPanelHost#getWidth() | ||
116 | + */ | ||
117 | + @Override | ||
118 | + public int getWidth() | ||
119 | + { | ||
120 | + return this.panelWidth; | ||
121 | + } | ||
122 | + | ||
123 | + /* (non-Javadoc) | ||
124 | + * @see com.mumfrey.liteloader.modconfig.ConfigPanelHost#getHeight() | ||
125 | + */ | ||
126 | + @Override | ||
127 | + public int getHeight() | ||
128 | + { | ||
129 | + return this.panelHeight; | ||
130 | + } | ||
131 | + | ||
132 | + /* (non-Javadoc) | ||
133 | + * @see com.mumfrey.liteloader.modconfig.ConfigPanelHost#close() | ||
134 | + */ | ||
135 | + @Override | ||
136 | + public void close() | ||
137 | + { | ||
138 | + this.parent.closeConfigPanel(this); | ||
139 | + } | ||
140 | + | ||
141 | + /** | ||
142 | + * Callback from parent screen when window is resized | ||
143 | + * | ||
144 | + * @param width | ||
145 | + * @param height | ||
146 | + */ | ||
147 | + void setSize(int width, int height) | ||
148 | + { | ||
149 | + this.width = width; | ||
150 | + this.height = height; | ||
151 | + | ||
152 | + this.panelHeight = this.height - TOP - BOTTOM; | ||
153 | + this.panelWidth = this.width - (MARGIN * 2) - 6; | ||
154 | + | ||
155 | + this.panel.onPanelResize(this); | ||
156 | + | ||
157 | + this.controls.clear(); | ||
158 | + this.controls.add(new GuiButton(0, this.width - 99 - MARGIN, this.height - BOTTOM + 9, 100, 20, "Save & Close")); | ||
159 | + } | ||
160 | + | ||
161 | + /** | ||
162 | + * Callback from parent screen when panel is displayed | ||
163 | + */ | ||
164 | + void onShown() | ||
165 | + { | ||
166 | + this.panel.onPanelShown(this); | ||
167 | + } | ||
168 | + | ||
169 | + /** | ||
170 | + * Callback from parent screen when panel is hidden | ||
171 | + */ | ||
172 | + void onHidden() | ||
173 | + { | ||
174 | + this.panel.onPanelHidden(); | ||
175 | + } | ||
176 | + | ||
177 | + /** | ||
178 | + * Callback from parent screen every tick | ||
179 | + */ | ||
180 | + void onTick() | ||
181 | + { | ||
182 | + this.panel.onTick(this); | ||
183 | + } | ||
184 | + | ||
185 | + /** | ||
186 | + * Draw the panel and chrome | ||
187 | + * | ||
188 | + * @param mouseX | ||
189 | + * @param mouseY | ||
190 | + * @param partialTicks | ||
191 | + */ | ||
192 | + void draw(int mouseX, int mouseY, float partialTicks) | ||
193 | + { | ||
194 | + // Scroll position | ||
195 | + this.panelTop = TOP - this.scrollBar.getValue(); | ||
196 | + | ||
197 | + // Draw panel title | ||
198 | + String panelTitle = this.panel.getPanelTitle(); | ||
199 | + if (panelTitle != null) | ||
200 | + { | ||
201 | + this.mc.fontRenderer.drawString(panelTitle, MARGIN, TOP - 14, 0xFFFFFFFF); | ||
202 | + } | ||
203 | + | ||
204 | + // Draw top and bottom horizontal bars | ||
205 | + drawRect(MARGIN, TOP - 4, this.width - MARGIN, TOP - 3, 0xFF999999); | ||
206 | + drawRect(MARGIN, this.height - BOTTOM + 2, this.width - MARGIN, this.height - BOTTOM + 3, 0xFF999999); | ||
207 | + | ||
208 | + // Clip rect | ||
209 | + glEnableClipping(MARGIN, this.width - MARGIN - 6, TOP, this.height - BOTTOM); | ||
210 | + | ||
211 | + // Offset by scroll | ||
212 | + glPushMatrix(); | ||
213 | + glTranslatef(MARGIN, this.panelTop, 0.0F); | ||
214 | + | ||
215 | + // Draw panel contents | ||
216 | + this.panel.drawPanel(this, mouseX - MARGIN, mouseY - this.panelTop, partialTicks); | ||
217 | + glClear(GL_DEPTH_BUFFER_BIT); | ||
218 | + | ||
219 | + // Disable clip rect | ||
220 | + glDisableClipping(); | ||
221 | + | ||
222 | + // Restore transform | ||
223 | + glPopMatrix(); | ||
224 | + | ||
225 | + // Get total scroll height from panel | ||
226 | + this.totalHeight = Math.max(-1, this.panel.getContentHeight()); | ||
227 | + | ||
228 | + // Update and draw scroll bar | ||
229 | + this.scrollBar.setMaxValue(this.totalHeight - this.panelHeight); | ||
230 | + this.scrollBar.drawScrollBar(mouseX, mouseY, partialTicks, this.width - MARGIN - 5, TOP, 5, this.panelHeight, Math.max(this.panelHeight, this.totalHeight)); | ||
231 | + | ||
232 | + // Draw other buttons | ||
233 | + for (GuiButton control : this.controls) | ||
234 | + control.drawButton(this.mc, mouseX, mouseY); | ||
235 | + } | ||
236 | + | ||
237 | + /** | ||
238 | + * @param control | ||
239 | + */ | ||
240 | + private void actionPerformed(GuiButton control) | ||
241 | + { | ||
242 | + if (control.id == 0) this.close(); | ||
243 | + } | ||
244 | + | ||
245 | + /** | ||
246 | + * @param mouseWheelDelta | ||
247 | + */ | ||
248 | + public void mouseWheelScrolled(int mouseWheelDelta) | ||
249 | + { | ||
250 | + this.scrollBar.offsetValue(-mouseWheelDelta / 8); | ||
251 | + } | ||
252 | + | ||
253 | + /** | ||
254 | + * @param mouseX | ||
255 | + * @param mouseY | ||
256 | + * @param mouseButton | ||
257 | + */ | ||
258 | + void mousePressed(int mouseX, int mouseY, int mouseButton) | ||
259 | + { | ||
260 | + if (mouseButton == 0) | ||
261 | + { | ||
262 | + if (this.scrollBar.wasMouseOver()) | ||
263 | + this.scrollBar.setDragging(true); | ||
264 | + | ||
265 | + for (GuiButton control : this.controls) | ||
266 | + { | ||
267 | + if (control.mousePressed(this.mc, mouseX, mouseY)) | ||
268 | + { | ||
269 | + this.mc.sndManager.playSoundFX("random.click", 1.0F, 1.0F); | ||
270 | + this.actionPerformed(control); | ||
271 | + } | ||
272 | + } | ||
273 | + } | ||
274 | + | ||
275 | + this.panel.mousePressed(this, mouseX - MARGIN, mouseY - this.panelTop, mouseButton); | ||
276 | + } | ||
277 | + | ||
278 | + /** | ||
279 | + * @param mouseX | ||
280 | + * @param mouseY | ||
281 | + * @param mouseButton | ||
282 | + */ | ||
283 | + void mouseReleased(int mouseX, int mouseY, int mouseButton) | ||
284 | + { | ||
285 | + if (mouseButton == 0) | ||
286 | + { | ||
287 | + this.scrollBar.setDragging(false); | ||
288 | + } | ||
289 | + | ||
290 | + this.panel.mouseReleased(this, mouseX - MARGIN, mouseY - this.panelTop, mouseButton); | ||
291 | + } | ||
292 | + | ||
293 | + /** | ||
294 | + * @param mouseX | ||
295 | + * @param mouseY | ||
296 | + */ | ||
297 | + void mouseMoved(int mouseX, int mouseY) | ||
298 | + { | ||
299 | + this.panel.mouseMoved(this, mouseX - MARGIN, mouseY - this.panelTop); | ||
300 | + } | ||
301 | + | ||
302 | + /** | ||
303 | + * @param keyChar | ||
304 | + * @param keyCode | ||
305 | + */ | ||
306 | + void keyPressed(char keyChar, int keyCode) | ||
307 | + { | ||
308 | + this.panel.keyPressed(this, keyChar, keyCode); | ||
309 | + } | ||
310 | +} |
java/com/mumfrey/liteloader/gui/GuiModListEntry.java
@@ -24,6 +24,10 @@ public class GuiModListEntry extends Gui | @@ -24,6 +24,10 @@ public class GuiModListEntry extends Gui | ||
24 | * For text display | 24 | * For text display |
25 | */ | 25 | */ |
26 | private FontRenderer fontRenderer; | 26 | private FontRenderer fontRenderer; |
27 | + | ||
28 | + private LiteMod modInstance; | ||
29 | + | ||
30 | + private Class<? extends LiteMod> modClass; | ||
27 | 31 | ||
28 | /** | 32 | /** |
29 | * The metadata name (id) of the mod, used as the enablement/disablement key | 33 | * The metadata name (id) of the mod, used as the enablement/disablement key |
@@ -82,17 +86,19 @@ public class GuiModListEntry extends Gui | @@ -82,17 +86,19 @@ public class GuiModListEntry extends Gui | ||
82 | * @param loader | 86 | * @param loader |
83 | * @param enabledMods | 87 | * @param enabledMods |
84 | * @param fontRenderer | 88 | * @param fontRenderer |
85 | - * @param mod | 89 | + * @param modInstance |
86 | */ | 90 | */ |
87 | - GuiModListEntry(LiteLoader loader, EnabledModsList enabledMods, FontRenderer fontRenderer, LiteMod mod) | 91 | + GuiModListEntry(LiteLoader loader, EnabledModsList enabledMods, FontRenderer fontRenderer, LiteMod modInstance) |
88 | { | 92 | { |
89 | this.fontRenderer = fontRenderer; | 93 | this.fontRenderer = fontRenderer; |
90 | - this.metaName = loader.getModMetaName(mod.getClass()); | ||
91 | - this.name = mod.getName(); | ||
92 | - this.version = mod.getVersion(); | ||
93 | - this.author = loader.getModMetaData(mod.getClass(), "author", "Unknown"); | ||
94 | - this.url = loader.getModMetaData(mod.getClass(), "url", null); | ||
95 | - this.description = loader.getModMetaData(mod.getClass(), "description", ""); | 94 | + this.modInstance = modInstance; |
95 | + this.modClass = modInstance.getClass(); | ||
96 | + this.metaName = loader.getModMetaName(this.modClass); | ||
97 | + this.name = modInstance.getName(); | ||
98 | + this.version = modInstance.getVersion(); | ||
99 | + this.author = loader.getModMetaData(this.modClass, "author", "Unknown"); | ||
100 | + this.url = loader.getModMetaData(this.modClass, "url", null); | ||
101 | + this.description = loader.getModMetaData(this.modClass, "description", ""); | ||
96 | this.enabled = true; | 102 | this.enabled = true; |
97 | this.canBeToggled = this.metaName != null && enabledMods.saveAllowed(); | 103 | this.canBeToggled = this.metaName != null && enabledMods.saveAllowed(); |
98 | this.willBeEnabled = true; | 104 | this.willBeEnabled = true; |
@@ -204,6 +210,16 @@ public class GuiModListEntry extends Gui | @@ -204,6 +210,16 @@ public class GuiModListEntry extends Gui | ||
204 | return this.metaName + Integer.toHexString(this.hashCode()); | 210 | return this.metaName + Integer.toHexString(this.hashCode()); |
205 | } | 211 | } |
206 | 212 | ||
213 | + public LiteMod getModInstance() | ||
214 | + { | ||
215 | + return this.modInstance; | ||
216 | + } | ||
217 | + | ||
218 | + public Class<? extends LiteMod> getModClass() | ||
219 | + { | ||
220 | + return this.modClass; | ||
221 | + } | ||
222 | + | ||
207 | public String getName() | 223 | public String getName() |
208 | { | 224 | { |
209 | return this.name; | 225 | return this.name; |
java/com/mumfrey/liteloader/gui/GuiScreenModInfo.java
@@ -19,6 +19,8 @@ import com.mumfrey.liteloader.LiteMod; | @@ -19,6 +19,8 @@ import com.mumfrey.liteloader.LiteMod; | ||
19 | import com.mumfrey.liteloader.core.EnabledModsList; | 19 | import com.mumfrey.liteloader.core.EnabledModsList; |
20 | import com.mumfrey.liteloader.core.LiteLoader; | 20 | import com.mumfrey.liteloader.core.LiteLoader; |
21 | import com.mumfrey.liteloader.core.ModFile; | 21 | import com.mumfrey.liteloader.core.ModFile; |
22 | +import com.mumfrey.liteloader.modconfig.ConfigPanel; | ||
23 | +import com.mumfrey.liteloader.modconfig.ConfigPanelManager; | ||
22 | 24 | ||
23 | import net.minecraft.src.DynamicTexture; | 25 | import net.minecraft.src.DynamicTexture; |
24 | import net.minecraft.src.GuiButton; | 26 | import net.minecraft.src.GuiButton; |
@@ -39,12 +41,14 @@ import net.minecraft.src.Tessellator; | @@ -39,12 +41,14 @@ import net.minecraft.src.Tessellator; | ||
39 | */ | 41 | */ |
40 | public class GuiScreenModInfo extends GuiScreen | 42 | public class GuiScreenModInfo extends GuiScreen |
41 | { | 43 | { |
42 | - private static final int LEFT_EDGE = 80; | ||
43 | - private static final int TAB_WIDTH = 20; | ||
44 | - private static final int TAB_HEIGHT = 40; | ||
45 | - private static final int TAB_TOP = 20; | ||
46 | - private static final int PANEL_TOP = 83; | ||
47 | - private static final int PANEL_BOTTOM = 26; | 44 | + private static final int LEFT_EDGE = 80; |
45 | + private static final int MARGIN = 12; | ||
46 | + private static final int TAB_WIDTH = 20; | ||
47 | + private static final int TAB_HEIGHT = 40; | ||
48 | + private static final int TAB_TOP = 20; | ||
49 | + private static final int PANEL_TOP = 83; | ||
50 | + private static final int PANEL_BOTTOM = 26; | ||
51 | + private static final int SCROLLBAR_WIDTH = 5; | ||
48 | 52 | ||
49 | private static final double TWEEN_RATE = 0.08; | 53 | private static final double TWEEN_RATE = 0.08; |
50 | 54 | ||
@@ -83,6 +87,11 @@ public class GuiScreenModInfo extends GuiScreen | @@ -83,6 +87,11 @@ public class GuiScreenModInfo extends GuiScreen | ||
83 | private boolean mouseDown, toggled; | 87 | private boolean mouseDown, toggled; |
84 | 88 | ||
85 | /** | 89 | /** |
90 | + * Timer used to handle double-clicking on a mod | ||
91 | + */ | ||
92 | + private int doubleClickTime = 0; | ||
93 | + | ||
94 | + /** | ||
86 | * Hover opacity for the tab | 95 | * Hover opacity for the tab |
87 | */ | 96 | */ |
88 | private float tabOpacity = 0.0F; | 97 | private float tabOpacity = 0.0F; |
@@ -118,20 +127,33 @@ public class GuiScreenModInfo extends GuiScreen | @@ -118,20 +127,33 @@ public class GuiScreenModInfo extends GuiScreen | ||
118 | private GuiButton btnToggle; | 127 | private GuiButton btnToggle; |
119 | 128 | ||
120 | /** | 129 | /** |
130 | + * Config button | ||
131 | + */ | ||
132 | + private GuiButton btnConfig; | ||
133 | + | ||
134 | + /** | ||
121 | * Enable the mod info tab checkbox | 135 | * Enable the mod info tab checkbox |
122 | */ | 136 | */ |
123 | private GuiCheckbox chkEnabled; | 137 | private GuiCheckbox chkEnabled; |
124 | 138 | ||
139 | + private ConfigPanelManager configPanelManager; | ||
140 | + | ||
141 | + /** | ||
142 | + * Configuration panel | ||
143 | + */ | ||
144 | + private GuiConfigPanelContainer configPanel; | ||
145 | + | ||
125 | /** | 146 | /** |
126 | * @param minecraft | 147 | * @param minecraft |
127 | * @param mainMenu | 148 | * @param mainMenu |
128 | * @param loader | 149 | * @param loader |
129 | * @param enabledModsList | 150 | * @param enabledModsList |
130 | */ | 151 | */ |
131 | - public GuiScreenModInfo(Minecraft minecraft, GuiMainMenu mainMenu, LiteLoader loader, EnabledModsList enabledModsList) | 152 | + public GuiScreenModInfo(Minecraft minecraft, GuiMainMenu mainMenu, LiteLoader loader, EnabledModsList enabledModsList, ConfigPanelManager configPanelManager) |
132 | { | 153 | { |
133 | this.mc = minecraft; | 154 | this.mc = minecraft; |
134 | this.mainMenu = mainMenu; | 155 | this.mainMenu = mainMenu; |
156 | + this.configPanelManager = configPanelManager; | ||
135 | 157 | ||
136 | // Spawn the texture resource if we haven't already | 158 | // Spawn the texture resource if we haven't already |
137 | if (aboutTexture == null) | 159 | if (aboutTexture == null) |
@@ -206,11 +228,17 @@ public class GuiScreenModInfo extends GuiScreen | @@ -206,11 +228,17 @@ public class GuiScreenModInfo extends GuiScreen | ||
206 | @Override | 228 | @Override |
207 | public void initGui() | 229 | public void initGui() |
208 | { | 230 | { |
209 | - int left = LEFT_EDGE + 16 + (this.width - LEFT_EDGE - 28) / 2; | 231 | + if (this.configPanel != null) |
232 | + { | ||
233 | + this.configPanel.setSize(this.width - LEFT_EDGE, this.height); | ||
234 | + } | ||
235 | + | ||
236 | + int left = LEFT_EDGE + MARGIN + 4 + (this.width - LEFT_EDGE - MARGIN - MARGIN - 4) / 2; | ||
210 | 237 | ||
211 | this.buttonList.clear(); | 238 | this.buttonList.clear(); |
212 | - this.buttonList.add(this.btnToggle = new GuiButton(0, left, this.height - PANEL_BOTTOM - 24, 100, 20, "Enable mod")); | ||
213 | - this.buttonList.add(this.chkEnabled = new GuiCheckbox(1, LEFT_EDGE + 12, this.height - PANEL_BOTTOM + 9, "Show LiteLoader tab on main menu")); | 239 | + this.buttonList.add(this.btnToggle = new GuiButton(0, left, this.height - PANEL_BOTTOM - 24, 90, 20, "Enable mod")); |
240 | + this.buttonList.add(this.btnConfig = new GuiButton(1, left + 92, this.height - PANEL_BOTTOM - 24, 60, 20, "Config")); | ||
241 | + this.buttonList.add(this.chkEnabled = new GuiCheckbox(2, LEFT_EDGE + MARGIN, this.height - PANEL_BOTTOM + 9, "Show LiteLoader tab on main menu")); | ||
214 | 242 | ||
215 | this.selectMod(this.selectedMod); | 243 | this.selectMod(this.selectedMod); |
216 | } | 244 | } |
@@ -236,6 +264,11 @@ public class GuiScreenModInfo extends GuiScreen | @@ -236,6 +264,11 @@ public class GuiScreenModInfo extends GuiScreen | ||
236 | @Override | 264 | @Override |
237 | public void updateScreen() | 265 | public void updateScreen() |
238 | { | 266 | { |
267 | + if (this.configPanel != null) | ||
268 | + { | ||
269 | + this.configPanel.onTick(); | ||
270 | + } | ||
271 | + | ||
239 | this.tickNumber++; | 272 | this.tickNumber++; |
240 | 273 | ||
241 | if (this.mc.currentScreen == this) | 274 | if (this.mc.currentScreen == this) |
@@ -248,6 +281,9 @@ public class GuiScreenModInfo extends GuiScreen | @@ -248,6 +281,9 @@ public class GuiScreenModInfo extends GuiScreen | ||
248 | { | 281 | { |
249 | this.onToggled(); | 282 | this.onToggled(); |
250 | } | 283 | } |
284 | + | ||
285 | + if (this.doubleClickTime > 0) | ||
286 | + this.doubleClickTime--; | ||
251 | } | 287 | } |
252 | 288 | ||
253 | /* (non-Javadoc) | 289 | /* (non-Javadoc) |
@@ -311,28 +347,55 @@ public class GuiScreenModInfo extends GuiScreen | @@ -311,28 +347,55 @@ public class GuiScreenModInfo extends GuiScreen | ||
311 | // Only draw the panel contents if we are actually open | 347 | // Only draw the panel contents if we are actually open |
312 | if (this.tweenAmount > 0.0) | 348 | if (this.tweenAmount > 0.0) |
313 | { | 349 | { |
314 | - // Draw the header pieces | ||
315 | - glDrawTexturedRect(LEFT_EDGE + 12, 12, 128, 40, 0, 0, 256, 80, 1.0F); // liteloader logo | ||
316 | - glDrawTexturedRect(this.width - 32 - 12, 12, 32, 45, 0, 80, 64, 170, 1.0F); // chicken | ||
317 | - | ||
318 | - // Draw header text | ||
319 | - this.fontRenderer.drawString("Version " + LiteLoader.getVersion(), LEFT_EDGE + 12 + 38, 50, 0xFFFFFFFF); | ||
320 | - this.fontRenderer.drawString(this.activeModText, LEFT_EDGE + 12 + 38, 60, 0xFFAAAAAA); | ||
321 | - | ||
322 | - // Draw top and bottom horizontal rules | ||
323 | - drawRect(LEFT_EDGE + 12, 80, this.width - 12, 81, 0xFF999999); | ||
324 | - drawRect(LEFT_EDGE + 12, this.height - PANEL_BOTTOM + 2, this.width - 12, this.height - PANEL_BOTTOM + 3, 0xFF999999); | 350 | + if (this.configPanel != null) |
351 | + { | ||
352 | + this.drawConfigPanel(mouseX, mouseY, partialTicks); | ||
353 | + } | ||
354 | + else | ||
355 | + { | ||
356 | + // Draw the header pieces | ||
357 | + glDrawTexturedRect(LEFT_EDGE + MARGIN, 12, 128, 40, 0, 0, 256, 80, 1.0F); // liteloader logo | ||
358 | + glDrawTexturedRect(this.width - 32 - MARGIN, 12, 32, 45, 0, 80, 64, 170, 1.0F); // chicken | ||
359 | + | ||
360 | + // Draw header text | ||
361 | + this.fontRenderer.drawString("Version " + LiteLoader.getVersion(), LEFT_EDGE + MARGIN + 38, 50, 0xFFFFFFFF); | ||
362 | + this.fontRenderer.drawString(this.activeModText, LEFT_EDGE + MARGIN + 38, 60, 0xFFAAAAAA); | ||
363 | + | ||
364 | + // Draw top and bottom horizontal rules | ||
365 | + drawRect(LEFT_EDGE + MARGIN, 80, this.width - MARGIN, 81, 0xFF999999); | ||
366 | + drawRect(LEFT_EDGE + MARGIN, this.height - PANEL_BOTTOM + 2, this.width - MARGIN, this.height - PANEL_BOTTOM + 3, 0xFF999999); | ||
367 | + | ||
368 | + int innerWidth = this.width - LEFT_EDGE - MARGIN - MARGIN - 4; | ||
369 | + int panelWidth = innerWidth / 2; | ||
370 | + int panelHeight = this.height - PANEL_BOTTOM - PANEL_TOP; | ||
371 | + | ||
372 | + this.drawModsList(mouseX, mouseY, partialTicks, panelWidth, panelHeight); | ||
373 | + this.drawSelectedMod(mouseX, mouseY, partialTicks, panelWidth, panelHeight); | ||
374 | + | ||
375 | + // Draw other controls inside the transform so that they slide properly | ||
376 | + super.drawScreen(mouseX, mouseY, partialTicks); | ||
377 | + } | ||
378 | + } | ||
379 | + else if (this.configPanel != null) | ||
380 | + { | ||
381 | + this.closeConfigPanel(this.configPanel); | ||
382 | + } | ||
325 | 383 | ||
326 | - int innerWidth = this.width - LEFT_EDGE - 24 - 4; | ||
327 | - int panelWidth = innerWidth / 2; | ||
328 | - int panelHeight = this.height - PANEL_BOTTOM - PANEL_TOP; | ||
329 | - | ||
330 | - this.drawModsList(mouseX, mouseY, partialTicks, panelWidth, panelHeight); | ||
331 | - this.drawSelectedMod(mouseX, mouseY, partialTicks, panelWidth, panelHeight); | 384 | + |
385 | + glPopMatrix(); | ||
386 | + } | ||
332 | 387 | ||
333 | - // Draw other controls inside the transform so that they slide properly | ||
334 | - super.drawScreen(mouseX, mouseY, partialTicks); | ||
335 | - } | 388 | + /** |
389 | + * @param mouseX | ||
390 | + * @param mouseY | ||
391 | + * @param partialTicks | ||
392 | + */ | ||
393 | + public void drawConfigPanel(int mouseX, int mouseY, float partialTicks) | ||
394 | + { | ||
395 | + glPushMatrix(); | ||
396 | + glTranslatef(LEFT_EDGE, 0, 0); | ||
397 | + | ||
398 | + this.configPanel.draw(mouseX - LEFT_EDGE, mouseY, partialTicks); | ||
336 | 399 | ||
337 | glPopMatrix(); | 400 | glPopMatrix(); |
338 | } | 401 | } |
@@ -346,10 +409,10 @@ public class GuiScreenModInfo extends GuiScreen | @@ -346,10 +409,10 @@ public class GuiScreenModInfo extends GuiScreen | ||
346 | */ | 409 | */ |
347 | public void drawModsList(int mouseX, int mouseY, float partialTicks, int width, int height) | 410 | public void drawModsList(int mouseX, int mouseY, float partialTicks, int width, int height) |
348 | { | 411 | { |
349 | - this.scrollBar.drawScrollBar(mouseX, mouseY, partialTicks, LEFT_EDGE + 12 + width - 5, PANEL_TOP, 5, height, this.listHeight); | 412 | + this.scrollBar.drawScrollBar(mouseX, mouseY, partialTicks, LEFT_EDGE + MARGIN + width - SCROLLBAR_WIDTH, PANEL_TOP, SCROLLBAR_WIDTH, height, this.listHeight); |
350 | 413 | ||
351 | // clip outside of scroll area | 414 | // clip outside of scroll area |
352 | - glEnableClipping(LEFT_EDGE + 12, LEFT_EDGE + 12 + width - 6, PANEL_TOP, this.height - PANEL_BOTTOM); | 415 | + glEnableClipping(LEFT_EDGE + MARGIN, LEFT_EDGE + MARGIN + width - SCROLLBAR_WIDTH - 1, PANEL_TOP, this.height - PANEL_BOTTOM); |
353 | 416 | ||
354 | // handle scrolling | 417 | // handle scrolling |
355 | glPushMatrix(); | 418 | glPushMatrix(); |
@@ -361,7 +424,7 @@ public class GuiScreenModInfo extends GuiScreen | @@ -361,7 +424,7 @@ public class GuiScreenModInfo extends GuiScreen | ||
361 | for (GuiModListEntry mod : this.mods) | 424 | for (GuiModListEntry mod : this.mods) |
362 | { | 425 | { |
363 | // drawListEntry returns a value indicating the height of the item drawn | 426 | // drawListEntry returns a value indicating the height of the item drawn |
364 | - yPos += mod.drawListEntry(mouseX, mouseY, partialTicks, LEFT_EDGE + 12, yPos, width - 6, mod == this.selectedMod); | 427 | + yPos += mod.drawListEntry(mouseX, mouseY, partialTicks, LEFT_EDGE + MARGIN, yPos, width - 6, mod == this.selectedMod); |
365 | } | 428 | } |
366 | 429 | ||
367 | glPopMatrix(); | 430 | glPopMatrix(); |
@@ -382,8 +445,8 @@ public class GuiScreenModInfo extends GuiScreen | @@ -382,8 +445,8 @@ public class GuiScreenModInfo extends GuiScreen | ||
382 | { | 445 | { |
383 | if (this.selectedMod != null) | 446 | if (this.selectedMod != null) |
384 | { | 447 | { |
385 | - int left = LEFT_EDGE + 12 + width; | ||
386 | - int right = this.width - 12; | 448 | + int left = LEFT_EDGE + MARGIN + width; |
449 | + int right = this.width - MARGIN; | ||
387 | 450 | ||
388 | glEnableClipping(left, right, PANEL_TOP, this.height - PANEL_BOTTOM - 28); | 451 | glEnableClipping(left, right, PANEL_TOP, this.height - PANEL_BOTTOM - 28); |
389 | this.selectedMod.drawInfo(mouseX, mouseY, partialTicks, left, PANEL_TOP, right - left); | 452 | this.selectedMod.drawInfo(mouseX, mouseY, partialTicks, left, PANEL_TOP, right - left); |
@@ -399,11 +462,14 @@ public class GuiScreenModInfo extends GuiScreen | @@ -399,11 +462,14 @@ public class GuiScreenModInfo extends GuiScreen | ||
399 | { | 462 | { |
400 | this.selectedMod = mod; | 463 | this.selectedMod = mod; |
401 | this.btnToggle.drawButton = false; | 464 | this.btnToggle.drawButton = false; |
465 | + this.btnConfig.drawButton = false; | ||
402 | 466 | ||
403 | if (this.selectedMod != null && this.selectedMod.canBeToggled()) | 467 | if (this.selectedMod != null && this.selectedMod.canBeToggled()) |
404 | { | 468 | { |
405 | this.btnToggle.drawButton = true; | 469 | this.btnToggle.drawButton = true; |
406 | this.btnToggle.displayString = this.selectedMod.willBeEnabled() ? "Disable mod" : "Enable mod"; | 470 | this.btnToggle.displayString = this.selectedMod.willBeEnabled() ? "Disable mod" : "Enable mod"; |
471 | + | ||
472 | + this.btnConfig.drawButton = this.configPanelManager.hasPanel(this.selectedMod.getModClass()); | ||
407 | } | 473 | } |
408 | } | 474 | } |
409 | 475 | ||
@@ -421,6 +487,11 @@ public class GuiScreenModInfo extends GuiScreen | @@ -421,6 +487,11 @@ public class GuiScreenModInfo extends GuiScreen | ||
421 | 487 | ||
422 | if (button.id == 1) | 488 | if (button.id == 1) |
423 | { | 489 | { |
490 | + this.openConfigPanel(); | ||
491 | + } | ||
492 | + | ||
493 | + if (button.id == 2) | ||
494 | + { | ||
424 | this.chkEnabled.checked = !this.chkEnabled.checked; | 495 | this.chkEnabled.checked = !this.chkEnabled.checked; |
425 | LiteLoader.getInstance().setDisplayModInfoScreenTab(this.chkEnabled.checked); | 496 | LiteLoader.getInstance().setDisplayModInfoScreenTab(this.chkEnabled.checked); |
426 | 497 | ||
@@ -437,6 +508,12 @@ public class GuiScreenModInfo extends GuiScreen | @@ -437,6 +508,12 @@ public class GuiScreenModInfo extends GuiScreen | ||
437 | @Override | 508 | @Override |
438 | protected void keyTyped(char keyChar, int keyCode) | 509 | protected void keyTyped(char keyChar, int keyCode) |
439 | { | 510 | { |
511 | + if (this.configPanel != null) | ||
512 | + { | ||
513 | + this.configPanel.keyPressed(keyChar, keyCode); | ||
514 | + return; | ||
515 | + } | ||
516 | + | ||
440 | if (keyCode == Keyboard.KEY_ESCAPE) | 517 | if (keyCode == Keyboard.KEY_ESCAPE) |
441 | { | 518 | { |
442 | this.onToggled(); | 519 | this.onToggled(); |
@@ -450,6 +527,12 @@ public class GuiScreenModInfo extends GuiScreen | @@ -450,6 +527,12 @@ public class GuiScreenModInfo extends GuiScreen | ||
450 | @Override | 527 | @Override |
451 | protected void mouseClicked(int mouseX, int mouseY, int button) | 528 | protected void mouseClicked(int mouseX, int mouseY, int button) |
452 | { | 529 | { |
530 | + if (this.configPanel != null) | ||
531 | + { | ||
532 | + this.configPanel.mousePressed(mouseX - LEFT_EDGE, mouseY, button); | ||
533 | + return; | ||
534 | + } | ||
535 | + | ||
453 | if (button == 0) | 536 | if (button == 0) |
454 | { | 537 | { |
455 | if (this.scrollBar.wasMouseOver()) | 538 | if (this.scrollBar.wasMouseOver()) |
@@ -459,9 +542,22 @@ public class GuiScreenModInfo extends GuiScreen | @@ -459,9 +542,22 @@ public class GuiScreenModInfo extends GuiScreen | ||
459 | 542 | ||
460 | if (mouseY > PANEL_TOP && mouseY < this.height - PANEL_BOTTOM) | 543 | if (mouseY > PANEL_TOP && mouseY < this.height - PANEL_BOTTOM) |
461 | { | 544 | { |
545 | + GuiModListEntry lastSelectedMod = this.selectedMod; | ||
546 | + | ||
462 | for (GuiModListEntry mod : this.mods) | 547 | for (GuiModListEntry mod : this.mods) |
463 | { | 548 | { |
464 | - if (mod.mouseWasOver()) this.selectMod(mod); | 549 | + if (mod.mouseWasOver()) |
550 | + { | ||
551 | + this.selectMod(mod); | ||
552 | + | ||
553 | + // handle double-click | ||
554 | + if (mod == lastSelectedMod && this.doubleClickTime > 0 && this.btnConfig.drawButton) | ||
555 | + { | ||
556 | + this.actionPerformed(this.btnConfig); | ||
557 | + } | ||
558 | + | ||
559 | + this.doubleClickTime = 5; | ||
560 | + } | ||
465 | } | 561 | } |
466 | } | 562 | } |
467 | } | 563 | } |
@@ -475,6 +571,16 @@ public class GuiScreenModInfo extends GuiScreen | @@ -475,6 +571,16 @@ public class GuiScreenModInfo extends GuiScreen | ||
475 | @Override | 571 | @Override |
476 | protected void mouseMovedOrUp(int mouseX, int mouseY, int button) | 572 | protected void mouseMovedOrUp(int mouseX, int mouseY, int button) |
477 | { | 573 | { |
574 | + if (this.configPanel != null) | ||
575 | + { | ||
576 | + if (button == -1) | ||
577 | + this.configPanel.mouseMoved(mouseX - LEFT_EDGE, mouseY); | ||
578 | + else | ||
579 | + this.configPanel.mouseReleased(mouseX - LEFT_EDGE, mouseY, button); | ||
580 | + | ||
581 | + return; | ||
582 | + } | ||
583 | + | ||
478 | if (button == 0) | 584 | if (button == 0) |
479 | { | 585 | { |
480 | this.scrollBar.setDragging(false); | 586 | this.scrollBar.setDragging(false); |
@@ -490,10 +596,12 @@ public class GuiScreenModInfo extends GuiScreen | @@ -490,10 +596,12 @@ public class GuiScreenModInfo extends GuiScreen | ||
490 | public void handleMouseInput() | 596 | public void handleMouseInput() |
491 | { | 597 | { |
492 | int mouseWheelDelta = Mouse.getEventDWheel(); | 598 | int mouseWheelDelta = Mouse.getEventDWheel(); |
493 | - | ||
494 | if (mouseWheelDelta != 0) | 599 | if (mouseWheelDelta != 0) |
495 | { | 600 | { |
496 | - this.scrollBar.offsetValue(-mouseWheelDelta / 8); | 601 | + if (this.configPanel != null) |
602 | + this.configPanel.mouseWheelScrolled(mouseWheelDelta); | ||
603 | + else | ||
604 | + this.scrollBar.offsetValue(-mouseWheelDelta / 8); | ||
497 | } | 605 | } |
498 | 606 | ||
499 | super.handleMouseInput(); | 607 | super.handleMouseInput(); |
@@ -550,6 +658,40 @@ public class GuiScreenModInfo extends GuiScreen | @@ -550,6 +658,40 @@ public class GuiScreenModInfo extends GuiScreen | ||
550 | } | 658 | } |
551 | 659 | ||
552 | /** | 660 | /** |
661 | + * Callback for the "config" button, display the config panel for the currently selected mod | ||
662 | + */ | ||
663 | + private void openConfigPanel() | ||
664 | + { | ||
665 | + if (this.selectedMod != null && this.selectedMod.getModClass() != null) | ||
666 | + { | ||
667 | + ConfigPanel panel = this.configPanelManager.getPanel(this.selectedMod.getModClass()); | ||
668 | + if (panel != null) | ||
669 | + { | ||
670 | + if (this.configPanel != null) | ||
671 | + { | ||
672 | + this.configPanel.onHidden(); | ||
673 | + } | ||
674 | + | ||
675 | + this.configPanel = new GuiConfigPanelContainer(this, this.mc, panel, this.selectedMod.getModInstance()); | ||
676 | + this.configPanel.setSize(this.width - LEFT_EDGE, this.height); | ||
677 | + this.configPanel.onShown(); | ||
678 | + } | ||
679 | + } | ||
680 | + } | ||
681 | + | ||
682 | + /* (non-Javadoc) | ||
683 | + * @see com.mumfrey.liteloader.modconfig.ConfigPanelHost#close() | ||
684 | + */ | ||
685 | + void closeConfigPanel(GuiConfigPanelContainer container) | ||
686 | + { | ||
687 | + if (this.configPanel != null && (container == null || this.configPanel == container)) | ||
688 | + { | ||
689 | + this.configPanel.onHidden(); | ||
690 | + this.configPanel = null; | ||
691 | + } | ||
692 | + } | ||
693 | + | ||
694 | + /** | ||
553 | * @param x | 695 | * @param x |
554 | * @param y | 696 | * @param y |
555 | * @param width | 697 | * @param width |
@@ -590,7 +732,7 @@ public class GuiScreenModInfo extends GuiScreen | @@ -590,7 +732,7 @@ public class GuiScreenModInfo extends GuiScreen | ||
590 | * @param yTop Top edge clip or -1 to not use this plane | 732 | * @param yTop Top edge clip or -1 to not use this plane |
591 | * @param yBottom Bottom edge clip or -1 to not use this plane | 733 | * @param yBottom Bottom edge clip or -1 to not use this plane |
592 | */ | 734 | */ |
593 | - private final static void glEnableClipping(int xLeft, int xRight, int yTop, int yBottom) | 735 | + final static void glEnableClipping(int xLeft, int xRight, int yTop, int yBottom) |
594 | { | 736 | { |
595 | // Apply left edge clipping if specified | 737 | // Apply left edge clipping if specified |
596 | if (xLeft != -1) | 738 | if (xLeft != -1) |
@@ -632,7 +774,7 @@ public class GuiScreenModInfo extends GuiScreen | @@ -632,7 +774,7 @@ public class GuiScreenModInfo extends GuiScreen | ||
632 | /** | 774 | /** |
633 | * Disable OpenGL clipping planes (uses planes 2, 3, 4 and 5) | 775 | * Disable OpenGL clipping planes (uses planes 2, 3, 4 and 5) |
634 | */ | 776 | */ |
635 | - private final static void glDisableClipping() | 777 | + final static void glDisableClipping() |
636 | { | 778 | { |
637 | glDisable(GL_CLIP_PLANE5); | 779 | glDisable(GL_CLIP_PLANE5); |
638 | glDisable(GL_CLIP_PLANE4); | 780 | glDisable(GL_CLIP_PLANE4); |
java/com/mumfrey/liteloader/modconfig/ConfigPanel.java
0 → 100644
1 | +package com.mumfrey.liteloader.modconfig; | ||
2 | + | ||
3 | +/** | ||
4 | + * Interface for mod config panels to implement | ||
5 | + * | ||
6 | + * @author Adam Mummery-Smith | ||
7 | + */ | ||
8 | +public interface ConfigPanel | ||
9 | +{ | ||
10 | + /** | ||
11 | + * Panels should return the text to display at the top of the config panel window | ||
12 | + */ | ||
13 | + public abstract String getPanelTitle(); | ||
14 | + | ||
15 | + /** | ||
16 | + * Get the height of the content area for scrolling purposes, return -1 to disable scrolling | ||
17 | + */ | ||
18 | + public abstract int getContentHeight(); | ||
19 | + | ||
20 | + /** | ||
21 | + * Called when the panel is displayed, initialise the panel (read settings, etc) | ||
22 | + * | ||
23 | + * @param host panel host | ||
24 | + */ | ||
25 | + public abstract void onPanelShown(ConfigPanelHost host); | ||
26 | + | ||
27 | + /** | ||
28 | + * Called when the window is resized whilst the panel is active | ||
29 | + * | ||
30 | + * @param host panel host | ||
31 | + */ | ||
32 | + public abstract void onPanelResize(ConfigPanelHost host); | ||
33 | + | ||
34 | + /** | ||
35 | + * Called when the panel is closed, panel should save settings | ||
36 | + */ | ||
37 | + public abstract void onPanelHidden(); | ||
38 | + | ||
39 | + /** | ||
40 | + * Called every tick | ||
41 | + */ | ||
42 | + public abstract void onTick(ConfigPanelHost host); | ||
43 | + | ||
44 | + /** | ||
45 | + * Draw the configuration panel | ||
46 | + * | ||
47 | + * @param host | ||
48 | + * @param mouseX | ||
49 | + * @param mouseY | ||
50 | + * @param partialTicks | ||
51 | + */ | ||
52 | + public abstract void drawPanel(ConfigPanelHost host, int mouseX, int mouseY, float partialTicks); | ||
53 | + | ||
54 | + /** | ||
55 | + * Called when a mouse button is pressed | ||
56 | + * | ||
57 | + * @param host | ||
58 | + * @param mouseX | ||
59 | + * @param mouseY | ||
60 | + * @param mouseButton | ||
61 | + */ | ||
62 | + public abstract void mousePressed(ConfigPanelHost host, int mouseX, int mouseY, int mouseButton); | ||
63 | + | ||
64 | + /** | ||
65 | + * Called when a mouse button is released | ||
66 | + * | ||
67 | + * @param host | ||
68 | + * @param mouseX | ||
69 | + * @param mouseY | ||
70 | + * @param mouseButton | ||
71 | + */ | ||
72 | + public abstract void mouseReleased(ConfigPanelHost host, int mouseX, int mouseY, int mouseButton); | ||
73 | + | ||
74 | + /** | ||
75 | + * Called when the mouse is moved | ||
76 | + * | ||
77 | + * @param host | ||
78 | + * @param mouseX | ||
79 | + * @param mouseY | ||
80 | + */ | ||
81 | + public abstract void mouseMoved(ConfigPanelHost host, int mouseX, int mouseY); | ||
82 | + | ||
83 | + /** | ||
84 | + * Called when a key is pressed | ||
85 | + * | ||
86 | + * @param host | ||
87 | + * @param keyChar | ||
88 | + * @param keyCode | ||
89 | + */ | ||
90 | + public abstract void keyPressed(ConfigPanelHost host, char keyChar, int keyCode); | ||
91 | +} |
java/com/mumfrey/liteloader/modconfig/ConfigPanelHost.java
0 → 100644
1 | +package com.mumfrey.liteloader.modconfig; | ||
2 | + | ||
3 | +import com.mumfrey.liteloader.LiteMod; | ||
4 | + | ||
5 | +/** | ||
6 | + * Interface for object which can host configuration panels | ||
7 | + * | ||
8 | + * @author Adam Mummery-Smith | ||
9 | + */ | ||
10 | +public interface ConfigPanelHost | ||
11 | +{ | ||
12 | + /** | ||
13 | + * Get the mod instance which owns the panel | ||
14 | + */ | ||
15 | + public abstract <ModClass extends LiteMod> ModClass getMod(); | ||
16 | + | ||
17 | + /** | ||
18 | + * Get the width of the configuration panel area | ||
19 | + */ | ||
20 | + public abstract int getWidth(); | ||
21 | + | ||
22 | + /** | ||
23 | + * Get the height of the configuration panel area | ||
24 | + */ | ||
25 | + public abstract int getHeight(); | ||
26 | + | ||
27 | + /** | ||
28 | + * Notify the panel host that the panel wishes to close | ||
29 | + */ | ||
30 | + public abstract void close(); | ||
31 | + | ||
32 | + /** | ||
33 | + * Notify the panel host that the panel wishes to advance to the next panel | ||
34 | + */ | ||
35 | +// public abstract void next(); | ||
36 | + | ||
37 | + /** | ||
38 | + * Notify the panel host that the panel wishes to go back to the previous panel | ||
39 | + */ | ||
40 | +// public abstract void previous(); | ||
41 | +} |
java/com/mumfrey/liteloader/modconfig/ConfigPanelManager.java
0 → 100644
1 | +package com.mumfrey.liteloader.modconfig; | ||
2 | + | ||
3 | +import java.util.HashMap; | ||
4 | +import java.util.Map; | ||
5 | + | ||
6 | +import com.mumfrey.liteloader.Configurable; | ||
7 | +import com.mumfrey.liteloader.LiteMod; | ||
8 | + | ||
9 | +/** | ||
10 | + * Registry where we keep the mod config panel classes | ||
11 | + * | ||
12 | + * @author Adam Mummery-Smith | ||
13 | + */ | ||
14 | +public class ConfigPanelManager | ||
15 | +{ | ||
16 | + /** | ||
17 | + * Mod config panel classes | ||
18 | + */ | ||
19 | + private Map<Class<? extends LiteMod>, Class<? extends ConfigPanel>> configPanels = new HashMap<Class<? extends LiteMod>, Class<? extends ConfigPanel>>(); | ||
20 | + | ||
21 | + /** | ||
22 | + * Register a mod, adds the config panel class to the map if the mod implements Configurable | ||
23 | + */ | ||
24 | + public void registerMod(LiteMod mod) | ||
25 | + { | ||
26 | + if (mod instanceof Configurable) | ||
27 | + { | ||
28 | + Class<? extends ConfigPanel> panelClass = ((Configurable)mod).getConfigPanelClass(); | ||
29 | + if (panelClass != null) this.configPanels.put(mod.getClass(), panelClass); | ||
30 | + } | ||
31 | + } | ||
32 | + | ||
33 | + /** | ||
34 | + * Check whether a config panel is available for the specified class | ||
35 | + * | ||
36 | + * @param modClass | ||
37 | + * @return | ||
38 | + */ | ||
39 | + public boolean hasPanel(Class<? extends LiteMod> modClass) | ||
40 | + { | ||
41 | + return modClass != null && this.configPanels.containsKey(modClass); | ||
42 | + } | ||
43 | + | ||
44 | + /** | ||
45 | + * Instance a new config panel for the specified mod class if one is available | ||
46 | + * | ||
47 | + * @param modClass | ||
48 | + * @return | ||
49 | + */ | ||
50 | + public ConfigPanel getPanel(Class<? extends LiteMod> modClass) | ||
51 | + { | ||
52 | + if (modClass != null && this.configPanels.containsKey(modClass)) | ||
53 | + { | ||
54 | + try | ||
55 | + { | ||
56 | + return this.configPanels.get(modClass).newInstance(); | ||
57 | + } | ||
58 | + catch (InstantiationException ex) {} | ||
59 | + catch (IllegalAccessException ex) {} | ||
60 | + | ||
61 | + // If instantiation fails, remove the panel | ||
62 | + this.configPanels.remove(modClass); | ||
63 | + } | ||
64 | + | ||
65 | + return null; | ||
66 | + } | ||
67 | +} |
java/com/mumfrey/liteloader/permissions/PermissionsManagerClient.java
@@ -14,6 +14,7 @@ import net.minecraft.src.Minecraft; | @@ -14,6 +14,7 @@ import net.minecraft.src.Minecraft; | ||
14 | import net.minecraft.src.NetHandler; | 14 | import net.minecraft.src.NetHandler; |
15 | import net.minecraft.src.Packet1Login; | 15 | import net.minecraft.src.Packet1Login; |
16 | 16 | ||
17 | +import com.mumfrey.liteloader.LiteMod; | ||
17 | import com.mumfrey.liteloader.Permissible; | 18 | import com.mumfrey.liteloader.Permissible; |
18 | import com.mumfrey.liteloader.PluginChannelListener; | 19 | import com.mumfrey.liteloader.PluginChannelListener; |
19 | import com.mumfrey.liteloader.core.PluginChannels; | 20 | import com.mumfrey.liteloader.core.PluginChannels; |
@@ -127,6 +128,19 @@ public class PermissionsManagerClient implements PermissionsManager, PluginChann | @@ -127,6 +128,19 @@ public class PermissionsManagerClient implements PermissionsManager, PluginChann | ||
127 | ServerPermissions modPermissions = this.serverPermissions.get(modName); | 128 | ServerPermissions modPermissions = this.serverPermissions.get(modName); |
128 | return modPermissions != null ? modPermissions.getReplicationTime() : 0; | 129 | return modPermissions != null ? modPermissions.getReplicationTime() : 0; |
129 | } | 130 | } |
131 | + | ||
132 | + /** | ||
133 | + * Register a new mod, if permissible | ||
134 | + * | ||
135 | + * @param mod | ||
136 | + */ | ||
137 | + public void registerMod(LiteMod mod) | ||
138 | + { | ||
139 | + if (mod instanceof Permissible) | ||
140 | + { | ||
141 | + this.registerPermissible((Permissible)mod); | ||
142 | + } | ||
143 | + } | ||
130 | 144 | ||
131 | /* (non-Javadoc) | 145 | /* (non-Javadoc) |
132 | * @see net.eq2online.permissions.PermissionsManager#registerListener(net.eq2online.permissions.PermissionsListener) | 146 | * @see net.eq2online.permissions.PermissionsManager#registerListener(net.eq2online.permissions.PermissionsListener) |