Commit 10a436e98aa90a7b587c28d72c81b2dbae8e6b23
1 parent
3e896077
LiteLoader 1.6.4_02 - experimental - added basic mod list gui and enable/disable mod functionality
Showing
9 changed files
with
1146 additions
and
11 deletions
java/com/mumfrey/liteloader/core/EnabledModsList.java
@@ -40,6 +40,11 @@ public class EnabledModsList | @@ -40,6 +40,11 @@ public class EnabledModsList | ||
40 | private transient Boolean defaultEnabledValue = Boolean.TRUE; | 40 | private transient Boolean defaultEnabledValue = Boolean.TRUE; |
41 | private transient boolean allowSave = true; | 41 | private transient boolean allowSave = true; |
42 | 42 | ||
43 | + /** | ||
44 | + * JSON file containing the list of enabled/disabled mods by profile | ||
45 | + */ | ||
46 | + private transient File enabledModsFile = null; | ||
47 | + | ||
43 | private EnabledModsList() | 48 | private EnabledModsList() |
44 | { | 49 | { |
45 | // Private because we are always instanced by the static createFrom() method below | 50 | // Private because we are always instanced by the static createFrom() method below |
@@ -151,6 +156,7 @@ public class EnabledModsList | @@ -151,6 +156,7 @@ public class EnabledModsList | ||
151 | { | 156 | { |
152 | reader = new FileReader(file); | 157 | reader = new FileReader(file); |
153 | EnabledModsList instance = gson.fromJson(reader, EnabledModsList.class); | 158 | EnabledModsList instance = gson.fromJson(reader, EnabledModsList.class); |
159 | + instance.setEnabledModsFile(file); | ||
154 | return instance; | 160 | return instance; |
155 | } | 161 | } |
156 | catch (Exception ex) | 162 | catch (Exception ex) |
@@ -171,7 +177,9 @@ public class EnabledModsList | @@ -171,7 +177,9 @@ public class EnabledModsList | ||
171 | } | 177 | } |
172 | } | 178 | } |
173 | 179 | ||
174 | - return new EnabledModsList(); | 180 | + EnabledModsList instance = new EnabledModsList(); |
181 | + instance.setEnabledModsFile(file); | ||
182 | + return instance; | ||
175 | } | 183 | } |
176 | 184 | ||
177 | /** | 185 | /** |
@@ -207,4 +215,33 @@ public class EnabledModsList | @@ -207,4 +215,33 @@ public class EnabledModsList | ||
207 | } | 215 | } |
208 | } | 216 | } |
209 | } | 217 | } |
218 | + | ||
219 | + /** | ||
220 | + * Save to the file we were loaded from | ||
221 | + */ | ||
222 | + public void save() | ||
223 | + { | ||
224 | + if (this.enabledModsFile != null) | ||
225 | + { | ||
226 | + this.saveTo(this.enabledModsFile); | ||
227 | + } | ||
228 | + } | ||
229 | + | ||
230 | + /** | ||
231 | + * Get whether saving this list is allowed | ||
232 | + */ | ||
233 | + public boolean saveAllowed() | ||
234 | + { | ||
235 | + return this.allowSave; | ||
236 | + } | ||
237 | + | ||
238 | + public File getEnabledModsFile() | ||
239 | + { | ||
240 | + return this.enabledModsFile; | ||
241 | + } | ||
242 | + | ||
243 | + public void setEnabledModsFile(File enabledModsFile) | ||
244 | + { | ||
245 | + this.enabledModsFile = enabledModsFile; | ||
246 | + } | ||
210 | } | 247 | } |
java/com/mumfrey/liteloader/core/Events.java
@@ -3,6 +3,8 @@ package com.mumfrey.liteloader.core; | @@ -3,6 +3,8 @@ package com.mumfrey.liteloader.core; | ||
3 | import java.util.LinkedList; | 3 | import java.util.LinkedList; |
4 | import java.util.logging.Level; | 4 | import java.util.logging.Level; |
5 | 5 | ||
6 | +import org.lwjgl.input.Mouse; | ||
7 | + | ||
6 | import net.minecraft.src.*; | 8 | import net.minecraft.src.*; |
7 | 9 | ||
8 | import com.mumfrey.liteloader.*; | 10 | import com.mumfrey.liteloader.*; |
@@ -223,7 +225,6 @@ public class Events implements IPlayerUsage | @@ -223,7 +225,6 @@ public class Events implements IPlayerUsage | ||
223 | this.pluginChannels.addPluginChannelListener((PluginChannelListener)listener); | 225 | this.pluginChannels.addPluginChannelListener((PluginChannelListener)listener); |
224 | } | 226 | } |
225 | } | 227 | } |
226 | - | ||
227 | 228 | ||
228 | /** | 229 | /** |
229 | * Initialise mod hooks | 230 | * Initialise mod hooks |
@@ -448,6 +449,10 @@ public class Events implements IPlayerUsage | @@ -448,6 +449,10 @@ public class Events implements IPlayerUsage | ||
448 | */ | 449 | */ |
449 | public void onRender() | 450 | public void onRender() |
450 | { | 451 | { |
452 | + this.currentResolution = new ScaledResolution(this.minecraft.gameSettings, this.minecraft.displayWidth, this.minecraft.displayHeight); | ||
453 | + this.screenWidth = this.currentResolution.getScaledWidth(); | ||
454 | + this.screenHeight = this.currentResolution.getScaledHeight(); | ||
455 | + | ||
451 | this.loader.onRender(); | 456 | this.loader.onRender(); |
452 | 457 | ||
453 | for (RenderListener renderListener : this.renderListeners) | 458 | for (RenderListener renderListener : this.renderListeners) |
@@ -521,10 +526,6 @@ public class Events implements IPlayerUsage | @@ -521,10 +526,6 @@ public class Events implements IPlayerUsage | ||
521 | */ | 526 | */ |
522 | public void onRenderHUD() | 527 | public void onRenderHUD() |
523 | { | 528 | { |
524 | - this.currentResolution = new ScaledResolution(this.minecraft.gameSettings, this.minecraft.displayWidth, this.minecraft.displayHeight); | ||
525 | - this.screenWidth = this.currentResolution.getScaledWidth(); | ||
526 | - this.screenHeight = this.currentResolution.getScaledHeight(); | ||
527 | - | ||
528 | if (!this.minecraft.gameSettings.hideGUI || this.minecraft.currentScreen != null) | 529 | if (!this.minecraft.gameSettings.hideGUI || this.minecraft.currentScreen != null) |
529 | { | 530 | { |
530 | for (HUDRenderListener hudRenderListener : this.hudRenderListeners) | 531 | for (HUDRenderListener hudRenderListener : this.hudRenderListeners) |
@@ -583,6 +584,10 @@ public class Events implements IPlayerUsage | @@ -583,6 +584,10 @@ public class Events implements IPlayerUsage | ||
583 | { | 584 | { |
584 | this.loader.onTick(partialTicks, inGame); | 585 | this.loader.onTick(partialTicks, inGame); |
585 | } | 586 | } |
587 | + | ||
588 | + int mouseX = Mouse.getX() * this.screenWidth / this.minecraft.displayWidth; | ||
589 | + int mouseY = this.screenHeight - Mouse.getY() * this.screenHeight / this.minecraft.displayHeight - 1; | ||
590 | + this.loader.postRender(mouseX, mouseY, partialTicks); | ||
586 | 591 | ||
587 | // Iterate tickable mods | 592 | // Iterate tickable mods |
588 | for (Tickable tickable : this.tickListeners) | 593 | for (Tickable tickable : this.tickListeners) |
java/com/mumfrey/liteloader/core/LiteLoader.java
@@ -19,9 +19,12 @@ import java.util.logging.Logger; | @@ -19,9 +19,12 @@ import java.util.logging.Logger; | ||
19 | 19 | ||
20 | import javax.activity.InvalidActivityException; | 20 | import javax.activity.InvalidActivityException; |
21 | 21 | ||
22 | +import org.lwjgl.input.Keyboard; | ||
23 | + | ||
22 | import net.minecraft.launchwrapper.LaunchClassLoader; | 24 | import net.minecraft.launchwrapper.LaunchClassLoader; |
23 | import net.minecraft.src.CrashReport; | 25 | import net.minecraft.src.CrashReport; |
24 | import net.minecraft.src.GuiControls; | 26 | import net.minecraft.src.GuiControls; |
27 | +import net.minecraft.src.GuiMainMenu; | ||
25 | import net.minecraft.src.GuiScreen; | 28 | import net.minecraft.src.GuiScreen; |
26 | import net.minecraft.src.KeyBinding; | 29 | import net.minecraft.src.KeyBinding; |
27 | import net.minecraft.src.Minecraft; | 30 | import net.minecraft.src.Minecraft; |
@@ -35,6 +38,7 @@ import com.mumfrey.liteloader.*; | @@ -35,6 +38,7 @@ import com.mumfrey.liteloader.*; | ||
35 | import com.mumfrey.liteloader.crashreport.CallableLiteLoaderBrand; | 38 | import com.mumfrey.liteloader.crashreport.CallableLiteLoaderBrand; |
36 | import com.mumfrey.liteloader.crashreport.CallableLiteLoaderMods; | 39 | import com.mumfrey.liteloader.crashreport.CallableLiteLoaderMods; |
37 | import com.mumfrey.liteloader.gui.GuiControlsPaginated; | 40 | import com.mumfrey.liteloader.gui.GuiControlsPaginated; |
41 | +import com.mumfrey.liteloader.gui.GuiScreenModInfo; | ||
38 | import com.mumfrey.liteloader.permissions.PermissionsManagerClient; | 42 | import com.mumfrey.liteloader.permissions.PermissionsManagerClient; |
39 | import com.mumfrey.liteloader.util.PrivateFields; | 43 | import com.mumfrey.liteloader.util.PrivateFields; |
40 | 44 | ||
@@ -196,6 +200,23 @@ public final class LiteLoader | @@ -196,6 +200,23 @@ public final class LiteLoader | ||
196 | private Map<KeyBinding, Integer> storedModKeyBindings = new HashMap<KeyBinding, Integer>(); | 200 | private Map<KeyBinding, Integer> storedModKeyBindings = new HashMap<KeyBinding, Integer>(); |
197 | 201 | ||
198 | /** | 202 | /** |
203 | + * Setting which determines whether we show the "mod info" screen tab in the main menu | ||
204 | + */ | ||
205 | + private boolean displayModInfoScreenTab = true; | ||
206 | + | ||
207 | + /** | ||
208 | + * Override for the "mod info" tab setting, so that mods which want to handle the mod info themselves | ||
209 | + * can temporarily disable the function without having to change the underlying property | ||
210 | + */ | ||
211 | + private boolean hideModInfoScreenTab = false; | ||
212 | + | ||
213 | + /** | ||
214 | + * Active "mod info" screen, drawn as an overlay when in the main menu and made the active screen if | ||
215 | + * the user clicks the tab | ||
216 | + */ | ||
217 | + private GuiScreenModInfo modInfoScreen; | ||
218 | + | ||
219 | + /** | ||
199 | * Pre-init routine, called using reflection by the tweaker | 220 | * Pre-init routine, called using reflection by the tweaker |
200 | * | 221 | * |
201 | * @param gameDirectory Game directory passed to the tweaker | 222 | * @param gameDirectory Game directory passed to the tweaker |
@@ -295,6 +316,7 @@ public final class LiteLoader | @@ -295,6 +316,7 @@ public final class LiteLoader | ||
295 | 316 | ||
296 | this.paginateControls = this.bootstrap.getAndStoreBooleanProperty("controls.pages", true); | 317 | this.paginateControls = this.bootstrap.getAndStoreBooleanProperty("controls.pages", true); |
297 | this.inhibitSoundManagerReload = this.bootstrap.getAndStoreBooleanProperty("soundManagerFix", true); | 318 | this.inhibitSoundManagerReload = this.bootstrap.getAndStoreBooleanProperty("soundManagerFix", true); |
319 | + this.displayModInfoScreenTab = this.bootstrap.getAndStoreBooleanProperty("modInfoScreen", true); | ||
298 | 320 | ||
299 | this.enumerator.discoverModClasses(); | 321 | this.enumerator.discoverModClasses(); |
300 | } | 322 | } |
@@ -328,7 +350,7 @@ public final class LiteLoader | @@ -328,7 +350,7 @@ public final class LiteLoader | ||
328 | this.events.initHooks(); | 350 | this.events.initHooks(); |
329 | this.startupComplete = true; | 351 | this.startupComplete = true; |
330 | 352 | ||
331 | - this.enabledModsList.saveTo(this.enabledModsFile); | 353 | + this.enabledModsList.save(); |
332 | this.bootstrap.writeProperties(); | 354 | this.bootstrap.writeProperties(); |
333 | } | 355 | } |
334 | 356 | ||
@@ -880,6 +902,33 @@ public final class LiteLoader | @@ -880,6 +902,33 @@ public final class LiteLoader | ||
880 | } | 902 | } |
881 | } | 903 | } |
882 | } | 904 | } |
905 | + | ||
906 | + /** | ||
907 | + * @param partialTicks | ||
908 | + */ | ||
909 | + void postRender(int mouseX, int mouseY, float partialTicks) | ||
910 | + { | ||
911 | + if (this.minecraft.currentScreen instanceof GuiMainMenu && this.displayModInfoScreenTab && !this.hideModInfoScreenTab) | ||
912 | + { | ||
913 | + // If we're at the main menu, prepare the overlay | ||
914 | + if (this.modInfoScreen == null || this.modInfoScreen.getMenu() != this.minecraft.currentScreen) | ||
915 | + { | ||
916 | + this.modInfoScreen = new GuiScreenModInfo(this.minecraft, (GuiMainMenu)this.minecraft.currentScreen, this, this.enabledModsList); | ||
917 | + } | ||
918 | + | ||
919 | + this.modInfoScreen.drawScreen(mouseX, mouseY, partialTicks); | ||
920 | + } | ||
921 | + else if (this.minecraft.currentScreen != this.modInfoScreen && this.modInfoScreen != null) | ||
922 | + { | ||
923 | + // If we're in any other screen, kill the overlay | ||
924 | + this.modInfoScreen.release(); | ||
925 | + this.modInfoScreen = null; | ||
926 | + } | ||
927 | + else if (this.minecraft.currentScreen instanceof GuiMainMenu && Keyboard.isKeyDown(Keyboard.KEY_LCONTROL) && Keyboard.isKeyDown(Keyboard.KEY_LSHIFT) && Keyboard.isKeyDown(Keyboard.KEY_TAB)) | ||
928 | + { | ||
929 | + this.minecraft.displayGuiScreen(new GuiScreenModInfo(this.minecraft, (GuiMainMenu)this.minecraft.currentScreen, this, this.enabledModsList)); | ||
930 | + } | ||
931 | + } | ||
883 | 932 | ||
884 | /** | 933 | /** |
885 | * @param partialTicks | 934 | * @param partialTicks |
@@ -891,6 +940,11 @@ public final class LiteLoader | @@ -891,6 +940,11 @@ public final class LiteLoader | ||
891 | this.permissionsManager.onTick(this.minecraft, partialTicks, inGame); | 940 | this.permissionsManager.onTick(this.minecraft, partialTicks, inGame); |
892 | 941 | ||
893 | this.checkAndStoreKeyBindings(); | 942 | this.checkAndStoreKeyBindings(); |
943 | + | ||
944 | + if (this.modInfoScreen != null && this.minecraft.currentScreen != this.modInfoScreen) | ||
945 | + { | ||
946 | + this.modInfoScreen.updateScreen(); | ||
947 | + } | ||
894 | } | 948 | } |
895 | 949 | ||
896 | /** | 950 | /** |
@@ -963,16 +1017,40 @@ public final class LiteLoader | @@ -963,16 +1017,40 @@ public final class LiteLoader | ||
963 | } | 1017 | } |
964 | catch (IOException ex) {} | 1018 | catch (IOException ex) {} |
965 | } | 1019 | } |
966 | - | 1020 | + |
1021 | + /** | ||
1022 | + * Set the "mod info" screen tab to hidden, regardless of the property setting | ||
1023 | + */ | ||
1024 | + public void hideModInfoScreenTab() | ||
1025 | + { | ||
1026 | + this.hideModInfoScreenTab = true; | ||
1027 | + } | ||
1028 | + | ||
1029 | + /** | ||
1030 | + * Set whether the "mod info" screen tab should be shown in the main menu | ||
1031 | + */ | ||
1032 | + public void setDisplayModInfoScreenTab(boolean show) | ||
1033 | + { | ||
1034 | + this.displayModInfoScreenTab = show; | ||
1035 | + this.bootstrap.setBooleanProperty("modInfoScreen", show); | ||
1036 | + this.bootstrap.writeProperties(); | ||
1037 | + } | ||
1038 | + | ||
1039 | + /** | ||
1040 | + * Get whether the "mod info" screen tab is shown in the main menu | ||
1041 | + */ | ||
1042 | + public boolean getDisplayModInfoScreenTab() | ||
1043 | + { | ||
1044 | + return this.displayModInfoScreenTab; | ||
1045 | + } | ||
1046 | + | ||
967 | private static void logInfo(String string, Object... args) | 1047 | private static void logInfo(String string, Object... args) |
968 | { | 1048 | { |
969 | -// System.out.println("<INFO> " + String.format(string, args)); | ||
970 | LiteLoader.logger.info(String.format(string, args)); | 1049 | LiteLoader.logger.info(String.format(string, args)); |
971 | } | 1050 | } |
972 | 1051 | ||
973 | private static void logWarning(String string, Object... args) | 1052 | private static void logWarning(String string, Object... args) |
974 | { | 1053 | { |
975 | -// System.out.println("<WARN> " + String.format(string, args)); | ||
976 | LiteLoader.logger.warning(String.format(string, args)); | 1054 | LiteLoader.logger.warning(String.format(string, args)); |
977 | } | 1055 | } |
978 | 1056 |
java/com/mumfrey/liteloader/core/LiteLoaderBootstrap.java
@@ -40,7 +40,7 @@ class LiteLoaderBootstrap implements ILoaderBootstrap | @@ -40,7 +40,7 @@ class LiteLoaderBootstrap implements ILoaderBootstrap | ||
40 | /** | 40 | /** |
41 | * Liteloader version | 41 | * Liteloader version |
42 | */ | 42 | */ |
43 | - public static final LiteLoaderVersion VERSION = LiteLoaderVersion.MC_1_6_4_R1; | 43 | + public static final LiteLoaderVersion VERSION = LiteLoaderVersion.MC_1_6_4_R2; |
44 | 44 | ||
45 | /** | 45 | /** |
46 | * Local logger reference | 46 | * Local logger reference |
java/com/mumfrey/liteloader/gui/GuiCheckbox.java
0 → 100644
1 | +package com.mumfrey.liteloader.gui; | ||
2 | + | ||
3 | +import static org.lwjgl.opengl.GL11.*; | ||
4 | + | ||
5 | +import net.minecraft.src.GuiButton; | ||
6 | +import net.minecraft.src.Minecraft; | ||
7 | + | ||
8 | +/** | ||
9 | + * Super-simple implementation of a checkbox control | ||
10 | + * | ||
11 | + * @author Adam Mummery-Smith | ||
12 | + */ | ||
13 | +public class GuiCheckbox extends GuiButton | ||
14 | +{ | ||
15 | + public boolean checked; | ||
16 | + | ||
17 | + public GuiCheckbox(int controlId, int xPosition, int yPosition, String displayString) | ||
18 | + { | ||
19 | + super(controlId, xPosition, yPosition, 200, 12, displayString); | ||
20 | + } | ||
21 | + | ||
22 | + @Override | ||
23 | + public void drawButton(Minecraft minecraft, int mouseX, int mouseY) | ||
24 | + { | ||
25 | + if (this.drawButton) | ||
26 | + { | ||
27 | + minecraft.getTextureManager().bindTexture(GuiScreenModInfo.aboutTextureResource); | ||
28 | + glColor4f(1.0F, 1.0F, 1.0F, 1.0F); | ||
29 | + this.field_82253_i = mouseX >= this.xPosition && mouseY >= this.yPosition && mouseX < this.xPosition + this.width && mouseY < this.yPosition + this.height; | ||
30 | + | ||
31 | + this.drawTexturedModalRect(this.xPosition, this.yPosition, this.checked ? 134 : 122, 80, 12, 12); | ||
32 | + this.mouseDragged(minecraft, mouseX, mouseY); | ||
33 | + | ||
34 | + int colour = 0xE0E0E0; | ||
35 | + if (!this.enabled) colour = 0xA0A0A0; | ||
36 | + else if (this.field_82253_i) colour = 0xFFFFA0; | ||
37 | + | ||
38 | + this.drawString(minecraft.fontRenderer, this.displayString, this.xPosition + 16, this.yPosition + 2, colour); | ||
39 | + } | ||
40 | + } | ||
41 | +} |
java/com/mumfrey/liteloader/gui/GuiModListEntry.java
0 → 100644
1 | +package com.mumfrey.liteloader.gui; | ||
2 | + | ||
3 | +import com.mumfrey.liteloader.LiteMod; | ||
4 | +import com.mumfrey.liteloader.core.ClassPathMod; | ||
5 | +import com.mumfrey.liteloader.core.EnabledModsList; | ||
6 | +import com.mumfrey.liteloader.core.LiteLoader; | ||
7 | +import com.mumfrey.liteloader.core.ModFile; | ||
8 | + | ||
9 | +import net.minecraft.src.FontRenderer; | ||
10 | +import net.minecraft.src.Gui; | ||
11 | + | ||
12 | +/** | ||
13 | + * Represents a mod in the mod info screen, keeps track of mod information and provides methods | ||
14 | + * for displaying the mod in the mod list and drawing the selected mod info | ||
15 | + * | ||
16 | + * @author Adam Mummery-Smith | ||
17 | + */ | ||
18 | +public class GuiModListEntry extends Gui | ||
19 | +{ | ||
20 | + private static final int PANEL_HEIGHT = 32; | ||
21 | + private static final int PANEL_SPACING = 4; | ||
22 | + | ||
23 | + /** | ||
24 | + * Enabled mods list, keep a reference so that we can toggle mod enablement when required | ||
25 | + */ | ||
26 | + private EnabledModsList enabledModsList; | ||
27 | + | ||
28 | + /** | ||
29 | + * For text display | ||
30 | + */ | ||
31 | + private FontRenderer fontRenderer; | ||
32 | + | ||
33 | + /** | ||
34 | + * The metadata name (id) of the mod, used as the enablement/disablement key | ||
35 | + */ | ||
36 | + private String metaName; | ||
37 | + | ||
38 | + /** | ||
39 | + * Display name of the mod, disabled mods use the file/folder name | ||
40 | + */ | ||
41 | + private String name; | ||
42 | + | ||
43 | + /** | ||
44 | + * Mod version string | ||
45 | + */ | ||
46 | + private String version; | ||
47 | + | ||
48 | + /** | ||
49 | + * Mod author, from the metadata | ||
50 | + */ | ||
51 | + private String author; | ||
52 | + | ||
53 | + /** | ||
54 | + * Mod URL, from the metadata | ||
55 | + */ | ||
56 | + private String url; | ||
57 | + | ||
58 | + /** | ||
59 | + * Mod description, from metadata | ||
60 | + */ | ||
61 | + private String description; | ||
62 | + | ||
63 | + /** | ||
64 | + * Whether the mod is currently active | ||
65 | + */ | ||
66 | + private boolean enabled; | ||
67 | + | ||
68 | + /** | ||
69 | + * Whether the mod can be toggled, not all mods support this, eg. internal mods | ||
70 | + */ | ||
71 | + private boolean canBeToggled; | ||
72 | + | ||
73 | + /** | ||
74 | + * Whether the mod WILL be enabled on the next startup, if the mod is active and has been disabled this | ||
75 | + * will be false, and if it's currently disabled by has been toggled then it will be true | ||
76 | + */ | ||
77 | + private boolean willBeEnabled; | ||
78 | + | ||
79 | + /** | ||
80 | + * True if the mouse was over this mod on the last render | ||
81 | + */ | ||
82 | + private boolean mouseOver; | ||
83 | + | ||
84 | + /** | ||
85 | + * Mod list entry for an ACTIVE mod | ||
86 | + * | ||
87 | + * @param loader | ||
88 | + * @param enabledMods | ||
89 | + * @param fontRenderer | ||
90 | + * @param mod | ||
91 | + */ | ||
92 | + GuiModListEntry(LiteLoader loader, EnabledModsList enabledMods, FontRenderer fontRenderer, LiteMod mod) | ||
93 | + { | ||
94 | + this.enabledModsList = enabledMods; | ||
95 | + this.fontRenderer = fontRenderer; | ||
96 | + this.metaName = loader.getModMetaName(mod.getClass()); | ||
97 | + this.name = mod.getName(); | ||
98 | + this.version = mod.getVersion(); | ||
99 | + this.author = loader.getModMetaData(mod.getClass(), "author", "Unknown"); | ||
100 | + this.url = loader.getModMetaData(mod.getClass(), "url", null); | ||
101 | + this.description = loader.getModMetaData(mod.getClass(), "description", ""); | ||
102 | + this.enabled = true; | ||
103 | + this.canBeToggled = this.metaName != null && this.enabledModsList.saveAllowed(); | ||
104 | + this.willBeEnabled = true; | ||
105 | + } | ||
106 | + | ||
107 | + /** | ||
108 | + * Mod list entry for a currently disabled mod | ||
109 | + * | ||
110 | + * @param loader | ||
111 | + * @param enabledMods | ||
112 | + * @param fontRenderer | ||
113 | + * @param file | ||
114 | + */ | ||
115 | + GuiModListEntry(LiteLoader loader, EnabledModsList enabledMods, FontRenderer fontRenderer, ModFile file) | ||
116 | + { | ||
117 | + this.enabledModsList = enabledMods; | ||
118 | + this.fontRenderer = fontRenderer; | ||
119 | + this.metaName = file.getModName().toLowerCase(); | ||
120 | + this.name = file instanceof ClassPathMod ? file.getModName() : file.getName(); | ||
121 | + this.version = file.getVersion(); | ||
122 | + this.author = file.getMetaValue("author", "Unknown"); | ||
123 | + this.url = file.getMetaValue("url", null); | ||
124 | + this.description = file.getMetaValue("description", ""); | ||
125 | + this.enabled = false; | ||
126 | + this.canBeToggled = this.enabledModsList.saveAllowed(); | ||
127 | + this.willBeEnabled = enabledMods.isEnabled(loader.getProfile(), this.metaName); | ||
128 | + } | ||
129 | + | ||
130 | + /** | ||
131 | + * Draw this list entry as a list item | ||
132 | + * | ||
133 | + * @param mouseX | ||
134 | + * @param mouseY | ||
135 | + * @param partialTicks | ||
136 | + * @param xPosition | ||
137 | + * @param yPosition | ||
138 | + * @param width | ||
139 | + * @param selected | ||
140 | + * @return | ||
141 | + */ | ||
142 | + public int drawListEntry(int mouseX, int mouseY, float partialTicks, int xPosition, int yPosition, int width, boolean selected) | ||
143 | + { | ||
144 | + int colour1 = selected ? 0xB04785D1 : 0xB0000000; | ||
145 | + drawGradientRect(xPosition, yPosition, xPosition + width, yPosition + PANEL_HEIGHT, colour1, 0xB0333333); | ||
146 | + | ||
147 | + this.fontRenderer.drawString(this.name, xPosition + 5, yPosition + 2, this.enabled ? 0xFFFFFFFF : 0xFF999999); | ||
148 | + this.fontRenderer.drawString("Version " + this.version, xPosition + 5, yPosition + 12, 0xFF999999); | ||
149 | + | ||
150 | + String status = "Active"; | ||
151 | + | ||
152 | + if (this.canBeToggled) | ||
153 | + { | ||
154 | + if (!this.enabled && !this.willBeEnabled) status = "\2477Disabled"; | ||
155 | + if (!this.enabled && this.willBeEnabled) status = "\247aEnabled on next startup"; | ||
156 | + if ( this.enabled && !this.willBeEnabled) status = "\247cDisabled on next startup"; | ||
157 | + } | ||
158 | + | ||
159 | + this.fontRenderer.drawString(status, xPosition + 5, yPosition + 22, 0xFF4785D1); | ||
160 | + | ||
161 | + this.mouseOver = mouseX > xPosition && mouseX < xPosition + width && mouseY > yPosition && mouseY < yPosition + PANEL_HEIGHT; | ||
162 | + drawRect(xPosition, yPosition, xPosition + 1, yPosition + PANEL_HEIGHT, this.mouseOver ? 0xFFFFFFFF : 0xFF999999); | ||
163 | + | ||
164 | + return PANEL_HEIGHT + PANEL_SPACING; | ||
165 | + } | ||
166 | + | ||
167 | + /** | ||
168 | + * Draw this entry as the info page | ||
169 | + * | ||
170 | + * @param mouseX | ||
171 | + * @param mouseY | ||
172 | + * @param partialTicks | ||
173 | + * @param xPosition | ||
174 | + * @param yPosition | ||
175 | + * @param width | ||
176 | + */ | ||
177 | + public void drawInfo(int mouseX, int mouseY, float partialTicks, int xPosition, int yPosition, int width) | ||
178 | + { | ||
179 | + yPosition += 2; | ||
180 | + | ||
181 | + this.fontRenderer.drawString(this.name, xPosition + 5, yPosition, 0xFFFFFFFF); yPosition += 10; | ||
182 | + this.fontRenderer.drawString("Version " + this.version, xPosition + 5, yPosition, 0xFF999999); yPosition += 10; | ||
183 | + | ||
184 | + drawRect(xPosition + 5, yPosition, xPosition + width, yPosition + 1, 0xFF999999); yPosition += 4; | ||
185 | + | ||
186 | + this.fontRenderer.drawString("Authors: \2477" + this.author, xPosition + 5, yPosition, 0xFFFFFFFF); yPosition += 10; | ||
187 | + if (this.url != null) | ||
188 | + { | ||
189 | + this.fontRenderer.drawString(this.url, xPosition + 5, yPosition, 0xB04785D1); yPosition += 10; | ||
190 | + } | ||
191 | + | ||
192 | + drawRect(xPosition + 5, yPosition, xPosition + width, yPosition + 1, 0xFF999999); yPosition += 4; | ||
193 | + | ||
194 | + this.fontRenderer.drawSplitString(this.description, xPosition + 5, yPosition, width - 5, 0xFFFFFFFF); | ||
195 | + } | ||
196 | + | ||
197 | + /** | ||
198 | + * Toggle the enablement status of this mod, if supported | ||
199 | + */ | ||
200 | + public void toggleEnabled() | ||
201 | + { | ||
202 | + if (this.canBeToggled) | ||
203 | + { | ||
204 | + this.willBeEnabled = !this.willBeEnabled; | ||
205 | + this.enabledModsList.setEnabled(LiteLoader.getProfile(), this.metaName, this.willBeEnabled); | ||
206 | + this.enabledModsList.save(); | ||
207 | + } | ||
208 | + } | ||
209 | + | ||
210 | + public String getKey() | ||
211 | + { | ||
212 | + return this.metaName + Integer.toHexString(this.hashCode()); | ||
213 | + } | ||
214 | + | ||
215 | + public String getName() | ||
216 | + { | ||
217 | + return this.name; | ||
218 | + } | ||
219 | + | ||
220 | + public String getVersion() | ||
221 | + { | ||
222 | + return this.version; | ||
223 | + } | ||
224 | + | ||
225 | + public String getAuthor() | ||
226 | + { | ||
227 | + return this.author; | ||
228 | + } | ||
229 | + | ||
230 | + public String getDescription() | ||
231 | + { | ||
232 | + return this.description; | ||
233 | + } | ||
234 | + | ||
235 | + public boolean isEnabled() | ||
236 | + { | ||
237 | + return this.enabled; | ||
238 | + } | ||
239 | + | ||
240 | + public boolean canBeToggled() | ||
241 | + { | ||
242 | + return this.canBeToggled; | ||
243 | + } | ||
244 | + | ||
245 | + public boolean willBeEnabled() | ||
246 | + { | ||
247 | + return this.willBeEnabled; | ||
248 | + } | ||
249 | + | ||
250 | + public boolean mouseWasOver() | ||
251 | + { | ||
252 | + return this.mouseOver; | ||
253 | + } | ||
254 | +} |
java/com/mumfrey/liteloader/gui/GuiScreenModInfo.java
0 → 100644
1 | +package com.mumfrey.liteloader.gui; | ||
2 | + | ||
3 | +import static org.lwjgl.opengl.GL11.*; | ||
4 | + | ||
5 | +import java.awt.image.BufferedImage; | ||
6 | +import java.nio.DoubleBuffer; | ||
7 | +import java.util.ArrayList; | ||
8 | +import java.util.List; | ||
9 | +import java.util.Map; | ||
10 | +import java.util.TreeMap; | ||
11 | + | ||
12 | +import javax.imageio.ImageIO; | ||
13 | + | ||
14 | +import org.lwjgl.BufferUtils; | ||
15 | +import org.lwjgl.input.Keyboard; | ||
16 | +import org.lwjgl.input.Mouse; | ||
17 | + | ||
18 | +import com.mumfrey.liteloader.LiteMod; | ||
19 | +import com.mumfrey.liteloader.core.EnabledModsList; | ||
20 | +import com.mumfrey.liteloader.core.LiteLoader; | ||
21 | +import com.mumfrey.liteloader.core.ModFile; | ||
22 | + | ||
23 | +import net.minecraft.src.DynamicTexture; | ||
24 | +import net.minecraft.src.GuiButton; | ||
25 | +import net.minecraft.src.GuiMainMenu; | ||
26 | +import net.minecraft.src.GuiScreen; | ||
27 | +import net.minecraft.src.Minecraft; | ||
28 | +import net.minecraft.src.ResourceLocation; | ||
29 | +import net.minecraft.src.Tessellator; | ||
30 | + | ||
31 | +/** | ||
32 | + * GUI screen which displays info about loaded mods and also allows them to be enabled and | ||
33 | + * disabled. An instance of this class is created every time the main menu is displayed and is | ||
34 | + * drawn as an overlay until the tab is clicked, at which point it becomes the active GUI screen | ||
35 | + * and draws the parent main menu screen as its background to give the appearance of being | ||
36 | + * overlaid on the main menu. | ||
37 | + * | ||
38 | + * @author Adam Mummery-Smith | ||
39 | + */ | ||
40 | +public class GuiScreenModInfo extends GuiScreen | ||
41 | +{ | ||
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 | + | ||
47 | + /** | ||
48 | + * Used for clipping | ||
49 | + */ | ||
50 | + private static DoubleBuffer doubleBuffer = BufferUtils.createByteBuffer(64).asDoubleBuffer(); | ||
51 | + | ||
52 | + public static ResourceLocation aboutTextureResource; | ||
53 | + private static DynamicTexture aboutTexture; | ||
54 | + | ||
55 | + private GuiMainMenu mainMenu; | ||
56 | + | ||
57 | + private long tickNumber; | ||
58 | + | ||
59 | + private double lastTick; | ||
60 | + | ||
61 | + private double tweenAmount = 0.0, tweenRate = 0.08; | ||
62 | + | ||
63 | + private boolean mouseDown, toggled; | ||
64 | + | ||
65 | + private float tabOpacity = 0.0F; | ||
66 | + | ||
67 | + private List<GuiModListEntry> mods = new ArrayList<GuiModListEntry>(); | ||
68 | + | ||
69 | + private GuiModListEntry selectedMod = null; | ||
70 | + | ||
71 | + private String activeModText = "0 mod(s) loaded"; | ||
72 | + | ||
73 | + private int listHeight; | ||
74 | + | ||
75 | + private GuiSimpleScrollBar scrollBar = new GuiSimpleScrollBar(); | ||
76 | + | ||
77 | + private GuiButton btnToggle; | ||
78 | + | ||
79 | + private GuiCheckbox chkEnabled; | ||
80 | + | ||
81 | + public GuiScreenModInfo(Minecraft minecraft, GuiMainMenu mainMenu, LiteLoader loader, EnabledModsList enabledModsList) | ||
82 | + { | ||
83 | + this.mc = minecraft; | ||
84 | + this.mainMenu = mainMenu; | ||
85 | + | ||
86 | + if (aboutTexture == null) | ||
87 | + { | ||
88 | + try | ||
89 | + { | ||
90 | + BufferedImage aboutImage = ImageIO.read(GuiScreenModInfo.class.getResourceAsStream("/assets/liteloader/textures/gui/about.png")); | ||
91 | + aboutTexture = new DynamicTexture(aboutImage); | ||
92 | + aboutTextureResource = minecraft.getTextureManager().getDynamicTextureLocation("about_assets", aboutTexture); | ||
93 | + } | ||
94 | + catch (Exception ex) {} | ||
95 | + } | ||
96 | + | ||
97 | + this.enumerateMods(loader, enabledModsList); | ||
98 | + } | ||
99 | + | ||
100 | + /** | ||
101 | + * Populate the mods list | ||
102 | + * | ||
103 | + * @param loader | ||
104 | + * @param enabledModsList | ||
105 | + */ | ||
106 | + private void enumerateMods(LiteLoader loader, EnabledModsList enabledModsList) | ||
107 | + { | ||
108 | + this.activeModText = String.format("%d mod(s) loaded", loader.getLoadedMods().size()); | ||
109 | + | ||
110 | + Map<String, GuiModListEntry> sortedMods = new TreeMap<String, GuiModListEntry>(); | ||
111 | + | ||
112 | + for (LiteMod mod : loader.getLoadedMods()) | ||
113 | + { | ||
114 | + GuiModListEntry modListEntry = new GuiModListEntry(loader, enabledModsList, this.mc.fontRenderer, mod); | ||
115 | + sortedMods.put(modListEntry.getKey(), modListEntry); | ||
116 | + } | ||
117 | + | ||
118 | + for (ModFile disabledMod : loader.getDisabledMods()) | ||
119 | + { | ||
120 | + GuiModListEntry modListEntry = new GuiModListEntry(loader, enabledModsList, this.mc.fontRenderer, disabledMod); | ||
121 | + sortedMods.put(modListEntry.getKey(), modListEntry); | ||
122 | + } | ||
123 | + | ||
124 | + this.mods.addAll(sortedMods.values()); | ||
125 | + | ||
126 | + if (this.mods.size() > 0) | ||
127 | + { | ||
128 | + this.selectedMod = this.mods.get(0); | ||
129 | + } | ||
130 | + } | ||
131 | + | ||
132 | + /** | ||
133 | + * Release references prior to being disposed | ||
134 | + */ | ||
135 | + public void release() | ||
136 | + { | ||
137 | + this.mainMenu = null; | ||
138 | + } | ||
139 | + | ||
140 | + /** | ||
141 | + * Get the parent menu | ||
142 | + */ | ||
143 | + public GuiMainMenu getMenu() | ||
144 | + { | ||
145 | + return this.mainMenu; | ||
146 | + } | ||
147 | + | ||
148 | + /* (non-Javadoc) | ||
149 | + * @see net.minecraft.src.GuiScreen#initGui() | ||
150 | + */ | ||
151 | + @SuppressWarnings("unchecked") | ||
152 | + @Override | ||
153 | + public void initGui() | ||
154 | + { | ||
155 | + int left = LEFT_EDGE + 16 + (this.width - LEFT_EDGE - 28) / 2; | ||
156 | + | ||
157 | + this.buttonList.clear(); | ||
158 | + this.buttonList.add(this.btnToggle = new GuiButton(0, left, this.height - 50, 100, 20, "Enable mod")); | ||
159 | + this.buttonList.add(this.chkEnabled = new GuiCheckbox(1, LEFT_EDGE + 12, this.height - 17, "Show LiteLoader tab on main menu")); | ||
160 | + | ||
161 | + this.selectMod(this.selectedMod); | ||
162 | + } | ||
163 | + | ||
164 | + /* (non-Javadoc) | ||
165 | + * @see net.minecraft.src.GuiScreen#setWorldAndResolution(net.minecraft.src.Minecraft, int, int) | ||
166 | + */ | ||
167 | + @Override | ||
168 | + public void setWorldAndResolution(Minecraft minecraft, int width, int height) | ||
169 | + { | ||
170 | + if (this.mc.currentScreen == this) | ||
171 | + { | ||
172 | + // Set res in parent screen if we are the active GUI | ||
173 | + this.mainMenu.setWorldAndResolution(minecraft, width, height); | ||
174 | + } | ||
175 | + | ||
176 | + super.setWorldAndResolution(minecraft, width, height); | ||
177 | + } | ||
178 | + | ||
179 | + /* (non-Javadoc) | ||
180 | + * @see net.minecraft.src.GuiScreen#updateScreen() | ||
181 | + */ | ||
182 | + @Override | ||
183 | + public void updateScreen() | ||
184 | + { | ||
185 | + this.tickNumber++; | ||
186 | + | ||
187 | + if (this.mc.currentScreen == this) | ||
188 | + { | ||
189 | + this.mainMenu.updateScreen(); | ||
190 | + this.chkEnabled.checked = LiteLoader.getInstance().getDisplayModInfoScreenTab(); | ||
191 | + } | ||
192 | + | ||
193 | + if (this.toggled) | ||
194 | + { | ||
195 | + this.onToggled(); | ||
196 | + } | ||
197 | + } | ||
198 | + | ||
199 | + /* (non-Javadoc) | ||
200 | + * @see net.minecraft.src.GuiScreen#drawScreen(int, int, float) | ||
201 | + */ | ||
202 | + @Override | ||
203 | + public void drawScreen(int mouseX, int mouseY, float partialTicks) | ||
204 | + { | ||
205 | + boolean active = this.mc.currentScreen == this; | ||
206 | + | ||
207 | + this.width = this.mainMenu.width; | ||
208 | + this.height = this.mainMenu.height; | ||
209 | + | ||
210 | + if (active) | ||
211 | + { | ||
212 | + glClear(GL_DEPTH_BUFFER_BIT); | ||
213 | + this.mainMenu.drawScreen(-10, -10, partialTicks); | ||
214 | + glClear(GL_DEPTH_BUFFER_BIT); | ||
215 | + } | ||
216 | + | ||
217 | + float xOffset = (this.width - LEFT_EDGE) * this.calcTween(partialTicks, active) + 16.0F + (this.tabOpacity * -32.0F); | ||
218 | + mouseX -= (int)xOffset; | ||
219 | + | ||
220 | + boolean mouseOverTab = mouseX > LEFT_EDGE - TAB_WIDTH && mouseX < LEFT_EDGE && mouseY > TAB_TOP && mouseY < TAB_TOP + TAB_HEIGHT; | ||
221 | + this.handleMouseClick(mouseX, mouseY, partialTicks, active, mouseOverTab); | ||
222 | + | ||
223 | + this.tabOpacity = mouseOverTab || this.tweenAmount > 0.0 ? 0.5F : Math.max(0.0F, this.tabOpacity - partialTicks * 0.1F); | ||
224 | + this.drawPanel(mouseX, mouseY, partialTicks, active, xOffset); | ||
225 | + } | ||
226 | + | ||
227 | + /** | ||
228 | + * @param mouseX | ||
229 | + * @param mouseY | ||
230 | + * @param partialTicks | ||
231 | + * @param active | ||
232 | + * @param xOffset | ||
233 | + */ | ||
234 | + private void drawPanel(int mouseX, int mouseY, float partialTicks, boolean active, float xOffset) | ||
235 | + { | ||
236 | + glPushMatrix(); | ||
237 | + glTranslatef(xOffset, 0.0F, 0.0F); | ||
238 | + | ||
239 | + drawRect(LEFT_EDGE, 0, this.width, this.height, 0xB0000000); | ||
240 | + drawRect(LEFT_EDGE, 0, LEFT_EDGE + 1, TAB_TOP, 0xFFFFFFFF); | ||
241 | + drawRect(LEFT_EDGE, TAB_TOP + TAB_HEIGHT, LEFT_EDGE + 1, this.height, 0xFFFFFFFF); | ||
242 | + | ||
243 | + this.mc.getTextureManager().bindTexture(aboutTextureResource); | ||
244 | + glDrawTexturedRect(LEFT_EDGE - TAB_WIDTH, TAB_TOP, TAB_WIDTH + 1, TAB_HEIGHT, 80, 80, 122, 160, 0.5F + this.tabOpacity); | ||
245 | + | ||
246 | + if (this.tweenAmount > 0.0) | ||
247 | + { | ||
248 | + glDrawTexturedRect(LEFT_EDGE + 12, 12, 128, 40, 0, 0, 256, 80, 1.0F); | ||
249 | + glDrawTexturedRect(this.width - 32 - 12, 12, 32, 45, 0, 80, 64, 170, 1.0F); | ||
250 | + | ||
251 | + this.fontRenderer.drawString("Version " + LiteLoader.getVersion(), LEFT_EDGE + 12 + 38, 50, 0xFFFFFFFF); | ||
252 | + this.fontRenderer.drawString(this.activeModText, LEFT_EDGE + 12 + 38, 60, 0xFFAAAAAA); | ||
253 | + | ||
254 | + drawRect(LEFT_EDGE + 12, 80, this.width - 12, 81, 0xFF999999); | ||
255 | + drawRect(LEFT_EDGE + 12, this.height - 24, this.width - 12, this.height - 23, 0xFF999999); | ||
256 | + | ||
257 | + int panelTop = 83; | ||
258 | + int innerWidth = this.width - LEFT_EDGE - 24 - 4; | ||
259 | + int listWidth = innerWidth / 2; | ||
260 | + | ||
261 | + this.drawModsList(mouseX, mouseY, partialTicks, panelTop, listWidth); | ||
262 | + this.drawSelectedMod(mouseX, mouseY, partialTicks, panelTop, listWidth); | ||
263 | + | ||
264 | + super.drawScreen(mouseX, mouseY, partialTicks); | ||
265 | + } | ||
266 | + | ||
267 | + glPopMatrix(); | ||
268 | + } | ||
269 | + | ||
270 | + /** | ||
271 | + * @param mouseX | ||
272 | + * @param mouseY | ||
273 | + * @param partialTicks | ||
274 | + * @param panelWidth | ||
275 | + */ | ||
276 | + public void drawModsList(int mouseX, int mouseY, float partialTicks, int panelTop, int panelWidth) | ||
277 | + { | ||
278 | + int panelHeight = this.height - 26 - panelTop; | ||
279 | + this.scrollBar.drawScrollBar(mouseX, mouseY, partialTicks, LEFT_EDGE + 12 + panelWidth - 5, panelTop, 5, panelHeight, this.listHeight); | ||
280 | + | ||
281 | + glEnableClipping(LEFT_EDGE + 12, LEFT_EDGE + 12 + panelWidth - 6, panelTop, this.height - 26); | ||
282 | + | ||
283 | + glPushMatrix(); | ||
284 | + glTranslatef(0.0F, panelTop - this.scrollBar.getValue(), 0.0F); | ||
285 | + | ||
286 | + mouseY -= (panelTop - this.scrollBar.getValue()); | ||
287 | + | ||
288 | + int yPos = 0; | ||
289 | + for (GuiModListEntry mod : this.mods) | ||
290 | + { | ||
291 | + yPos += mod.drawListEntry(mouseX, mouseY, partialTicks, LEFT_EDGE + 12, yPos, panelWidth - 6, mod == this.selectedMod); | ||
292 | + } | ||
293 | + | ||
294 | + glPopMatrix(); | ||
295 | + glDisableClipping(); | ||
296 | + | ||
297 | + this.listHeight = yPos; | ||
298 | + this.scrollBar.setMaxValue(this.listHeight - panelHeight); | ||
299 | + } | ||
300 | + | ||
301 | + /** | ||
302 | + * @param mouseX | ||
303 | + * @param mouseY | ||
304 | + * @param partialTicks | ||
305 | + * @param panelTop | ||
306 | + * @param listWidth | ||
307 | + */ | ||
308 | + public void drawSelectedMod(int mouseX, int mouseY, float partialTicks, int panelTop, int listWidth) | ||
309 | + { | ||
310 | + if (this.selectedMod != null) | ||
311 | + { | ||
312 | + int left = LEFT_EDGE + 12 + listWidth; | ||
313 | + int right = this.width - 12; | ||
314 | + | ||
315 | + glEnableClipping(left, right, panelTop, this.height - 54); | ||
316 | + this.selectedMod.drawInfo(mouseX, mouseY, partialTicks, left, panelTop, right - left); | ||
317 | + glDisableClipping(); | ||
318 | + } | ||
319 | + } | ||
320 | + | ||
321 | + /** | ||
322 | + * @param mod | ||
323 | + * @return | ||
324 | + */ | ||
325 | + public void selectMod(GuiModListEntry mod) | ||
326 | + { | ||
327 | + this.selectedMod = mod; | ||
328 | + this.btnToggle.drawButton = false; | ||
329 | + | ||
330 | + if (this.selectedMod != null && this.selectedMod.canBeToggled()) | ||
331 | + { | ||
332 | + this.btnToggle.drawButton = true; | ||
333 | + this.btnToggle.displayString = this.selectedMod.willBeEnabled() ? "Disable mod" : "Enable mod"; | ||
334 | + } | ||
335 | + } | ||
336 | + | ||
337 | + /* (non-Javadoc) | ||
338 | + * @see net.minecraft.src.GuiScreen#actionPerformed(net.minecraft.src.GuiButton) | ||
339 | + */ | ||
340 | + @Override | ||
341 | + protected void actionPerformed(GuiButton button) | ||
342 | + { | ||
343 | + if (button.id == 0 && this.selectedMod != null) | ||
344 | + { | ||
345 | + this.selectedMod.toggleEnabled(); | ||
346 | + this.selectMod(this.selectedMod); | ||
347 | + } | ||
348 | + | ||
349 | + if (button.id == 1) | ||
350 | + { | ||
351 | + this.chkEnabled.checked = !this.chkEnabled.checked; | ||
352 | + LiteLoader.getInstance().setDisplayModInfoScreenTab(this.chkEnabled.checked); | ||
353 | + | ||
354 | + if (!this.chkEnabled.checked) | ||
355 | + { | ||
356 | + this.chkEnabled.displayString = "Show LiteLoader tab on main menu \247e(use \2479CTRL\247e+\2479SHIFT\247e+\2479TAB\247e)"; | ||
357 | + } | ||
358 | + } | ||
359 | + } | ||
360 | + | ||
361 | + /* (non-Javadoc) | ||
362 | + * @see net.minecraft.src.GuiScreen#keyTyped(char, int) | ||
363 | + */ | ||
364 | + @Override | ||
365 | + protected void keyTyped(char keyChar, int keyCode) | ||
366 | + { | ||
367 | + if (keyCode == Keyboard.KEY_ESCAPE) | ||
368 | + { | ||
369 | + this.onToggled(); | ||
370 | + return; | ||
371 | + } | ||
372 | + } | ||
373 | + | ||
374 | + /* (non-Javadoc) | ||
375 | + * @see net.minecraft.src.GuiScreen#mouseClicked(int, int, int) | ||
376 | + */ | ||
377 | + @Override | ||
378 | + protected void mouseClicked(int mouseX, int mouseY, int button) | ||
379 | + { | ||
380 | + if (button == 0) | ||
381 | + { | ||
382 | + if (this.scrollBar.wasMouseOver()) | ||
383 | + { | ||
384 | + this.scrollBar.setDragging(true); | ||
385 | + } | ||
386 | + | ||
387 | + if (mouseY > 83 && mouseY < this.height - 26) | ||
388 | + { | ||
389 | + for (GuiModListEntry mod : this.mods) | ||
390 | + { | ||
391 | + if (mod.mouseWasOver()) this.selectMod(mod); | ||
392 | + } | ||
393 | + } | ||
394 | + } | ||
395 | + | ||
396 | + super.mouseClicked(mouseX, mouseY, button); | ||
397 | + } | ||
398 | + | ||
399 | + /* (non-Javadoc) | ||
400 | + * @see net.minecraft.src.GuiScreen#mouseMovedOrUp(int, int, int) | ||
401 | + */ | ||
402 | + @Override | ||
403 | + protected void mouseMovedOrUp(int mouseX, int mouseY, int button) | ||
404 | + { | ||
405 | + if (button == 0) | ||
406 | + { | ||
407 | + this.scrollBar.setDragging(false); | ||
408 | + } | ||
409 | + | ||
410 | + super.mouseMovedOrUp(mouseX, mouseY, button); | ||
411 | + } | ||
412 | + | ||
413 | + /* (non-Javadoc) | ||
414 | + * @see net.minecraft.src.GuiScreen#handleMouseInput() | ||
415 | + */ | ||
416 | + @Override | ||
417 | + public void handleMouseInput() | ||
418 | + { | ||
419 | + int mouseWheelDelta = Mouse.getEventDWheel(); | ||
420 | + | ||
421 | + if (mouseWheelDelta != 0) | ||
422 | + { | ||
423 | + this.scrollBar.offsetValue(-mouseWheelDelta / 8); | ||
424 | + } | ||
425 | + | ||
426 | + super.handleMouseInput(); | ||
427 | + } | ||
428 | + | ||
429 | + /** | ||
430 | + * @param mouseX | ||
431 | + * @param active | ||
432 | + * @param mouseOverTab | ||
433 | + */ | ||
434 | + public void handleMouseClick(int mouseX, int mouseY, float partialTicks, boolean active, boolean mouseOverTab) | ||
435 | + { | ||
436 | + boolean mouseDown = Mouse.isButtonDown(0); | ||
437 | + if (((active && mouseX < LEFT_EDGE) || mouseOverTab) && !this.mouseDown && mouseDown) | ||
438 | + { | ||
439 | + this.mouseDown = true; | ||
440 | + this.toggled = true; | ||
441 | + } | ||
442 | + else if (this.mouseDown && !mouseDown) | ||
443 | + { | ||
444 | + this.mouseDown = false; | ||
445 | + } | ||
446 | + } | ||
447 | + | ||
448 | + /** | ||
449 | + * @param partialTicks | ||
450 | + * @param active | ||
451 | + * @return | ||
452 | + */ | ||
453 | + private float calcTween(float partialTicks, boolean active) | ||
454 | + { | ||
455 | + double tickValue = this.tickNumber + partialTicks; | ||
456 | + | ||
457 | + if (active && this.tweenAmount < 1.0) | ||
458 | + { | ||
459 | + this.tweenAmount = Math.min(1.0, this.tweenAmount + ((tickValue - this.lastTick) * this.tweenRate)); | ||
460 | + } | ||
461 | + else if (!active && this.tweenAmount > 0.0) | ||
462 | + { | ||
463 | + this.tweenAmount = Math.max(0.0, this.tweenAmount - ((tickValue - this.lastTick) * this.tweenRate)); | ||
464 | + } | ||
465 | + | ||
466 | + this.lastTick = tickValue; | ||
467 | + return 1.0F - (float)Math.sin(this.tweenAmount * 0.5 * Math.PI); | ||
468 | + } | ||
469 | + | ||
470 | + /** | ||
471 | + * Called when the tab is clicked | ||
472 | + */ | ||
473 | + private void onToggled() | ||
474 | + { | ||
475 | + this.toggled = false; | ||
476 | + this.mc.displayGuiScreen(this.mc.currentScreen == this ? this.mainMenu : this); | ||
477 | + } | ||
478 | + | ||
479 | + /** | ||
480 | + * @param x | ||
481 | + * @param y | ||
482 | + * @param width | ||
483 | + * @param height | ||
484 | + * @param u | ||
485 | + * @param v | ||
486 | + * @param u2 | ||
487 | + * @param v2 | ||
488 | + * @param alpha | ||
489 | + */ | ||
490 | + private static void glDrawTexturedRect(int x, int y, int width, int height, int u, int v, int u2, int v2, float alpha) | ||
491 | + { | ||
492 | + glDisable(GL_LIGHTING); | ||
493 | + glEnable(GL_BLEND); | ||
494 | + glAlphaFunc(GL_GREATER, 0.0F); | ||
495 | + glEnable(GL_TEXTURE_2D); | ||
496 | + glColor4f(1.0F, 1.0F, 1.0F, alpha); | ||
497 | + | ||
498 | + float texMapScale = 0.00390625F; // 256px | ||
499 | + | ||
500 | + Tessellator tessellator = Tessellator.instance; | ||
501 | + tessellator.startDrawingQuads(); | ||
502 | + tessellator.addVertexWithUV(x + 0, y + height, 0, u * texMapScale, v2 * texMapScale); | ||
503 | + tessellator.addVertexWithUV(x + width, y + height, 0, u2 * texMapScale, v2 * texMapScale); | ||
504 | + tessellator.addVertexWithUV(x + width, y + 0, 0, u2 * texMapScale, v * texMapScale); | ||
505 | + tessellator.addVertexWithUV(x + 0, y + 0, 0, u * texMapScale, v * texMapScale); | ||
506 | + tessellator.draw(); | ||
507 | + | ||
508 | + glDisable(GL_BLEND); | ||
509 | + glAlphaFunc(GL_GREATER, 0.01F); | ||
510 | + } | ||
511 | + | ||
512 | + /** | ||
513 | + * Enable OpenGL clipping planes (uses planes 2, 3, 4 and 5) | ||
514 | + * | ||
515 | + * @param xLeft Left edge clip or -1 to not use this plane | ||
516 | + * @param xRight Right edge clip or -1 to not use this plane | ||
517 | + * @param yTop Top edge clip or -1 to not use this plane | ||
518 | + * @param yBottom Bottom edge clip or -1 to not use this plane | ||
519 | + */ | ||
520 | + private final static void glEnableClipping(int xLeft, int xRight, int yTop, int yBottom) | ||
521 | + { | ||
522 | + // Apply left edge clipping if specified | ||
523 | + if (xLeft != -1) | ||
524 | + { | ||
525 | + doubleBuffer.clear(); | ||
526 | + doubleBuffer.put(1).put(0).put(0).put(-xLeft).flip(); | ||
527 | + glClipPlane(GL_CLIP_PLANE2, doubleBuffer); | ||
528 | + glEnable(GL_CLIP_PLANE2); | ||
529 | + } | ||
530 | + | ||
531 | + // Apply right edge clipping if specified | ||
532 | + if (xRight != -1) | ||
533 | + { | ||
534 | + doubleBuffer.clear(); | ||
535 | + doubleBuffer.put(-1).put(0).put(0).put(xRight).flip(); | ||
536 | + glClipPlane(GL_CLIP_PLANE3, doubleBuffer); | ||
537 | + glEnable(GL_CLIP_PLANE3); | ||
538 | + } | ||
539 | + | ||
540 | + // Apply top edge clipping if specified | ||
541 | + if (yTop != -1) | ||
542 | + { | ||
543 | + doubleBuffer.clear(); | ||
544 | + doubleBuffer.put(0).put(1).put(0).put(-yTop).flip(); | ||
545 | + glClipPlane(GL_CLIP_PLANE4, doubleBuffer); | ||
546 | + glEnable(GL_CLIP_PLANE4); | ||
547 | + } | ||
548 | + | ||
549 | + // Apply bottom edge clipping if specified | ||
550 | + if (yBottom != -1) | ||
551 | + { | ||
552 | + doubleBuffer.clear(); | ||
553 | + doubleBuffer.put(0).put(-1).put(0).put(yBottom).flip(); | ||
554 | + glClipPlane(GL_CLIP_PLANE5, doubleBuffer); | ||
555 | + glEnable(GL_CLIP_PLANE5); | ||
556 | + } | ||
557 | + } | ||
558 | + | ||
559 | + /** | ||
560 | + * Disable OpenGL clipping planes (uses planes 2, 3, 4 and 5) | ||
561 | + */ | ||
562 | + private final static void glDisableClipping() | ||
563 | + { | ||
564 | + glDisable(GL_CLIP_PLANE5); | ||
565 | + glDisable(GL_CLIP_PLANE4); | ||
566 | + glDisable(GL_CLIP_PLANE3); | ||
567 | + glDisable(GL_CLIP_PLANE2); | ||
568 | + } | ||
569 | +} | ||
0 | \ No newline at end of file | 570 | \ No newline at end of file |
java/com/mumfrey/liteloader/gui/GuiSimpleScrollBar.java
0 → 100644
1 | +package com.mumfrey.liteloader.gui; | ||
2 | + | ||
3 | +import net.minecraft.src.Gui; | ||
4 | + | ||
5 | +/** | ||
6 | + * Extremely simple scrollbar implementation | ||
7 | + * | ||
8 | + * @author Adam Mummery-Smith | ||
9 | + */ | ||
10 | +public class GuiSimpleScrollBar extends Gui | ||
11 | +{ | ||
12 | + /** | ||
13 | + * Current value | ||
14 | + */ | ||
15 | + private int value = 0; | ||
16 | + | ||
17 | + /** | ||
18 | + * Current maximum value | ||
19 | + */ | ||
20 | + private int maxValue = 100; | ||
21 | + | ||
22 | + private int backColour = 0x44FFFFFF; | ||
23 | + private int foreColour = 0xFFFFFFFF; | ||
24 | + | ||
25 | + /** | ||
26 | + * True if mouse was over the drag bar when last drawn | ||
27 | + */ | ||
28 | + private boolean mouseOver = false; | ||
29 | + | ||
30 | + /** | ||
31 | + * True if currently dragging the scroll bar | ||
32 | + */ | ||
33 | + private boolean dragging = false; | ||
34 | + | ||
35 | + /** | ||
36 | + * Value prior to starting to drag | ||
37 | + */ | ||
38 | + private int mouseDownValue = 0; | ||
39 | + | ||
40 | + /** | ||
41 | + * mouse Y coordinate prior to starting to drag | ||
42 | + */ | ||
43 | + private int mouseDownY = 0; | ||
44 | + | ||
45 | + /** | ||
46 | + * Get the current scroll value | ||
47 | + */ | ||
48 | + public int getValue() | ||
49 | + { | ||
50 | + return this.value; | ||
51 | + } | ||
52 | + | ||
53 | + /** | ||
54 | + * Set the scroll value, the value is clamped between 0 and the current max value | ||
55 | + */ | ||
56 | + public void setValue(int value) | ||
57 | + { | ||
58 | + this.value = Math.min(Math.max(value, 0), this.maxValue); | ||
59 | + } | ||
60 | + | ||
61 | + /** | ||
62 | + * Offset the scroll value by the specified amount, the value is clamped between 0 and the current max value | ||
63 | + */ | ||
64 | + public void offsetValue(int offset) | ||
65 | + { | ||
66 | + this.setValue(this.value + offset); | ||
67 | + } | ||
68 | + | ||
69 | + /** | ||
70 | + * Get the current max value | ||
71 | + */ | ||
72 | + public int getMaxValue() | ||
73 | + { | ||
74 | + return this.maxValue; | ||
75 | + } | ||
76 | + | ||
77 | + /** | ||
78 | + * Sets the current max value | ||
79 | + */ | ||
80 | + public void setMaxValue(int maxValue) | ||
81 | + { | ||
82 | + this.maxValue = Math.max(0, maxValue); | ||
83 | + this.value = Math.min(this.value, this.maxValue); | ||
84 | + } | ||
85 | + | ||
86 | + /** | ||
87 | + * Returns true if the mouse was over the drag bar on the last render | ||
88 | + */ | ||
89 | + public boolean wasMouseOver() | ||
90 | + { | ||
91 | + return this.mouseOver; | ||
92 | + } | ||
93 | + | ||
94 | + /** | ||
95 | + * Set the current dragging state | ||
96 | + */ | ||
97 | + public void setDragging(boolean dragging) | ||
98 | + { | ||
99 | + this.dragging = dragging; | ||
100 | + } | ||
101 | + | ||
102 | + /** | ||
103 | + * Draw the scroll bar | ||
104 | + * | ||
105 | + * @param mouseX | ||
106 | + * @param mouseY | ||
107 | + * @param partialTicks | ||
108 | + * @param xPosition | ||
109 | + * @param yPosition | ||
110 | + * @param width | ||
111 | + * @param height | ||
112 | + * @param totalHeight | ||
113 | + */ | ||
114 | + public void drawScrollBar(int mouseX, int mouseY, float partialTicks, int xPosition, int yPosition, int width, int height, int totalHeight) | ||
115 | + { | ||
116 | + drawRect(xPosition, yPosition, xPosition + width, yPosition + height, this.backColour); | ||
117 | + | ||
118 | + if (totalHeight > 0) | ||
119 | + { | ||
120 | + int slideHeight = height - 2; | ||
121 | + float pct = Math.min(1.0F, (float)slideHeight / (float)totalHeight); | ||
122 | + int barHeight = (int)(pct * slideHeight); | ||
123 | + int barTravel = slideHeight - barHeight; | ||
124 | + int barPosition = this.maxValue > 0 ? yPosition + 1 + (int)((this.value / (float)this.maxValue) * barTravel) : 0; | ||
125 | + | ||
126 | + drawRect(xPosition + 1, barPosition, xPosition + width - 1, barPosition + barHeight, this.foreColour); | ||
127 | + | ||
128 | + this.mouseOver = mouseX > xPosition && mouseX < xPosition + width && mouseY > barPosition && mouseY < barPosition + barHeight; | ||
129 | + this.handleDrag(mouseY, barTravel); | ||
130 | + } | ||
131 | + } | ||
132 | + | ||
133 | + /** | ||
134 | + * @param mouseY | ||
135 | + * @param barTravel | ||
136 | + */ | ||
137 | + public void handleDrag(int mouseY, int barTravel) | ||
138 | + { | ||
139 | + if (this.dragging) | ||
140 | + { | ||
141 | + // Convert pixel delta to value delta | ||
142 | + float valuePerPixel = (float)this.maxValue / barTravel; | ||
143 | + this.setValue((int)(this.mouseDownValue + ((mouseY - this.mouseDownY) * valuePerPixel))); | ||
144 | + } | ||
145 | + else | ||
146 | + { | ||
147 | + this.mouseDownY = mouseY; | ||
148 | + this.mouseDownValue = this.value; | ||
149 | + } | ||
150 | + } | ||
151 | +} |
res/assets/liteloader/textures/gui/about.png
0 → 100644
27.2 KB