Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[pull] development from Wynntils:development #21

Open
wants to merge 139 commits into
base: development
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
139 commits
Select commit Hold shift + click to select a range
57f597c
vuln-fix: Zip Slip Vulnerability (#570)
JLLeitschuh Sep 9, 2022
f9174d5
Fixes a StringIndexOutOfBounds exception (#567)
byBackfish Sep 9, 2022
63f0224
fix: always sell all button (#573)
byBackfish Sep 9, 2022
a88c1ea
ci: Automatic changelog and deployment to Curseforge and Modrinth
DevScyu Sep 9, 2022
d22c8b2
fix: Some post 2.0 release fixes (#569)
ryanzhoudev Sep 10, 2022
89e7107
fix: Remove shortid fix (#581)
Incompleteusern Sep 16, 2022
6517c27
Add "Additional Comments" for bug_reports (#580)
IngeniousCoder Sep 16, 2022
4d5d68f
feat: add awakening mask progress bar (#576)
byBackfish Sep 18, 2022
9d6431c
feat: click to copy message (#565)
byBackfish Sep 18, 2022
a74594c
fix: old waypoints being invalid when trying to import (#583)
byBackfish Sep 18, 2022
a03ef5f
fix: Fix quick cast keys (#574)
ryanzhoudev Sep 19, 2022
3e97704
feat: Added Arcanist Mana Bank Bar (#578)
paotmb Sep 19, 2022
b755343
ci: rework [skip ci]
DevScyu Sep 19, 2022
15372c3
ci: add target commit to gh release [skip ci]
DevScyu Sep 21, 2022
7b30319
chore: upgrade gradle to 7.5.1 (#591)
ryanzhoudev Sep 21, 2022
878e70f
fix: rework party management gui (#590)
ryanzhoudev Sep 21, 2022
b7a0ec5
feat: add focus bar (#586)
byBackfish Sep 21, 2022
ca0ef1f
feat: custom trade market sell amount buttons (#584)
byBackfish Sep 21, 2022
d4705b8
feat: ability tree navigation using scroll wheel (#582)
byBackfish Sep 21, 2022
4cdd204
feat: add currently active shaman mask display (#577)
byBackfish Sep 21, 2022
b7647cd
ci: update releases (#592)
DevScyu Sep 21, 2022
43a0f87
chore(release): v1.12.1-beta.0 [skip ci]
invalid-email-address Sep 21, 2022
9b7ea7c
ci: fix release names [skip ci]
DevScyu Sep 21, 2022
79936c7
fix: mythic detection & /guild list spam (#594)
byBackfish Sep 23, 2022
36fb1af
chore(release): v1.12.1-beta.1 [skip ci]
invalid-email-address Sep 23, 2022
f821b79
feat: add corrupted bar (#595)
byBackfish Sep 24, 2022
e87436d
chore(release): v1.12.1-beta.2 [skip ci]
invalid-email-address Sep 24, 2022
fe06649
fix: ObjectivesOverlay: Fix patterns (#601)
kristofbolyai Oct 1, 2022
e106fc0
chore(release): v1.12.1-beta.3 [skip ci]
invalid-email-address Oct 1, 2022
34b1409
fix: hide token during registration process (#603)
HighCrit Oct 10, 2022
adebce0
chore(release): v1.12.1-beta.4 [skip ci]
invalid-email-address Oct 10, 2022
7af5f79
refactor: applying minor caching of variables in a few files. (#599)
TheAvonian Oct 10, 2022
f699c8f
chore(release): v1.12.1-beta.5 [skip ci]
invalid-email-address Oct 10, 2022
c3e0de4
fix: Fix log spam (#600)
Incompleteusern Oct 10, 2022
716945d
chore(release): v1.12.1-beta.6 [skip ci]
invalid-email-address Oct 10, 2022
ec88608
chore: enhance devauth integration
DevScyu Oct 11, 2022
7314984
chore(release): v1.12.1-beta.7 [skip ci]
invalid-email-address Oct 12, 2022
b597ad5
fix: emerald pouch message in chest not being sent (#605)
ryanzhoudev Oct 12, 2022
8034ae5
chore(release): v1.12.1-beta.8 [skip ci]
invalid-email-address Oct 12, 2022
b5b5ca8
chore: add codeowners file [skip ci]
DevScyu Oct 12, 2022
73a74fd
fix: resources in dev environment [skip ci]
DevScyu Oct 12, 2022
ead33b0
feat: Auto updater from github builds (#588)
DevScyu Oct 13, 2022
26cfb98
chore(release): v1.12.1-beta.9 [skip ci]
invalid-email-address Oct 13, 2022
996a4cc
chore: add workflow_dispatch to workflow [skip ci]
DevScyu Oct 13, 2022
2f61b71
Merge branch 'production' into development
DevScyu Oct 13, 2022
65e3e56
chore(release): v1.12.1-beta.10 [skip ci]
invalid-email-address Oct 13, 2022
e23d6e9
ci: update release workflow [skip ci]
DevScyu Oct 13, 2022
3dc3811
chore(release): v1.13.0 [skip ci]
invalid-email-address Oct 13, 2022
7f6e390
fix: Changelog and Updater bugfixing (#613)
DevScyu Oct 22, 2022
23ffe9e
chore(release): v1.13.1-beta.0 [skip ci]
invalid-email-address Oct 22, 2022
792dd46
fix: Missing Arrow Bomb cost modifiers (#617)
ryanzhoudev Oct 26, 2022
331677a
chore(release): v1.13.1-beta.1 [skip ci]
invalid-email-address Oct 26, 2022
84b3d20
fix: Guild territory list occasionally causing NPE (#618)
ryanzhoudev Oct 26, 2022
ccf071b
chore(release): v1.13.1-beta.2 [skip ci]
invalid-email-address Oct 26, 2022
a8297f9
chore(release): [RELEASE] v1.13.1 hotfix (#616)
DevScyu Oct 26, 2022
700608a
chore(release): v1.13.1 [skip ci]
invalid-email-address Oct 26, 2022
76e5bdb
feat: Tab list effect parsing (#615)
ryanzhoudev Oct 28, 2022
ce5e5e9
chore(release): v1.13.2-beta.0 [skip ci]
invalid-email-address Oct 28, 2022
312aa90
fix: improve skill point loadouts (#597)
ryanzhoudev Oct 28, 2022
b5ef00e
chore(release): v1.13.2-beta.1 [skip ci]
invalid-email-address Oct 28, 2022
be9986a
ci: update workflows [skip ci]
DevScyu Oct 28, 2022
144a62a
feat: add redirect for ability cooldowns (#624)
P0keDev Oct 29, 2022
87056c6
chore(release): v1.13.2-beta.2 [skip ci]
WynntilsBot Oct 29, 2022
4b18614
fix: Vanish timer missing, regex not detecting cooldowns, DynamicTime…
ryanzhoudev Oct 30, 2022
a180cfb
chore(release): v1.13.2-beta.3 [skip ci]
WynntilsBot Oct 30, 2022
a04e044
ci: Change to mc-publish (#631)
DevScyu Nov 2, 2022
9e86c47
ci: update to upstream action [skip ci]
DevScyu Nov 2, 2022
ab72486
ci: update github output [skip ci]
DevScyu Nov 2, 2022
028f658
chore: add logging to configs (#614)
DevScyu Nov 3, 2022
037207a
chore(release): v1.13.2-beta.4 [skip ci]
WynntilsBot Nov 3, 2022
9bf5191
ci: update github actions [skip ci]
DevScyu Nov 3, 2022
1f771b9
fix: regex for life/mana steal (#637)
ryanzhoudev Nov 14, 2022
967b45d
chore(release): v1.13.2-beta.5 [skip ci]
WynntilsBot Nov 14, 2022
edac71b
docs: update authenticating section (#623) [skip ci]
ryanzhoudev Nov 14, 2022
e5992f3
fix: Update spell cost ID ranges (#636)
P0keDev Nov 14, 2022
64fd918
chore(release): v1.13.2-beta.6 [skip ci]
WynntilsBot Nov 14, 2022
c0f2c83
ci: update github actions [skip ci]
DevScyu Nov 15, 2022
661a15f
fix: remove click to copy chat (#640)
ryanzhoudev Nov 15, 2022
a7d3aba
chore(release): v1.13.2-beta.7 [skip ci]
WynntilsBot Nov 15, 2022
1b3ff87
chore(release): v1.14.0 [skip ci]
WynntilsBot Nov 18, 2022
3d8f5c6
ci: fix workflow [skip ci]
DevScyu Nov 18, 2022
174a40a
chore(release): v1.14.0 [skip ci]
WynntilsBot Nov 18, 2022
7bac3cd
docs: Fix codeblocks not working (#638) [skip ci]
ryanzhoudev Nov 25, 2022
f790f30
feat: Switch to discord-game-sdk4j and Activity Party bug fixes. (#555)
Clashbestie Nov 25, 2022
03c9d08
chore(release): v1.14.1-beta.0 [skip ci]
WynntilsBot Nov 25, 2022
e52246f
fix: Revert feat: Switch to discord-game-sdk4j" (#647)
ryanzhoudev Nov 28, 2022
99a859c
chore(release): v1.14.1-beta.1 [skip ci]
WynntilsBot Nov 28, 2022
6aa0823
fix: Fix various ability bar bugs (#649)
ryanzhoudev Dec 8, 2022
36b2540
chore(release): v1.14.1-beta.2 [skip ci]
WynntilsBot Dec 8, 2022
26555fc
fix: update to match Wynn api (#644)
ryanzhoudev Dec 8, 2022
5739df9
chore(release): v1.14.1-beta.3 [skip ci]
WynntilsBot Dec 8, 2022
d98fd1d
fix: aioob in ChatManager (#643)
ryanzhoudev Dec 8, 2022
9029c6a
chore(release): v1.14.1-beta.4 [skip ci]
WynntilsBot Dec 8, 2022
c9565e1
fix: Powders & pouches not favouriting with Arabic numerals, missing …
ryanzhoudev Dec 8, 2022
4a1180d
chore(release): v1.14.1-beta.5 [skip ci]
WynntilsBot Dec 8, 2022
73bda2e
feat: add config reset button (#607)
ryanzhoudev Dec 8, 2022
10508ad
chore(release): v1.14.1-beta.6 [skip ci]
WynntilsBot Dec 8, 2022
c056dc5
ci: fix workflow [skip ci]
DevScyu Dec 9, 2022
df999ea
fix: Startup crash (#653)
ryanzhoudev Jan 3, 2023
550a9e5
chore(release): v1.14.1-beta.7 [skip ci]
WynntilsBot Jan 3, 2023
37ef9db
fix: Initial guild info message not being detected (#652)
ryanzhoudev Jan 19, 2023
ad73608
chore(release): v1.14.1-beta.8 [skip ci]
WynntilsBot Jan 19, 2023
57384b5
fix: remove bank page confirms (#656)
ryanzhoudev Jan 19, 2023
fa3d93b
chore(release): v1.14.1-beta.9 [skip ci]
WynntilsBot Jan 19, 2023
4bc8bbd
fix: proper icon fix (#655)
ryanzhoudev Jan 19, 2023
6829365
chore(release): v1.14.1-beta.10 [skip ci]
WynntilsBot Jan 19, 2023
b212e7d
fix: Mythic detection fix (#650)
ryanzhoudev Jan 25, 2023
b5f2491
chore(release): v1.14.1-beta.11 [skip ci]
WynntilsBot Jan 25, 2023
9a6c76b
fix: Fix crash on housing island (#663)
kristofbolyai Feb 15, 2023
e01d953
chore(release): v1.14.1-beta.12 [skip ci]
WynntilsBot Feb 15, 2023
374e255
fix: Prevent custom seaskipper menu crash (#664)
P0keDev Feb 17, 2023
a4520df
chore(release): v1.14.1-beta.13 [skip ci]
WynntilsBot Feb 17, 2023
c5b509d
feat: Remove support for stable update stream (#667)
P0keDev Feb 20, 2023
24703b1
chore(release): v1.14.1-beta.14 [skip ci]
WynntilsBot Feb 20, 2023
1a93a1e
chore(release): v1.15.0 [skip ci]
WynntilsBot Feb 21, 2023
f97f5ad
fix: Fix party finder crash on housing island (#669)
ENORMOUZ Apr 1, 2023
d60803c
chore(release): v1.15.1-beta.0 [skip ci]
WynntilsBot Apr 1, 2023
1ea89ce
feat: Add Artemis export button for waypoint manager GUI (#673)
kristofbolyai Apr 1, 2023
bf060a2
chore(release): v1.15.1-beta.1 [skip ci]
WynntilsBot Apr 1, 2023
cc98eb1
fix: The mod can now load Artemis (1.19.3) lootruns (#675)
kristofbolyai Apr 17, 2023
28538a3
chore(release): v1.15.1-beta.2 [skip ci]
WynntilsBot Apr 17, 2023
8a295f0
feat: Add K and M to convertEmeraldPrice (#661)
ENORMOUZ May 16, 2023
ffab244
chore(release): v1.15.1-beta.3 [skip ci]
WynntilsBot May 16, 2023
b9d15f5
chore: Remove broken quest book (#679)
ryanzhoudev Jul 18, 2023
b0e0d5b
chore(release): v1.15.1-beta.4 [skip ci]
WynntilsBot Jul 18, 2023
103a8b8
feat: Export favorites via command (#681)
ryanzhoudev Jul 24, 2023
1677480
chore(release): v1.15.1-beta.5 [skip ci]
WynntilsBot Jul 24, 2023
46408de
fix: Fixed TAB_EFFECT_PATTERN regex (#686)
ENORMOUZ Aug 12, 2023
71bf7fe
chore(release): v1.15.1-beta.6 [skip ci]
WynntilsBot Aug 12, 2023
e5cc971
fix: Fix Guild Map Crashing (#689)
ENORMOUZ Sep 13, 2023
f28c584
chore(release): v1.15.1-beta.7 [skip ci]
WynntilsBot Sep 13, 2023
76ed2da
fix: Fixed chat crash bug (#687)
ENORMOUZ Sep 15, 2023
0228ef2
chore(release): v1.15.1-beta.8 [skip ci]
WynntilsBot Sep 15, 2023
590726f
fix: do not crash with broken chat mention regex (#677)
ryanzhoudev Sep 16, 2023
5da7e73
chore(release): v1.15.1-beta.9 [skip ci]
WynntilsBot Sep 16, 2023
93739e0
Update issue templates
magicus Sep 16, 2023
94ce153
feat: Export favorites and waypoints from main menu (#696)
ShadowCat117 Nov 18, 2023
2f9e05b
chore(release): v1.15.1-beta.10 [skip ci]
WynntilsBot Nov 18, 2023
f22df6d
Update README.md
DevScyu Jan 21, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
feat: add corrupted bar (Wynntils#595)
* feat: add corrupted bar

* fix: change symbol, add hide default bar

Co-authored-by: byBackfish <maik@bybackifsh.de>
Co-authored-by: Magnus Ihse Bursie <mag@icus.se>
  • Loading branch information
3 people authored Sep 24, 2022
commit f821b799a020ba32d61a4e08a1b5b5edc74d980c
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ public class BossBarData extends PlayerData {
public static final Pattern BLOOD_POOL_PATTERN = Pattern.compile("§cBlood Pool §4\\[§c(\\d+)%§4]§r");
public static final Pattern MANA_BANK_PATTERN = Pattern.compile("§bMana Bank §3\\[(\\d+)/(\\d+)§3]§r");
public static final Pattern AWAKENED_PROGRESS_PATTERN = Pattern.compile("§fAwakening §7\\[§f(\\d+)/200§7]§r");
public static final Pattern CORRUPTED_PROGRESS_PATTERN = Pattern.compile("§cCorrupted §4\\[§c(\\d+)%§4]§r");
public static final Pattern FOCUS_PATTERN = Pattern.compile("§eFocus §6\\[§e(\\d+)/(\\d+)§6]§r");

public BossBarData() {
Expand All @@ -30,6 +31,7 @@ public void updateBossbarStats(SPacketUpdateBossInfo packet) {
updateAwakenedBar(packet);
updateManaBankBar(packet);
updateFocusBar(packet);
updateCorruptedBar(packet);
}

private void updateBloodPool(SPacketUpdateBossInfo packet) {
Expand Down Expand Up @@ -58,6 +60,13 @@ private void updateAwakenedBar(SPacketUpdateBossInfo packet) {
get(CharacterData.class).setAwakenedProgress(awakeningProgress);
}

private void updateCorruptedBar(SPacketUpdateBossInfo packet) {
Matcher m = CORRUPTED_PROGRESS_PATTERN.matcher(packet.getName().getFormattedText());
if (!m.matches()) return;
int corruptedProgress = Integer.parseInt(m.group(1));
get(CharacterData.class).setCorruptedProgressPercent(corruptedProgress);
}

private void updateFocusBar(SPacketUpdateBossInfo packet) {
Matcher m = FOCUS_PATTERN.matcher(packet.getName().getFormattedText());
if (!m.matches()) return;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ public class CharacterData extends PlayerData {
private int manaBank = -1;
private int maxManaBank = -1;
private int awakenedProgress = -1;
private int corruptedProgressPercent = -1;
private int focus = -1;
private int maxFocus = -1;
private int level = -1;
Expand Down Expand Up @@ -143,6 +144,8 @@ public int getMaxAwakenedProgress() {
return currentClass == ClassType.NONE ? -1 : 200;
}

public int getCorruptedProgressPercent() { return currentClass == ClassType.NONE ? -1 : corruptedProgressPercent; }

public int getFocus() {
return currentClass == ClassType.NONE ? -1 : focus;
}
Expand Down Expand Up @@ -216,6 +219,8 @@ public void setAwakenedProgress(int awakenedProgress) {
this.awakenedProgress = awakenedProgress;
}

public void setCorruptedProgressPercent(int corruptedProgressPercent) { this.corruptedProgressPercent = corruptedProgressPercent; }

public void setFocus(int focus) { this.focus = focus; }

public void setMaxFocus(int maxFocus) { this.maxFocus = maxFocus; }
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -356,6 +356,12 @@ public void updateBossBar(PacketEvent<SPacketUpdateBossInfo> e) {
if (awakeningBarMatcher.matches()) e.setCanceled(true);
}

if (OverlayConfig.CorruptedBar.INSTANCE.hideDefaultBar) {
// (!) Do not remove .getName() check, Intellij is wrong about it
Matcher corruptedMatcher = BossBarData.CORRUPTED_PROGRESS_PATTERN.matcher(e.getPacket().getName().getFormattedText());
if (corruptedMatcher.matches()) e.setCanceled(true);
}

if (OverlayConfig.Focus.INSTANCE.hideDefaultBar) {
// (!) Do not remove .getName() check, Intellij is wrong about it
Matcher focusMatcher = BossBarData.FOCUS_PATTERN.matcher(e.getPacket().getName().getFormattedText());
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,7 @@ public void onEnable() {
registerOverlay(new BloodPoolBarOverlay(), Priority.NORMAL);
registerOverlay(new ManaBankBarOverlay(), Priority.NORMAL);
registerOverlay(new AwakenedProgressBarOverlay(), Priority.NORMAL);
registerOverlay(new CorruptedBarOverlay(), Priority.NORMAL);
registerOverlay(new FocusBarOverlay(), Priority.NORMAL);
registerOverlay(new ExpBarOverlay(), Priority.NORMAL);
registerOverlay(currentMaskOverlay = new CurrentMaskOverlay(), Priority.NORMAL);
Expand Down Expand Up @@ -116,6 +117,7 @@ public void onEnable() {
registerSettings(OverlayConfig.Mana.class);
registerSettings(OverlayConfig.BloodPool.class);
registerSettings(OverlayConfig.ManaBank.class);
registerSettings(OverlayConfig.CorruptedBar.class);
registerSettings(OverlayConfig.AwakenedProgress.class);
registerSettings(OverlayConfig.MaskOverlay.class);
registerSettings(OverlayConfig.Focus.class);
Expand Down Expand Up @@ -149,10 +151,6 @@ public ActionBarOverlay getActionBarOverlay() {
return actionBarOverlay;
}

public CurrentMaskOverlay getCurrentMaskOverlay() {
return currentMaskOverlay;
}

public InfoFormatter getInfoFormatter() {
return infoFormatter;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -255,6 +255,46 @@ public enum AwakenedProgressTexture {
}
}

@SettingsInfo(name = "corrupted_bar", displayPath = "Utilities/Overlays/Corrupted Bar")
public static class CorruptedBar extends SettingsClass {
public static CorruptedBar INSTANCE;

@Setting(displayName = "Hide Default Corrupted Progress Bar", description = "Should the corrupted progress boss bar be hidden?")
public boolean hideDefaultBar = true;

@Setting(displayName = "Corrupted Progress Width", description = "How wide should the corrupted progress be in pixels?\n\n§8This will be adjusted using Minecraft's scaling.")
@Setting.Limitations.IntLimit(min = 0, max = 81)
public int width = 81;

@Setting(displayName = "Corrupted Progress Orientation", description = "How orientated in degrees should the corrupted progress bar be?\n\n§8Accompanied text will be removed.")
public OverlayRotation overlayRotation = OverlayRotation.NORMAL;

@Setting(displayName = "Corrupted Progress Texture", description = "What texture should be used for the corrupted progress bar?")
public CorruptedProgressTexture corruptedProgressTexture = CorruptedProgressTexture.a;

@Setting(displayName = "Animation Speed", description = "How fast should the animation be played?\n\n§8Set this to 0 for it to display instantly.")
@Setting.Limitations.FloatLimit(min = 0f, max = 10f)
public float animated = 2f;

@Setting(displayName = "Text Shadow", description = "What should the text shadow look like?")
public SmartFontRenderer.TextShadow textShadow = SmartFontRenderer.TextShadow.OUTLINE;

public enum CorruptedProgressTexture {
Wynn,
Brune,
Aether,
Skull,
Inverse,
Skyrim,
Rune,
a,
b,
c,
d
// following the format, to add more textures, register them here with a name and create a special case in the render method
}
}

@SettingsInfo(name = "current_mask_overlay", displayPath = "Utilities/Overlays/Mask")
public static class MaskOverlay extends SettingsClass {
public static MaskOverlay INSTANCE;
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
/*
* * Copyright © Wynntils - 2022.
*/

package com.wynntils.modules.utilities.overlays.hud;

import com.wynntils.Reference;
import com.wynntils.core.framework.instances.data.CharacterData;
import com.wynntils.core.framework.overlays.Overlay;
import com.wynntils.core.framework.rendering.SmartFontRenderer;
import com.wynntils.core.framework.rendering.colors.CommonColors;
import com.wynntils.core.framework.rendering.colors.CustomColor;
import com.wynntils.core.framework.rendering.textures.Textures;
import com.wynntils.core.framework.settings.annotations.Setting;
import com.wynntils.core.utils.objects.Pair;
import com.wynntils.modules.core.enums.OverlayRotation;
import com.wynntils.modules.utilities.configs.OverlayConfig;
import net.minecraftforge.client.event.RenderGameOverlayEvent;
import net.minecraftforge.fml.common.gameevent.TickEvent;

public class CorruptedBarOverlay extends Overlay {

public CorruptedBarOverlay() {
super("Corrupted Bar", 81, 21, true, 0.65f, 1.03f, -10, -38, OverlayGrowFrom.BOTTOM_RIGHT, RenderGameOverlayEvent.ElementType.HEALTH);
}

@Setting(displayName = "Flip", description = "Should the filling of the bar be flipped?")
public boolean flip = false;

@Setting(displayName = "Text Position", description = "The position offset of the text")
public Pair<Integer, Integer> textPositionOffset = new Pair<>(-40, -10);

@Setting(displayName = "Text Name", description = "What should the colour of the text be?")
public CustomColor textColor = CommonColors.RED;

private static int corruptedPercent = 0;
private static final int maxCorruptedPercent = 100;

@Override
public void tick(TickEvent.ClientTickEvent event, long ticks) {
if (!(visible = (get(CharacterData.class).getCorruptedProgressPercent() != -1 && !Reference.onLobby))) return;

if (OverlayConfig.CorruptedBar.INSTANCE.animated > 0.0f && OverlayConfig.CorruptedBar.INSTANCE.animated < 10.0f && !(corruptedPercent >= maxCorruptedPercent)) {
corruptedPercent -= (OverlayConfig.CorruptedBar.INSTANCE.animated * 0.1f) * (corruptedPercent - (float) get(CharacterData.class).getCorruptedProgressPercent());
} else {
corruptedPercent = get(CharacterData.class).getCorruptedProgressPercent();
}
}

@Override
public void render(RenderGameOverlayEvent.Pre event) {
switch (OverlayConfig.CorruptedBar.INSTANCE.corruptedProgressTexture) {
case Wynn:
drawDefaultBar(-1, 8, 0, 17, textColor);
break;
case a: drawDefaultBar(-1, 7, 18, 33, textColor);
break;
case b: drawDefaultBar(-1, 8, 34, 51, textColor);
break;
case c: drawDefaultBar(-1, 7, 52, 67, textColor);
break;
case d: drawDefaultBar(-1, 7, 68, 83, textColor);
break;
case Aether:
drawDefaultBar(-1, 7, 100, 115, textColor);
break;
case Skull:
drawDefaultBar(-1, 8, 116, 131, textColor);
break;
case Skyrim:
drawDefaultBar(-1, 8, 132, 147, textColor);
break;
case Rune:
drawDefaultBar(-1, 8, 148, 163, textColor);
break;
}
}

private void drawDefaultBar(int y1, int y2, int ty1, int ty2, CustomColor cc) {
if (OverlayConfig.CorruptedBar.INSTANCE.overlayRotation == OverlayRotation.NORMAL) {
drawString(get(CharacterData.class).getCorruptedProgressPercent() + " ☠ " + maxCorruptedPercent, textPositionOffset.a - (81 - OverlayConfig.CorruptedBar.INSTANCE.width), textPositionOffset.b, cc, SmartFontRenderer.TextAlignment.MIDDLE, OverlayConfig.CorruptedBar.INSTANCE.textShadow);
}

rotate(OverlayConfig.CorruptedBar.INSTANCE.overlayRotation.getDegrees());
drawProgressBar(Textures.Overlays.bars_health, -OverlayConfig.CorruptedBar.INSTANCE.width, y1, 0, y2, 0, ty1, 81, ty2, (flip ? -corruptedPercent : corruptedPercent) / (float) get(CharacterData.class).getCorruptedProgressPercent());
}

}