diff options
author | DeDiamondPro <67508414+DeDiamondPro@users.noreply.github.com> | 2022-06-12 20:19:53 +0200 |
---|---|---|
committer | DeDiamondPro <67508414+DeDiamondPro@users.noreply.github.com> | 2022-06-12 20:19:53 +0200 |
commit | 28488c6c292e793b03e8fd0197f5cd585b91bc72 (patch) | |
tree | 7a93eb28d3e1da96b497358990d7054eacafa55e /src/main/java/cc/polyfrost | |
parent | 354cab5542687c1272c8aab3f26834ecdc93de39 (diff) | |
download | OneConfigLoader-28488c6c292e793b03e8fd0197f5cd585b91bc72.tar.gz OneConfigLoader-28488c6c292e793b03e8fd0197f5cd585b91bc72.tar.bz2 OneConfigLoader-28488c6c292e793b03e8fd0197f5cd585b91bc72.zip |
fix flashing + add error message
Diffstat (limited to 'src/main/java/cc/polyfrost')
-rw-r--r-- | src/main/java/cc/polyfrost/oneconfigloader/OneConfigLoader.java | 117 |
1 files changed, 83 insertions, 34 deletions
diff --git a/src/main/java/cc/polyfrost/oneconfigloader/OneConfigLoader.java b/src/main/java/cc/polyfrost/oneconfigloader/OneConfigLoader.java index 892d524..149246f 100644 --- a/src/main/java/cc/polyfrost/oneconfigloader/OneConfigLoader.java +++ b/src/main/java/cc/polyfrost/oneconfigloader/OneConfigLoader.java @@ -15,10 +15,7 @@ import java.awt.*; import java.awt.image.BufferedImage; import java.io.*; import java.lang.reflect.Method; -import java.net.MalformedURLException; -import java.net.URL; -import java.net.URLClassLoader; -import java.net.URLConnection; +import java.net.*; import java.nio.charset.StandardCharsets; import java.nio.file.Files; import java.nio.file.StandardCopyOption; @@ -28,11 +25,18 @@ import java.util.Arrays; import java.util.Map; import java.util.Objects; - +@IFMLLoadingPlugin.MCVersion("1.8.9") public class OneConfigLoader implements IFMLLoadingPlugin { + public static final Color GRAY_900 = new Color(13, 14, 15, 255); + public static final Color GRAY_700 = new Color(34, 35, 38); + public static final Color PRIMARY_500 = new Color(26, 103, 255); + public static final Color PRIMARY_500_80 = new Color(26, 103, 204); + public static final Color WHITE_80 = new Color(255, 255, 255, 204); + public static final Color TRANSPARENT = new Color(0, 0, 0, 0); + private long timeLast = System.currentTimeMillis(); private float downloadPercent = 0f; - private final IFMLLoadingPlugin transformer; + private IFMLLoadingPlugin transformer = null; private static final Logger logger = LogManager.getLogger("OneConfigLoader"); public OneConfigLoader() { @@ -81,13 +85,13 @@ public class OneConfigLoader implements IFMLLoadingPlugin { } } - if (!oneConfigFile.exists()) throw new IllegalStateException("OneConfig jar doesn't exist"); + if (!oneConfigFile.exists()) showErrorScreen(); addToClasspath(oneConfigFile); } try { transformer = ((IFMLLoadingPlugin) Launch.classLoader.findClass("cc.polyfrost.oneconfig.internal.plugin.LoadingPlugin").newInstance()); } catch (ClassNotFoundException | InstantiationException | IllegalAccessException e) { - throw new RuntimeException(e); + showErrorScreen(); } } @@ -116,7 +120,7 @@ public class OneConfigLoader implements IFMLLoadingPlugin { } private void downloadFile(String url, File location) { - DownloadUI ui = new DownloadUI(); + Frame ui = new Frame(); try { URLConnection con = new URL(url).openConnection(); con.setRequestProperty("User-Agent", "OneConfig-Loader"); @@ -219,35 +223,18 @@ public class OneConfigLoader implements IFMLLoadingPlugin { return transformer == null ? null : transformer.getAccessTransformerClass(); } - private static class DownloadUI extends JFrame { + private static class DownloadUI extends JPanel { private BufferedImage base; - private final Color GRAY_700 = new Color(34, 35, 38); // Gray 700 - private final Color WHITE_60 = new Color(1f, 1f, 1f, 0.6f); // White 60% - private final Color PRIMARY_500 = new Color(26, 103, 255); // Primary 500 - private Font inter; private float progress = 0f; public DownloadUI() { - super("OneConfigLoader"); - Image icon; + super(); try { - base = ImageIO.read(Objects.requireNonNull(getClass().getResourceAsStream("/assets/frame.png"))); - icon = ImageIO.read(Objects.requireNonNull(getClass().getResourceAsStream("/assets/icon.png"))); - inter = Font.createFont(Font.TRUETYPE_FONT, Objects.requireNonNull(getClass().getResourceAsStream("/assets/fonts/Regular.otf"))).deriveFont(3f); - } catch (Exception e) { - e.printStackTrace(); - logger.error("Failed to display download UI, continuing anyway"); - return; + base = ImageIO.read(Objects.requireNonNull(getClass().getResourceAsStream("/assets/oneconfig-loader/frame.png"))); + } catch (Exception ignored) { } - setAlwaysOnTop(true); - setResizable(false); - setIconImage(icon); - setSize(300, 100); - setDefaultCloseOperation(WindowConstants.DO_NOTHING_ON_CLOSE); - setUndecorated(true); - setLocationRelativeTo(null); setBackground(new Color(0, 0, 0, 0)); - setVisible(true); + setPreferredSize(new Dimension(300, 100)); } @Override @@ -260,9 +247,6 @@ public class OneConfigLoader implements IFMLLoadingPlugin { g2d.fillRoundRect(12, 74, 275, 12, 12, 12); g2d.setColor(PRIMARY_500); g2d.fillRoundRect(12, 74, (int) (275 * progress), 12, 12, 12); - g2d.setFont(inter); - g2d.setColor(WHITE_60); - g2d.drawString("Downloading... (" + (int) (progress * 100) + "%)", 112, 94); g2d.dispose(); } @@ -271,4 +255,69 @@ public class OneConfigLoader implements IFMLLoadingPlugin { repaint(); } } + + private static class Frame extends JFrame { + private final DownloadUI downloadUI = new DownloadUI(); + + public Frame() { + super("OneConfig"); + setAlwaysOnTop(true); + setResizable(false); + Image icon = null; + try { + icon = ImageIO.read(Objects.requireNonNull(getClass().getResourceAsStream("/assets/oneconfig-loader/icon.png"))); + } catch (Exception ignored) { + } + setAlwaysOnTop(true); + setResizable(false); + setIconImage(icon); + setDefaultCloseOperation(WindowConstants.DO_NOTHING_ON_CLOSE); + setUndecorated(true); + setLocationRelativeTo(null); + setBackground(new Color(0, 0, 0, 0)); + add(downloadUI); + pack(); + setVisible(true); + } + + public void update(float progress) { + downloadUI.update(progress); + repaint(); + } + } + + private void showErrorScreen() { + try { + Icon icon = new ImageIcon(Objects.requireNonNull(getClass().getResource("/assets/oneconfig-loader/icon.png"))); + UIManager.put("OptionPane.background", GRAY_900); + UIManager.put("Panel.background", GRAY_900); + UIManager.put("OptionPane.messageForeground", WHITE_80); + UIManager.put("Button.background", PRIMARY_500); + UIManager.put("Button.select", PRIMARY_500_80); + UIManager.put("Button.foreground", WHITE_80); + UIManager.put("Button.focus", TRANSPARENT); + int response = JOptionPane.showOptionDialog( + null, + "OneConfig has failed to download!\n" + + "Please join our discord server at https://polyfrost.cc/discord\n" + + "for support, or try again later.", + "OneConfig has failed to download!", JOptionPane.OK_CANCEL_OPTION, JOptionPane.ERROR_MESSAGE, icon, + new Object[]{"Join Discord", "Close"}, "Join Discord" + ); + if (response == 0) { + if (Desktop.isDesktopSupported() && Desktop.getDesktop().isSupported(Desktop.Action.BROWSE)) { + Desktop.getDesktop().browse(new URI("https://polyfrost.cc/discord")); + } + } + } catch (Exception ignored) { + } finally { + try { + Method exit = Class.forName("java.lang.Shutdown").getDeclaredMethod("exit", int.class); + exit.setAccessible(true); + exit.invoke(null, 1); + } catch (Exception e) { + System.exit(1); + } + } + } }
\ No newline at end of file |