diff options
| author | DeDiamondPro <67508414+DeDiamondPro@users.noreply.github.com> | 2022-03-01 21:03:37 +0100 |
|---|---|---|
| committer | DeDiamondPro <67508414+DeDiamondPro@users.noreply.github.com> | 2022-03-01 21:03:37 +0100 |
| commit | a7a7f5a9ab21c9d0abfb9c2caf13df833c8c51a8 (patch) | |
| tree | 26fa29480dbe0490aab862ebc9446aeb7759f2b0 /src/main/java/io/polyfrost/oneconfig/hud/interfaces | |
| parent | 321ea5ca5b4feebc4c695fc739db7765cac77ff1 (diff) | |
| download | OneConfig-a7a7f5a9ab21c9d0abfb9c2caf13df833c8c51a8.tar.gz OneConfig-a7a7f5a9ab21c9d0abfb9c2caf13df833c8c51a8.tar.bz2 OneConfig-a7a7f5a9ab21c9d0abfb9c2caf13df833c8c51a8.zip | |
more hud stuff and hud scaling that works sometimes
Diffstat (limited to 'src/main/java/io/polyfrost/oneconfig/hud/interfaces')
| -rw-r--r-- | src/main/java/io/polyfrost/oneconfig/hud/interfaces/BasicHud.java | 39 |
1 files changed, 27 insertions, 12 deletions
diff --git a/src/main/java/io/polyfrost/oneconfig/hud/interfaces/BasicHud.java b/src/main/java/io/polyfrost/oneconfig/hud/interfaces/BasicHud.java index 121c258..ebc5459 100644 --- a/src/main/java/io/polyfrost/oneconfig/hud/interfaces/BasicHud.java +++ b/src/main/java/io/polyfrost/oneconfig/hud/interfaces/BasicHud.java @@ -5,8 +5,9 @@ import io.polyfrost.oneconfig.renderer.Renderer; import java.awt.*; public abstract class BasicHud { - public int normalX; - public int normalY; + public double xUnscaled = 0; + public double yUnscaled = 0; + public float scale = 1; public int paddingX = 5; public int paddingY = 5; public boolean background = true; @@ -26,23 +27,37 @@ public abstract class BasicHud { return getHeight(scale); } - public void drawAll(int x, int y, float scale) { - drawBackGround(x, y, scale); - draw(x, y, scale); + public void drawAll(float x, float y, float scale) { + drawBackground(x, y, scale); + draw((int) (x + paddingX * scale / 2f), (int) (y + paddingY * scale / 2f), scale); } - public void drawExampleAll(int x, int y, float scale) { - drawBackGround(x, y, scale); - drawExample(x, y, scale); + public void drawExampleAll(float x, float y, float scale) { + drawBackground(x, y, scale); + drawExample((int) (x + paddingX * scale / 2f), (int) (y + paddingY * scale / 2f), scale); } public void drawExample(int x, int y, float scale) { draw(x, y, scale); } - private void drawBackGround(int x, int y, float scale) { - Renderer.drawRoundRect(x - paddingX * scale / 2f, y - paddingY * scale / 2f, - getWidth(scale) + paddingX * scale, getHeight(scale) + paddingY * scale, - (2 * scale), new Color(0, 0, 0, 100).getRGB()); + private void drawBackground(float x, float y, float scale) { + Renderer.drawRoundRect((int) x, (int) y, + (int) (getWidth(scale) + paddingX * scale), (int) (getHeight(scale) + paddingY * scale), + (int) (2 * scale), new Color(0, 0, 0, 120).getRGB()); + } + + public float getXScaled(int screenWidth) { + if (xUnscaled <= 0.5) { + return (int) (screenWidth * xUnscaled); + } + return (float) (screenWidth - (1d - xUnscaled) * screenWidth - (getWidth(scale) + paddingX * scale)); + } + + public float getYScaled(int screenHeight) { + if (yUnscaled <= 0.5) { + return (int) (screenHeight * yUnscaled); + } + return (float) (screenHeight - (1d - yUnscaled) * screenHeight - (getHeight(scale) + paddingY * scale)); } } |
