Compare commits

...

372 Commits

Author SHA1 Message Date
590638a156 Update TOCs 2024-12-20 22:17:35 -06:00
e6bd39352c Fix max chi power not always updating correctly 2024-11-27 14:40:54 -06:00
a4060dff6f Update smaller changelog 2024-11-13 09:00:20 -06:00
268a6c6fbc Update TOCs 2024-11-13 08:58:17 -06:00
b75112db79 Fix error in CD module set to WhenReady mode 2024-08-30 21:54:08 -05:00
42e76dde72 Fix cooldown display for overridden spells
When a spell is overridden by another, our cooldown bar stops being able to track it. Normally this is fine if the spell completely changes as you probably don't expect a cd bar for Backstab to track Gloomblade.

But when the overridden spell shares the same name as the base spell, such as Fire Breath for Evokers with the Font of Magic talent, you very much would expect the bar to track both.

With this fix, tracking the base spell will show the cd for the overridden version as well.
2024-08-26 17:18:39 -05:00
43aa303887 Bump for new dependency versions 2024-08-25 22:46:07 -05:00
30ec3750c1 Fix error when using an invalid spell with a custom bar on 11.x 2024-08-14 11:34:54 -05:00
73891bca4b Update TOC for TWW 2024-08-14 10:20:29 -05:00
66f4492fa7 Fix spell cooldown bars in 11.x
GetSpellCooldown used to return 1 for "has duration", but the new native version returns true. Fun.

Additionally, it looks like the events triggering UpdateCustomBarEvent() are passing a nil argument that the mod thought was supposed to be the affected unit. So I also fixed that, though I don't know if that's an 11.x thing or not.

https://www.wowace.com/projects/ice-hud/issues/363
2024-07-27 15:42:31 -05:00
6c1c68a0c3 Update classic-era TOC 2024-07-25 22:34:32 -05:00
b17582afab Remove all the old right-click menu hackery
Evidently this isn't needed anymore on any current client, 11.x, Classic-era, et al.
2024-07-25 22:32:29 -05:00
e94138d201 Restore context menus for Health and Info modules
Apparently we don't have to do any of this anymore (and might not have had to do it for a long time, but I missed the memo) so if we can, just use the built-in menuing stuff. Setting focus doesn't trigger taint with this.
2024-07-25 22:25:55 -05:00
8a3f9e19d0 Fix error opening options in published package 2024-07-24 16:03:35 -05:00
1f4a8aefa7 Update TOC for 11.0 2024-07-24 09:32:06 -05:00
1ca424dccb Enable profile import/export
The UI for this is still rough, but it works fine.
2024-07-24 09:31:48 -05:00
8b9263a2c5 Update changelog 2024-07-21 14:07:22 -05:00
40efe6a551 Fix up uses of UnitBuff and UnitDebuff for 11.0.2 2024-07-21 14:00:48 -05:00
f15dda769d Fix popup menu replacement code error on 11.0.2 (temp)
This removes the menu replacement code that is preventing errors when trying to focus someone or dismiss a pet through a right-click menu on an addon. There is a new API, UnitPopup_OpenMenu, that is a replacement for ShowMenu, but it's not a drop-in replacement, so until I have access to the beta or an 11.0.2 PTR there's not much I can do here.
2024-07-21 13:54:45 -05:00
9b063bed63 More TWW/11.0.2 compatibility
I don't have beta access so I can't test this yet, but this should catch everything in the Deprecated_11_0_0 file in wow's official ui source as well as some stuff not mentioned but reported by users.
2024-07-21 13:51:17 -05:00
d451969177 Use packager action v4 2024-07-20 09:05:23 -05:00
6c2e759f45 Basic TWW compatibility 2024-06-22 18:07:42 -05:00
b0f7c776db Fix the Vengeance module
One of the return values of UnitAura is the Vengeance amount and the GameTooltip scanning thing is no longer working.
2024-05-12 11:11:53 -05:00
c425206748 Hopefully fix Vigor bar not showing up for some types of dragons
Specifically the Algarian Stormrider which has a different flavor of Vigor widget with customized colors. Apparently that's a whole different widget id. So now instead of checking for just the one vigor widget, we look up all widgets in the vigor set and use those to see if any vigor bar is showing.
2024-05-11 16:19:00 -05:00
57ddf62f73 Maybe stop castbar flashing sometimes 2024-05-11 15:42:54 -05:00
67cd7330ad Fix swapped DK runes in Cataclysm Classic
Fixes wowace ticket # 357
2024-05-11 15:29:52 -05:00
5c344cfac1 Update TOC 2024-05-09 00:04:36 -05:00
681e1f7b55 Update changelog 2024-04-30 23:25:35 -05:00
038ea16642 Support Cataclysm Classic 2024-04-30 23:16:42 -05:00
12c509b133 Update TOCs 2024-04-15 17:05:05 -05:00
2ae826654a Update LibRangeCheck version
Should fix taint issues as reported in https://www.wowace.com/projects/ice-hud/issues/353
2024-04-04 08:14:32 -05:00
acee3f4725 Fix error when loading in while mounted 2024-02-10 14:12:28 -06:00
2db6ddea57 Only hide Blizzard Vigor bar, not all fill-ups
This fixes the bar from the Digging event in 10.2.5 not showing. For real this time.
2024-02-10 10:47:04 -06:00
7e4a6ecab6 Attempt to fix other uses of PowerBarContainer
Apparently other things are now using the game's UIWidgetPowerBarContainerFrame but we're forcing it to be hidden due to a variety of factors. This attempts to restrict the Hide behavior of that frame to only when we're Dragonriding.
2024-01-21 12:36:15 -06:00
af33ab9781 Fix Vigor showing up sometimes when it shouldn't
Seems like UnitPowerMax for the AlternateMount power returns the actual max from PLAYER_ENTERING_WORLD until you mount and then dismount a Dragonriding mount. This wasn't previously the case.

Now we rely on the native widget info to tell us whether it believes it should be on or not.
2024-01-19 09:02:41 -06:00
c0262de622 Only use HasBuff method as a fallback
If we can check the power type, we should rely on only that.
2024-01-19 07:26:55 -06:00
cfa86813a7 Update TOC 2024-01-16 17:27:43 -06:00
c85c304eb6 Enable GCD, target target buffs in Classic 1.15+ 2024-01-07 14:49:42 -06:00
5321f7c64d Prevent error
Wowace ticket #351
2023-12-26 15:47:36 -06:00
6b2eb8d6e2 Update TOC for Classic-era 2023-12-10 18:58:52 -06:00
c72b67235d Enable TargetCastBar on Classic-era 1.15+ 2023-12-10 18:58:08 -06:00
140596b930 Fix Stagger bar error for 10.2.0
Fixes wowace ticket 348
2023-11-08 09:33:17 -06:00
6ddb056cdf Update TOC 2023-11-07 16:36:03 -06:00
8df330d3b4 Update TOC 2023-09-08 10:30:11 -05:00
1f9a1a3100 Update TOC for Classic-era 2023-08-23 14:38:11 -05:00
40a25a3315 Apply Strata adjustment in a few more places 2023-08-02 17:38:47 -05:00
6cee8c738c Apply strata adjustment inside BarFactory instead of every callsite 2023-08-02 08:25:34 -05:00
40fc8187fd Add ability to adjust strata globally
Submitted by slowkerd from Curseforge (thanks!)
2023-08-02 08:16:12 -05:00
b32f090644 using table.remove to not leave a hole in the array (#36) 2023-07-23 23:57:22 -05:00
d9cfb3a09c Fix 10.1.5 error building a player menu 2023-07-16 22:14:23 -10:00
8bc7b1ee90 Update TOCs 2023-07-11 16:52:17 -05:00
9cd800ee86 Update changelog 2023-07-05 13:33:12 -05:00
ca6008780f Bump TOC for Wrath-Classic 3.4.2 2023-07-04 10:18:52 -05:00
9a727e4893 Fix Vigor with new mount type(s)
I explicitly added what I believe to be the spell id for the new Grotto Netherwing Drake so it *should* work regardless, but then also discovered that the flying mount's UnitPowerMax is 0 unless you're on a Dragonriding mount, so that should be the longer-term fix for whenever old-world mounts add Dragonriding capability (10.1.5?).
2023-07-04 10:01:31 -05:00
4d71dcc660 Possible fix to reported issue
I can't reproduce the problem, but this should cover it if it happens.

https://www.wowace.com/projects/ice-hud/issues/344
2023-06-05 17:39:36 -05:00
343ac7b70b Fix aura icons not always showing on custom bars 2023-05-18 10:17:13 -05:00
573049f77e Fix Custom Bar showing empty bar in Missing mode 2023-05-18 10:15:38 -05:00
8dc173ae81 Fix custom bar showing when disabled and set to Missing
Fixes wowace ticket #343
2023-05-18 10:12:17 -05:00
5e04ace0f4 Fix CC modules on Wrath Classic 2023-05-18 09:41:44 -05:00
37108d3487 Increase max scale to 400% by request 2023-05-12 22:17:27 -05:00
8cd7c4b044 Add 10.1 dragonriding mount 2023-05-06 13:15:39 -05:00
bfffdd82d7 Fix vigor on entering world
Forgot to send the event argument, so it was returning early.

Fixes #34
2023-05-03 18:23:52 -05:00
24c45f320f Update TOC, add icon, fix Vigor for 10.1 2023-05-03 18:22:36 -05:00
1db8545b63 Update other changelog 2023-04-02 21:47:03 -05:00
18fa31807c Hide Debuff frame along with Buffs if desired 2023-04-01 20:58:25 -05:00
594ea0a3e3 Fix errors when toggling off Hide Blizz 2023-04-01 20:53:53 -05:00
cb83a3f63f Add option to hide during Cataloging 2023-04-01 20:45:37 -05:00
077286fd5f Show Runic Power on a 0-100ish scale with DogTags off 2023-04-01 20:17:50 -05:00
a50a313314 Update TOCs 2023-04-01 15:02:35 -05:00
271bb38a69 Add more Polymorph ranks 2023-02-06 20:15:52 -06:00
0e11a40d3a Don't hide Blizzard Totems by default on 10.0 2023-02-06 00:19:08 -06:00
5020279748 Fix errors when playing Faire games 2023-02-06 00:16:15 -06:00
cfaa09a541 Expose Totems Hide Blizzard setting 2023-02-01 16:41:31 -06:00
a0ed3ae6e6 Update TOCs 2023-01-25 13:40:36 -06:00
7709cb9130 Fix AltPower bar showing when it shouldn't 2023-01-22 15:56:41 -06:00
c1f631b732 Update changelog 2023-01-21 20:42:15 -06:00
6c44ddc93a Fix IceHUD hiding climbing, film, etc. frames
Fixes wowace ticket 336
2023-01-21 20:41:03 -06:00
8b45079d38 Don't forcefully show Blizzard frame
This enables other mods to hide Vigor even if IceHUD is told not to.
2023-01-15 22:23:47 -06:00
b1adbe8090 Add Dragonriding Vigor module
This displays the Vigor charges for the player whenever they're on a Dragonriding mount (which is detected via explicit buff ID scanning from a hardcoded list...I'd like to make that more robust so I don't have to keep up with new mounts being added, but I'm not sure how to do it another way just yet). The Alternate Power bar is hidden if the Vigor module is enabled so that we don't end up with duplicate Vigor trackers (although right now it flashes on the screen before the mount buff is detected, so I'd also like to fix that...).

I've effectively had to implement my own Vigor module from scratch by poking into the internals of the Vigor widget by its ID in order to determine the recharge amount on the final Vigor charge because there's currently no API to get this information otherwise. Hopefully this gets added; if it does, I'll happily rip out this widget inspection junk. Aside from the partial charge stuff, this is just a skinned version of an Alternate Power indicator that only shows when the user is on a dragonriding mount. ClassPowerCounter doesn't sound like a particularly appropriate base class for this, but since Vigor is implemented as Alternate Power, it worked out nicely.
2023-01-15 13:03:18 -06:00
01a017c179 Add support for background and frame
This adds more robust visuals on the power counters where we can (finally) display artwork similar to the default UI where the charges are sometimes framed by something and sometimes have a textured background behind empty charges. This doesn't yet add support for animations. Child classes can take advantage of this simply by implementing GetFrameAtlas() and/or GetBackgroundAtlas().

Note: as part of this, I moved the rune texture's layer to "BORDER" which doesn't feel quite appropriate, but does allow the layering to work as I want. I don't think this is going to be an issue since texture layers should only apply internal to a frame's strata (meaning this shouldn't suddenly cause an existing power counter to display above/below something else), but I wanted to document it in case something weird does come up later.

I also hardcoded a + 10 on the width/height for the frame since that's what works for Vigor. If those values don't work for any future users of this, it's easily adjusted.
2023-01-15 12:57:58 -06:00
b8aece0da3 Add support for a partially-ready final rune
This adds support for a class power counter that has a visible recharge on the final "rune." Most power counters are either fully ready or full un-ready (where the recharge is hidden away), but Dragonriding's Vigor resource does show the recharge of the final point, which this now supports.

Child classes can support this by setting self.partialReady to the index of the rune that's partially ready, and self.partialReadyPercent to the percentage that that final rune is ready (0.0-1.0). If the partially-charged point uses a different texture, the child can also implement GetPartialRuneAtlas() and it will be used only for the partially-ready rune.

If we ever need to be able to show multiple partially-ready runes, this will need a small refactor.
2023-01-15 12:52:22 -06:00
6b9b4a358c Move altpower to a local variable
This isn't used anywhere else, so there's no reason for it to pollute the global namespace. And being local now, it also doesn't need the IceHUD prefix on its name.
2023-01-15 12:46:20 -06:00
72adca99f9 Fix whitespace 2023-01-15 12:45:19 -06:00
f8e7cf06d6 Combine rune texture/color set into one method
This enables a simpler method of making sure the appropriate texture is set and using the appropriate color (for after a rune was modified to darkened/hidden).
2023-01-15 12:43:56 -06:00
059808c980 Add ability to opt out of displaypower event 2023-01-15 12:41:16 -06:00
689df94d55 Refactor repeated code into a function
I need this for an upcoming feature, and it turns out that the "new rune just became ready" feature didn't cooperate with width-growing runes anyway, so this is also a bugfix for that (I don't know that we have any width-growing power types in the game today, but still).
2023-01-15 12:40:51 -06:00
d49884198d Only apply numeric offset when not in numeric mode
This offset is an additional offset meant to apply only when a class power counter is in a non-Numeric mode with the "also show numeric" checkbox checked. This offset is hidden when in Numeric mode, but was still being applied, therefore making it an option you could not change without going through multiple other steps first.
2023-01-15 12:35:14 -06:00
8627ad39d5 Update changelog 2023-01-13 09:34:36 -06:00
8c62a841fd Update changelog 2022-12-19 12:51:51 -06:00
7496475ff4 Fix potential nil access
I can't reproduce a problem here, but based on some user feedback, this could potentially be an issue. Most other modules are calling the super's Update() first thing, but these modules call them later, so healthPercentage may not be defined at this point.
2022-12-19 12:19:10 -06:00
c5c44edf64 Fix several issues with low thresholds
This addresses a user-reported issue where Low Threshold was not usable with Color By Health/Mana % disabled, due to some internal technical reasons. This was exacerbated by the recent fix that allowed Low Threshold and Color By Health % to work together.

This also fixes the low threshold flash to apply immediately when changing the option, and fixes the Low Threshold % slider to be usable without the Low Flash option set.

Finally, it hides the Low Flash option for bars that don't support it (right now that's just PlayerMana, I think because it only sets the low threshold to the Min Mana Color even if the class uses a different power type...something for future me...).

Fixes wowace ticket #334
2022-12-13 20:48:02 -06:00
59f2792ce8 Update changelog 2022-11-25 17:02:25 -06:00
a80daface7 Unify low flash and low color thresholds
Low Flash was using >= while Low Color was using >, so they would activate at ever-so-slightly different values (0.4 vs 0.39999, for example).
2022-11-25 15:31:26 -06:00
f6db2f3b7c Fix Low Threshold and Color By Health % to work together
If Low Threshold was checked, then scaling by health/mana % was getting overridden and forced to the Max Health/Mana Color after being set to the scaled value.
2022-11-25 15:30:05 -06:00
5d09cad6cb Update changelog
v1.14.0 got posted again as if it were the newest version, so this small update remedies that.
2022-11-23 22:37:41 -06:00
8fc2e326aa Add option to scale absorb bar by health
By user request.
2022-11-23 18:50:52 -06:00
d775603ec0 Add module showing Energy for Druids
This shows the player's current Energy amount when they're in a form that doesn't use Energy. For example, this could show the user how much energy they currently have while they're in Bear form so that they can shift away and wait on their energy to refill.

Note: requires a new version of LibDogTag-Unit for the bar text tags to function if DogTags are enabled.
2022-11-18 17:08:26 -06:00
70bba2f186 Add ability to set module description
This is the text that shows up when hovering over the module in the Module Options list.
2022-11-18 16:58:16 -06:00
8ac9bee610 Fix instant casts for non-player spells
I was out questing and kept seeing "Near Training Gem" pop as an instant-cast. This filter seems to have stopped it.
2022-11-18 11:44:52 -06:00
07bda8e84d Add more Custom Bar display controls
Add ability for buff/debuff watchers to only display when the specified buff/debuff is missing. This also adds the ability to require that the given unit exists. So if you had Unit set to Target, Display mode set to Missing, and Only if unit exists checked, you'd show the bar if you have a target and they don't have the given buff/debuff.
2022-11-17 17:14:49 -06:00
5712114eb8 Fix Charged point support in ComboPointsBar 2022-11-16 21:14:51 -06:00
2a0db2eb01 Show charged combo point in Numeric mode 2022-11-16 21:09:44 -06:00
7d32b6d8c6 Fix player castbar flashes
There are controls on the player castbar module for flashing when a spell succeeds or fails, and separate controls for flashing when an instant cast completes. Those were broken (flashing never happened), but now work again.

UpdateBar() was necessary in MyOnUpdate() in the event that no other spell has been cast (in order to set the alpha so that the bottom text displays). The spellId is being passed along so that spells that aren't currently being cast can have their name and icon displayed appropriately, and so the early-out for "no known spell" doesn't trigger (which allows the Flash to actually work). The self.current reset fixes instant casts after a normal cast (we were only clearing the "current" spell conditionally when we only meant to filter StopBar, so if it wasn't cleared, future successful casts thought they were for a different spell than was currently being cast.
2022-11-16 13:09:58 -06:00
60d44601d1 Update changelog 2022-11-15 00:30:29 -06:00
b3cf33a945 Increase TOC for 10.0.2 2022-11-15 00:27:26 -06:00
3ddc2f9d2f Add more color 2022-11-13 11:33:05 -06:00
d6adaedc93 Adjust for 10.0 client
This option moved, so point to the new location.
2022-11-13 11:30:29 -06:00
6a985bc67a Add Evoker, empowered casting support 2022-11-11 11:29:15 -06:00
3a5e58bf34 Add Spell ID support for aura tracking (#31) 2022-11-06 08:34:01 -06:00
b467af21c0 Fix CC and Invuln not showing immediately
This is the same fix as was applied to RollTheBones in commit 46883e355b but I failed to audit the rest of the mod for places where this was possible. This one was reported over on the Curse addon page comments.
2022-10-31 23:36:38 -05:00
acc400de6e Fix error on Classic with Hide Party
I neglected to test the new party-hide implementation on pre-10.0. It was not fully implemented. This implementation is from Pitbull4 and is more complicated than I need, but certainly does the job and allows for some future usage if needed.

Fixes wowace ticket #330
2022-10-30 23:21:31 -05:00
cac0deeb3c Update license with current year 2022-10-28 22:48:37 -05:00
e951d40b12 Don't package file just meant to help packager 2022-10-28 22:48:31 -05:00
46883e355b Fix RollTheBones not showing immediately when cast
I guess UNIT_AURA now provides a third argument that it wasn't before. So instead of relying on a third argument, just override the event name to something we control and key off that for avoiding updates.
2022-10-28 22:44:38 -05:00
004df582ef Update changelog 2022-10-27 20:34:19 -05:00
b8cf6e90b0 Fix error on 10.0
I guess this frame is gone. I don't remember why this was necessary.
2022-10-27 20:32:47 -05:00
d0c06c7b55 Add sponsor file 2022-10-27 09:09:50 -05:00
8858459b10 Disable Runes Hide Blizzard option
This is no longer functional in 10.0 and I can't find an easy replacement, so I'm removing the functionality for 10.0+ for now. The entire player frame can still be hidden, which also hides the runes, so I don't feel like this is super critical to have.

Fixes #26
2022-10-27 08:56:53 -05:00
86e40187a2 Update Party hide feature for 10.0 compatibility 2022-10-25 22:42:46 -05:00
62bcc17ed6 Increase TOC to 10.0 2022-10-25 21:43:46 -05:00
52c9b51e8d Temp fix for error in 10.0
I need to find the new way to disable party frames, but this gets the addon loaded for now.
2022-10-25 21:43:13 -05:00
aa03a0b332 Add support for max power changing
Evokers can spec into an additional Essence, so we need to handle the power counter increasing/decreasing. This was a fundamental change to the class power counter, so I'm sure something else broke somewhere. A casual glance at other classes/specs seems fine, though...
2022-10-25 21:43:05 -05:00
3017b5dd18 Rename Anima Charged to Charged
Charged combo points are still a thing, but they're no longer called "Anima-charged" or relate to Kyrian.
2022-10-25 21:42:32 -05:00
1f54f7d41d Use new player castbar frame name 2022-10-25 21:42:13 -05:00
5b73d3b35f Update to correct LibDogTag url 2022-10-04 22:36:41 -05:00
decb0017f3 Update changelog 2022-10-04 22:33:35 -05:00
a32b75bf44 Update to latest packager example 2022-09-22 11:01:21 -05:00
6c506579be Add Wago packaging support 2022-09-22 10:46:11 -05:00
701fb1373f Fix Runes disappearing for DK on Wrath
MaxPower events fire, but I guess only Legion+ actually returns rune counts from this function. On Wrath it always returns 0, so the CheckMaxNumRunes logic was hiding all runes.
2022-09-20 14:27:31 -05:00
20d26d8f5e Update changelog for release 2022-09-19 10:21:41 -05:00
5a41d9a7f4 Fix ShadowOrbs causing priests to freeze/hang on login
I would still like to find a way to feature-flag this instead of WowVer-flag it, but it's not super important for now.
2022-09-19 10:21:02 -05:00
18d827965c Update changelog 2022-09-18 23:16:04 -05:00
c2183f99a0 Add missing feature flag definition 2022-09-18 23:07:07 -05:00
7ceb70737a Fix combo points display in Classic Era 2022-09-18 22:57:01 -05:00
faa3d326aa Replace WowVer checks in class power counters 2022-09-18 22:43:04 -05:00
9fc90551e2 Fix Charged combo points feature flag 2022-09-18 22:35:19 -05:00
0af47119e3 Continue replacement of WowVer checks 2022-09-18 21:49:53 -05:00
955fa6efdc Continue replacement of WowVer checks 2022-09-18 17:54:35 -05:00
41ae17ba9a Continue replacement of WowVer checks 2022-09-18 17:50:37 -05:00
5bc1f04504 Remove HolyPower reference from most power modules 2022-09-18 15:37:01 -05:00
09e1832fbe Fix more invalid texture layers 2022-09-18 15:36:45 -05:00
7c3fc54d26 Fix invalid texture layer
This is an error in 10.0 and was wrong before that.
2022-09-18 15:36:34 -05:00
8972f7eed5 Fix MaxPower event flag
I'm not sure how this got set the way it was...the event definitely exists in > 8.0...
2022-09-18 15:36:06 -05:00
9e68edbc43 Detect SnD max changing more reliably 2022-09-18 15:34:36 -05:00
a259db6b8a Use UnitPowerMax where available 2022-09-18 15:34:27 -05:00
d10586d477 More culling of WowVer checks 2022-09-18 13:33:51 -05:00
c804ba178b Convert a few more checks into feature flags 2022-09-18 08:30:06 -05:00
f04c5db493 Re-enable dev-only profile export/import
Exporting works pretty well, but importing is rough (mostly because error messaging isn't quite in place, and it's not obvious that you have to close the window to execute the import). I found a generic json serializer, decided to adapt it to WoW, and it seems to work.

But anyway, I saw this code sitting around and figured it wouldn't take too much work to get it in working order. I was mostly right.
2022-09-02 21:44:12 -05:00
1de917223f Use new Classic expansion checks where available 2022-09-02 20:48:10 -05:00
fa064dc866 Update changelogs 2022-09-02 14:35:27 -05:00
ee72cd1f33 Add feature flag for UnitGroupRolesAssigned 2022-09-02 14:31:51 -05:00
777cf01174 Add feature flag for Heal Prediction
And turn it on for Wrath Classic, because apparently it works there.
2022-09-02 14:27:33 -05:00
97e81018c7 Update for Wrath Classic (non-BCC pre-patch)
Apparently in full-blown Wrath classic, post-BCC-pre-patch, there's a new WOW_PROJECT constant that needs to be used.
2022-09-02 14:26:54 -05:00
b65909c570 Wrath updates for Paladin GCD, Rogue SnD 2022-08-30 22:25:16 -05:00
b33a82622f Update changelogs 2022-08-30 22:03:46 -05:00
96a8fb2c3d Bump TOC for retail 2022-08-30 22:01:00 -05:00
6c623d6965 Initial Wrath-Classic compatibility
Briefly fought a training dummy with a Death Knight and a Shaman. I'm sure stuff like Slice-and-dice will need attention for talents moving around and such.
2022-08-30 21:59:58 -05:00
d31872512e Add support for blocked submenu options
Some menus, such as when targeting other players, use mixins which are themselves menus. We have to dive down one more layer to resolve those. The official UI source does this submenu thing (as opposed to recursion) so this should exactly mimic how the base game now works.
2022-06-06 09:02:43 -05:00
d424afdab1 Rework blocked menu options for 9.2.5
Since 9.2.5 completely re-worked UnitPopupMenus, IceHUD's "Set Focus" right-click menu option overrides were broken. This restores the override so that it can still suppress the tainted functionality.

Additionally, it turns out that having Clique installed replaces this entire thing somehow and makes Set Focus et al function (with IceHUD's ClickCastFrames registration). I don't know what that magic is about, but none of this munging happens and the tainted paths work fine. Interesting.

Fixes wowace ticket #319
2022-06-05 23:30:09 -05:00
9500bdf393 Fix error on BCC
Fixes #21
2022-06-01 16:26:12 -05:00
6325ed1ade Fix changelogs
This is why Unreleased is used instead...
2022-06-01 08:31:05 -05:00
a4c44a5809 Update TOC 2022-06-01 08:30:21 -05:00
82db70969a Remove UnitPopupButtons usage
I need to find a way to reintroduce this, but Blizzard's new method of building these frames doesn't look like it's going to be particularly easy. This stops error popups on 9.2.5
2022-06-01 08:29:39 -05:00
47931922bd Fix target health updating infrequently on Classic 2022-05-02 12:22:07 -05:00
af74c9e3fe Update changelog 2022-03-28 10:30:30 -05:00
611f37a1f3 Add reported missing nil check
Fixes #20 (github)
2022-03-25 21:30:54 -05:00
5d8b83e5ef Update changelog 2022-03-24 11:54:20 -05:00
53fdb48b05 Fix reported TBC issue of target health updates
For some reason, on TBC classic target health is not updating frequently. I waded through the official TBC source code, and it looks like if predictedHealth is enabled (which it is by default), then the default UI uses an OnUpdate handler to update the target's health bar. So now I'm doing the same.
2022-03-24 11:51:58 -05:00
b64294ca11 Minor optimization for ZM puzzle detection
COMBAT_LOG_EVENT_UNFILTERED is a spam-fest, so let's only subscribe to it when we absolutely have to. This could arguably by done entirely in UNIT_AURA, but since we don't know for sure that a given UNIT_AURA event was the removal of a buff, there is a potential problem with trying to detect exactly when the puzzle session was finished. This code can potentially mis-detect puzzle starting, or hide the addon again when it's already hidden, but there shouldn't be an issue in practice. If this turns out to be problematic, I will roll back to the previous method.
2022-03-23 23:07:20 -05:00
0785265feb Convenience method for looking for any buff from a list 2022-03-23 23:04:00 -05:00
4007f1258b Fix whitespace 2022-03-23 11:40:12 -05:00
c7c92d468e Update changelog 2022-03-22 22:59:38 -05:00
eee20f17b4 Change method of hiding the target frame
See 51e2debc4d for the PlayerFrame version of this (and reasoning for this)
2022-03-22 22:57:36 -05:00
0aa584d81a Hide IceHUD during Zereth Mortis puzzles 2022-03-22 22:56:57 -05:00
51e2debc4d Change method of hiding the player frame
This existing method worked fine for many years, but seems to have become inadequate in 9.2, likely due to this change that's restoring player frame visibility sometimes: 20f786e45b

Fixes #19 (Github)
2022-03-22 15:58:10 -05:00
d48ae9b12a Update TOCs 2022-03-22 08:25:50 -05:00
83028c159f Prep for release 2022-01-28 11:22:18 -06:00
a8a3da753e Update TOC for BCC, changelog 2022-01-28 11:18:32 -06:00
9e77fa6831 fix totem bar dismissal (#18)
* fix totem bar dismissal

* limit insecure DestroyTotem fix to Classic/TBC

* fix fussy commit

Co-authored-by: Wiktor Ozimek <wiktor.ozimek@gmail.com>
2021-11-24 13:25:10 -06:00
e4919fb1fe Update TOCs 2021-11-11 13:00:39 -06:00
724a3001ed Prep for release 2021-10-14 19:55:56 -05:00
8226679ccd Update TOC for Classic 1.14.0 2021-10-13 22:15:21 -05:00
2c0b3d5f6f Update changelog 2021-10-12 21:22:51 -05:00
a08c2455c6 Support multiple anima-charged combo points
#16
2021-10-12 21:11:39 -05:00
8868b16785 Fix FocusMana event registration on Classic builds
Thanks to Lethay's comments on WowAce.
2021-09-25 09:34:44 -05:00
fc009492cb Update TOC for BC-Classic and Classic
WowAce ticket 317
2021-09-10 14:08:45 -05:00
e2ef8e6cb1 Rename closure variable to avoid shadowing a global/implicit var 2021-09-05 09:35:27 -05:00
da5498d1a2 Fix leaking variable 2021-09-05 09:33:46 -05:00
e8c8172298 Update changelog 2021-09-05 09:32:16 -05:00
345d12263c Add license 2021-09-01 09:53:57 -05:00
843292eda7 Use different GCD spell for Paladins in Classic 2021-08-25 21:41:50 -05:00
58721f4fa6 Update changelog for release 2021-07-19 12:52:30 -05:00
ebbddc0001 Expand vertical reach of Tank textures by request
This enables these bars to better represent the full 0-100 spectrum.
Previously, they would cut off the top and bottom by some amount
(differed per texture).
2021-07-18 23:36:07 -05:00
764a097fe2 Update TargetCC.lua (#13)
Added the working spell ID for FEAR on retail, tested on my max level Lock.
2021-07-16 09:37:05 -05:00
60587b22f8 Fix energy ticker when zoning back into an instance after dying
Instead of unhooking the event when we're dead, just hide the ticker
when dead. This ensures, regardless of the order the events come in
when zoning back into an instance, reviving, etc., the ticker is always
shown when appropriate.

WowAce ticket #316
2021-07-06 11:34:52 -05:00
ec80716991 Remove outdated readme message 2021-06-29 10:18:37 -05:00
bc16ae677b Update for WoW 9.1 2021-06-28 13:02:19 -05:00
dc5a3f3a05 Finalize changelog for v1.13.5 2021-06-26 14:21:36 -05:00
6c3ed55780 Update changelog 2021-06-26 14:20:39 -05:00
dfcef9617f Always update aura durations
If we're coming from a custom update func, it could mean that we're
tracking a unit that doesn't get events, like UNIT_AURA, for them. This
includes anything other than player, target, and focus, essentially.
2021-06-26 14:14:57 -05:00
94b62d56a0 Also subscribe for targettarget units 2021-06-26 14:13:57 -05:00
90f126d7a0 Fix custom bar update errors
I was tracking updates with two separate variables depending on where
the registration happened. The order that updates ran in was not
reliable, so sometimes one would register and sometimes the other would.
Since only one of them was setting itself as "from update", the behavior
internal to the bar was also inconsistent.
2021-06-26 14:13:44 -05:00
209fbe2b4e Trim whitespace off dogtags on upper/lower texts
This fixes an issue with strings getting clipped when newlines were
inadvertently included. wowace ticket #311
2021-06-10 22:29:30 -05:00
9435a9d74f Move LibRangeCheck to the proper location (wowace #306) 2021-05-21 07:40:01 -05:00
1519ac2299 Update changelog 2021-05-20 20:49:45 -05:00
2ba558d73d Package WeakAuras's fork of LibRangeCheck with BC-Classic compatibility 2021-05-20 20:48:24 -05:00
a3d9c7bd3d Update readme.md 2021-05-20 08:43:04 -05:00
d641886a8a Update with latest community packager changes for BC-Classic 2021-05-14 21:37:35 -05:00
87456ca051 Fix feature flag typo 2021-05-09 17:38:58 -05:00
d1eae2437f Temp rollback to earlier community packager
Community packager commit 3cbe4587 contains some incorrect logic that
causes the script to exit code 1 on successful WoWI upload when the new
WoWI changelog feature(s) aren't being used.
2021-05-09 17:10:25 -05:00
470ca2f592 Update changelog 2021-05-09 12:06:01 -05:00
e313e679ae Basic Classic-BC support
This has been tested on Classic PTR and Retail, but only with a Rogue
character. Don't have a ton of time to do more exhaustive tests right now.

Fixes #11
2021-05-09 12:04:23 -05:00
d43555b7c4 Update changelog 2021-04-25 22:54:29 -05:00
90e0dd1597 Update build script, include Classic-TBC detection 2021-04-25 22:50:32 -05:00
6282dfb256 Update changelog 2021-04-13 21:32:40 -05:00
4de8cb0d27 Show fury raw value as top number when DogTags are disabled
Same as commit 36c8f02fc2

WoWAce ticket #301
2021-04-13 21:31:32 -05:00
ea28a05051 Update Classic TOC 2021-03-23 12:15:38 -05:00
ca80ca3f75 Update TOC for 9.0.5, prepare for release 2021-03-22 21:43:38 -05:00
fe22f7e658 Update latest changes 2021-03-21 11:56:20 -05:00
354fb483bb Fix incorrect mana alpha when max mana is 0 2021-03-21 11:18:58 -05:00
f6c737c654 Activate totems for all classes in 9.0+
Some class abilities spawn units that live for a specific amount of time, and the game
handles these as Totems.
2020-12-27 21:28:16 -06:00
9a38c4b3ea Revert file to original 2020-12-05 16:49:07 -06:00
ab6b662ac4 Update all library paths to current 2020-12-04 13:38:54 -06:00
a2addcb627 Update url for DogTag dependencies 2020-12-04 13:20:42 -06:00
7f84c28538 Update for new release version 2020-12-04 08:50:12 -06:00
924bd4a6ef Update TOC to latest 2020-11-29 12:06:51 -06:00
0f753448d7 Add config setting to control showing anima-charged combo points 2020-11-28 23:00:24 -06:00
891ddc230c Update temp short changelog 2020-11-28 22:50:25 -06:00
06353d4974 Add support for Anima-charged combo points
Requested by Curseforge ticket 291
2020-11-28 20:37:12 -06:00
d44e62bee4 Reformat changelogs
This allows for a nicer release formatting, assuming I keep up with it.
2020-10-18 15:17:25 -05:00
8fe1ef75b7 Revert "Revert "Show "development" as addon version for non-packaged builds""
This reverts commit 087c64ee6a. Now that the community packager is being used, this should work fine.
2020-10-18 15:06:12 -05:00
702aa5bff6 Allow nolib versions to be created 2020-10-18 15:05:43 -05:00
d6e1fd707a Remove 9.0 dev note 2020-10-18 15:05:35 -05:00
88d7dd3982 Fix Options TOC to work with Classic 2020-10-18 09:11:38 -05:00
f495bb15be Change tabs to spaces to try and fix the community packager 2020-10-18 09:04:38 -05:00
087c64ee6a Revert "Show "development" as addon version for non-packaged builds"
This reverts commit 5c19d7f89c. The Twitch client is apparently having problems with alpha versions, so I'm taking guesses as to why that might be.
2020-10-14 13:05:26 -05:00
077f381adb Increased valid ranges by request (wowace ticket #280) 2020-10-14 12:57:34 -05:00
a5be2996da Fix RollTheBones for 9.0 2020-10-13 22:28:10 -05:00
22f473b54d Fix SnD for 9.0, add support for Deeper Stratagem talent
There's still some situations where refreshing SnD can give a much longer buff than expected...I'm not sure what those conditions are, though.
2020-10-13 21:59:44 -05:00
e7f95cbcb6 Holy power is usable by all specs in 9.0 2020-10-13 21:28:37 -05:00
5c19d7f89c Show "development" as addon version for non-packaged builds 2020-10-13 20:32:02 -05:00
f01d6495f8 Update readme to match Curse/WoWAce pages 2020-10-13 20:31:44 -05:00
34ecd95e4f Add github workflow for packaging with the community packager 2020-10-13 09:15:46 -05:00
564919e0c6 Configure for compatibility with community addon packager 2020-10-13 09:02:45 -05:00
a18144aec0 9.0 compatibility updates - initial attempt 2020-10-13 08:46:41 -05:00
53bf76c58a Update mailmap 2020-08-31 21:34:50 -05:00
1140d2e8c5 Update changelog 2020-08-31 21:24:43 -05:00
7d562dfb35 Possible fix for reported Classic issue 2020-08-28 21:20:47 -05:00
7c2fe06fa8 Update changelog 2020-07-13 11:21:59 -05:00
819cc64aca Maybe fix pet health visibility on teleport
Untested fix for a similar issue as seen on other modules.
2020-06-25 10:09:52 -05:00
36c8f02fc2 Show focus raw value as top number when DogTags are disabled 2020-06-19 14:07:38 -05:00
db7d797eb2 Fixed various class power indicators using the wrong alpha sometimes 2020-05-30 15:25:02 -05:00
a9cf5d5b2c Updated changelog 2020-05-27 11:26:18 -05:00
81d8ffeae1 Fixed issue of Runes alpha being wrong after a teleport with a target 2020-05-23 15:55:31 -05:00
d9c3de0a5e Drycode attempt to fix reported issue 278
This should only happen on a Classic client with LibClassicCasterino installed and a specific type of spell event fires
2020-05-22 10:17:18 -05:00
efdad59911 Updated changelog 2020-01-14 20:16:08 -06:00
b8e8b41ae7 Updated TOC 2020-01-14 20:14:34 -06:00
261be76d90 Fixed Rage showing on a scale of 0-1000 instead of 0-100 w/o DogTags on
Added a note about why this is happening for the next time I need to mess with it. I am fairly certain there is code in IceHUD that's already dealing with the 0-1000 scale and handling it, so I don't want to disrupt stuff without having enough testing.
2020-01-11 22:31:34 -06:00
55fbfbdf1c Fixed TargetMana value not showing in the proper color w/ DogTags off 2020-01-11 22:18:38 -06:00
e6077ab39f Updated FAQ 2020-01-07 19:46:20 -06:00
abf3c0d514 Updated changelog for release 2019-12-13 16:24:45 -06:00
b1e746bec9 Guard against missing GetTotemInfo API 2019-12-10 16:56:38 -06:00
659de89d0c Fixed player cast error for users without LibCasterCasterino installed 2019-11-30 10:49:37 -06:00
da79bb35c8 Updated changelog 2019-11-29 19:09:47 -06:00
b40829abbb add TargetCast support in Classic (#8)
This change adds support for using LibCasterCasterino to get your
target's casting info to enable the TargetCast module. It's not as
clean as the newer retail native calls but works well enough for
most interrupts.

Note: because LibCasterCasterino is using combat log events to get
casting info if a spell cast starts and is immediately cancelled or
interrupted the log may not get updated and the cast bar will zombie
complete.

LibCasterCasterino can be found at:

https://github.com/rgd87/LibClassicCasterino
2019-09-28 22:58:39 -05:00
7dfc05aa91 Fixed fallout from disabling GCD module
Fixes wowace ticket 253
2019-09-26 15:38:42 -05:00
a0d05ebf94 Updated changelog 2019-09-26 11:19:18 -05:00
b5b5c31791 Only use combo modules in Classic for Rogues and Druids 2019-09-22 14:24:02 -05:00
5c66970d8f GCD doesn't function in Classic 2019-09-19 22:09:16 -05:00
4fbb70ebc0 Updated changelog for release 2019-09-10 23:16:18 -05:00
9cfa00227f Fixed indentation to match the rest of the file (spaces/tabs) 2019-09-10 23:16:08 -05:00
9b90694912 add missing unit parameter on SpellCastFailed (#5) 2019-09-06 18:12:39 -05:00
67f79736d8 Preparing for release 2019-09-05 21:39:10 -05:00
dc98e5b521 Updated changelog 2019-09-04 17:56:29 -05:00
94506cc591 Merge remote-tracking branch 'github/master' 2019-09-04 17:52:07 -05:00
09d9a9c6f7 Add cooldowns support on target buffs/debuffs (#4)
* Add cooldowns support on target buffs/debuffs

Duration and expiration times are not set on target buffs/debuffs
when using UnitAura. This change looks up the spellID in
LibClassicDurations and sets the duration and expiry using that
source.

This change enables the cooldown sweep that allows OmniCC to properly
display the countdown of time remaining on the buff/debuff.

Note that this only adds the cooldown on buff/debuffs applied
to the target by the player.

* set LibStub to silently fail if library is missing

Support for cooldown durations on Classic WoW is provided by
LibClassicDurations, which comes with the ClassicAuraDurations
addon. This change prevents IceHUD throwing an error if the
library is missing.
2019-09-04 17:50:33 -05:00
8b7ce521ff Merge pull request #3 from TwentyOneZ/master
RealMobHealth addon compatibility
2019-09-03 17:34:51 -05:00
26fd86134b RealMobHealth addon compatibility
It will only work with DogTags disabled. Otherwise it will respect the DogTag (which doesn't support the RealMobHealth info).
2019-09-03 16:03:38 -03:00
e4d8bae185 Only allow custom bars to track players in Classic 2019-09-03 10:17:03 -05:00
2d42116f8d Updated changelog 2019-08-30 10:41:14 -05:00
a7d1629ed3 Fixed error in Classic when changing profiles 2019-08-29 11:53:27 -05:00
070d66eca3 Disabled target and target-target castbars in classic 2019-08-28 20:30:35 -05:00
a0c5b97ccb Updated changelog 2019-08-28 20:04:19 -05:00
3e56595709 Fixed energy ticker resetting when spending energy 2019-08-28 19:49:50 -05:00
c016b0ccc0 Fixed PLAYER_PET_CHANGED event on stack counters in Classic 2019-08-28 08:56:31 -05:00
d0187a44e3 Revving to get a new build to pick up the latest LibRangeCheck 2019-08-15 16:36:02 -05:00
b4e1374400 Revving to get a new build to pick up the latest Ace3 2019-08-12 08:07:49 -05:00
ba8748ecca First batch of WoW Classic compatibility updates
This has been tested on Classic with a Rogue up to level 5 using various modules and casually checked against a few level 1 classes. I'm sure there's a lot more to do here. I also made sure to test on Live.

Where possible I tried to check for API availability rather than specific client versions or program IDs. There are many cases where that's impractical, however, so version/program ID checks were used.

This was tested with:
* Ace3 @r1225
* AceGUI-3.0-SharedMediaWidgets @r61
* LibDBIcon-1.0 @v8.2.0
* LibDogTag-3.0 @v80200.1
* LibDogTag-Unit-3.0 @v80200.1-2-g93a898d-alpha
* LibRangeCheck-2.0 @v4.2.3 (with a couple of local changes)
* LibSharedMedia-3.0 @r113-alpha
2019-08-11 23:21:06 -05:00
5b71a4f819 Updated TOC to 8.2 2019-06-25 09:53:14 -05:00
77351997b4 Updated changelog 2019-06-03 22:55:26 -05:00
901b49f7b3 Attempt to fix pet health/power not updating when entering instance 2019-06-03 22:46:24 -05:00
53b59b5be2 Attempt to fix pet health not updating (wowace ticket 245) 2019-04-16 17:37:11 -05:00
1bb217c4aa Updated changelog 2019-03-17 12:30:49 -05:00
8469824f53 Fixed player health not updating to max health 2019-03-17 12:28:58 -05:00
118aa0f493 Updated TOC to 8.1 2019-01-12 17:33:29 -06:00
48ee6c0270 Updated changelog 2018-10-03 08:21:58 -05:00
395de299f0 Fixed shard numeric formatting incorrectly in non-Destruction specs 2018-10-03 08:20:30 -05:00
588ba76ef5 Possible fix for reported nil comparison issue. Can't reproduce here. 2018-10-02 09:02:59 -05:00
9fc64bcfe4 Added suggested CC spells 2018-09-19 16:35:13 -05:00
a4945641fb Updated changelog 2018-09-15 14:51:59 -05:00
195b7ab264 Only show placeholder icon when in config mode 2018-09-15 14:50:33 -05:00
410cc2b634 Fixed CD bars not displaying when both IgnoreRange and OnlyShowWithTarget were set 2018-09-12 22:06:33 -05:00
6986131d73 Only show placeholder icon when in config mode
If a CD bar was tracking a spell that was currently unknown to the player (such as the not-currently-active variations of Wildfire Bomb for Survival Hunters after first login/UI reload) then the placeholder frost icon would show up instead. The icon was only meant to be used to aid in configuration mode, so now the icon is set to the placeholder icon when config mode is enabled only. Technically we should clear the icon if it's set to the default whenever config mode is exited, but I figure config mode is pretty rare and should be okay for now.
2018-09-12 21:59:29 -05:00
43aff89b5c Updated changelog 2018-08-30 16:48:33 -05:00
b3a1602d6c Hide lag bar if lag is over half the cast time 2018-08-27 22:57:33 -05:00
c558010b25 Updated changelog 2018-08-27 21:02:05 -05:00
af42f4a4f3 Added option (enabled by default) to hide mod during shell games 2018-08-27 20:48:30 -05:00
ccdabc210c Added HasDebuffs utility method 2018-08-27 20:48:13 -05:00
32e2ce3902 Added Rogue Between the Eyes stun 2018-08-24 00:04:56 -05:00
9764694568 Updated changelog 2018-08-18 14:56:01 -05:00
337bd72545 Fix cast lag indicator updating for others' spells 2018-08-18 14:55:22 -05:00
c4d35b9766 Updated changelog 2018-08-18 11:02:40 -05:00
7dfe505db2 Increased reliability of lag bar
It's still, at it's core, a guess because Blizzard doesn't offer the necessary events to make a reliable decision, so it tends to be wrong semi-frequently in a chain-casting scenario. But it's better than it was.
2018-08-18 11:00:31 -05:00
a8f175fad4 Don't recreate lag bar unnecessarily 2018-08-17 22:45:12 -05:00
1591b36e89 Fixed SpellCastSucceeded signature and spell name for 8.0 2018-08-17 22:44:03 -05:00
8ddc6c5911 Fixed castbar lag indicator covering the whole bar sometimes 2018-08-17 22:41:18 -05:00
bbab772044 Fixed error when showing Blizzard's Rune frame 2018-08-16 20:21:16 -05:00
d27fb83f02 Fixed lag indicator for GCD bar 2018-08-16 17:07:43 -05:00
59e8ac2de8 Fixed cast lag indicator
Apparently the lag bar has been broken since 8.0 due to an incorrect event handler signature that was storing the cast guid incorrectly.
2018-08-16 10:47:01 -05:00
ef9fcdf29b Curse packager test 2018-08-06 16:51:18 -05:00
ac8effb177 C'mon packager... 2018-07-27 21:12:32 -05:00
b89bc5516e Poke Curse packager again 2018-07-24 21:51:56 -05:00
5ae7771fea Poke Curse packager 2018-07-24 21:51:28 -05:00
0d146ab10f Balance druids with Nature's Wrath now treat 50-100 astral power as full for alpha purposes 2018-07-24 21:49:59 -05:00
02ad6253d3 Renamed HarmonyPower to Chi
Updated readme link to the create-your-own-texture guide
2018-07-20 13:20:27 -05:00
6445b424b3 Useless commit to try and spur curse packager to make a build 2018-07-19 22:30:08 -05:00
383b7cae2f Fixed DK Rune state not always matching actual state 2018-07-19 22:18:05 -05:00
62201381c5 Updated changelog 2018-07-19 21:45:24 -05:00
161b0215be Actually fixed stagger 2018-07-19 21:12:51 -05:00
11ef3354f0 Attempt to suppress bugs in development builds 2018-07-19 09:50:22 -05:00
be64b56da6 Fixed 8.0 error when playing as a Monk
Fixed 8.0 castbar sometimes showing gibberish text and sometimes disappearing when the cast wasn't complete yet
2018-07-18 01:19:22 -05:00
4a6868a906 Fixed error in stagger bar on 8.0 2018-07-18 00:56:28 -05:00
47362d4cb0 Updated TOC for 8.0 2018-07-16 22:56:17 -05:00
26502214b2 Updated changelog 2018-07-16 14:33:17 -05:00
ee3d107863 More rune updates for 8.0
It looks like the entire game-side code for runes and rune events have been re-done, so this module was failing to properly update rune availability. I've switched to a model of ignoring the rune index coming in from the update event and just rebuilding my internal state of rune availability/cooldown for all runes on each event (sometimes the incoming rune index was 32760 or a huge negative number...looks like garbage values). This is how the built-in rune frame is handling things now as well.

I also tweaked the shine fade-in to not create a new function every shine. Whoops.
2018-07-16 11:36:24 -05:00
beb080b104 Set DH pain/fury colors to match 8.0 default UI 2018-07-16 11:36:24 -05:00
2d48f3a24c Don't show castbar "show rank" option on BfA
All the spellcasting event callbacks need their signatures changed, but I can't cleanly do that without breaking Legion compatibility. So that will have to wait, I think. Castbars seem to be working for now...
The simplest solution is probably to register different callbacks for BfA versus pre-BfA, but that seems ugly.
2018-07-16 11:36:24 -05:00
5605fcbc2b Updated changelog 2018-06-21 00:04:36 -05:00
7ebe7a05d7 Fixed color when rolling 5 buffs 2018-06-20 18:06:45 -05:00
bb4d7640ed Fixed GCD in BfA 2018-06-07 00:18:38 -05:00
388e314371 Missed this change note last time 2018-06-07 00:01:21 -05:00
89ef91b9b3 Initial dump of BfA compatibility
Updated for:
- SPELL_POWER_* constants becoming Enum.PowerType.*
- Rank no longer existing in return values for UnitAura, UnitBuff, UnitDebuff, UnitCastingInfo, UnitChannelInfo
- UNIT_POWER event becoming UNIT_POWER_UPDATE
- UnitPopupFrames no longer existing
- Removed events: PLAYER_PET_CHANGED, UNIT_MAXPOWER, PET_BAR_CHANGED, UNIT_DYNAMIC_FLAGS
- Texture return value from UnitAura type changing (name -> id)
- All Warlock specializations using soul shards
- Death Knight rune changes

Haven't tested all classes/specializations yet, so I'm sure I missed some stuff.
Probably need to add support for the new circular cooldown wipe flourish added in the base client.
Saw a problem with cooldown flashes being delayed on DK runes becoming available that probably need to be fixed.
2018-06-06 22:57:35 -05:00
0f7a2ff4f1 Added Gap setting between upper and lower text
Partial merge of pull request #1 from lrds (https://github.com/parnic/ice-hud/pull/1). Removed the localization change because loc is managed on the wowace side.
2018-06-06 20:20:08 -05:00
3ea273fe47 Show text on Absorb and AltMana with DogTags disabled 2018-02-10 17:45:09 -06:00
5003608a34 Fixed Insanity display with DogTags disabled
Apparently internally Insanity is multiplied by 100 from the value that's actually displayed on the ui (so the internal max for my test character is 10500 while the displayed amount is 105).
2018-02-10 17:44:32 -06:00
c21fe96707 Moved Round down for other modules to use 2018-02-10 17:41:44 -06:00
d108ac9e2e Updated TOC for 7.3 2017-08-31 16:10:36 -05:00
6c4e815b9e Added raid icon toggle to Info modules 2017-08-30 23:29:20 -05:00
46daddbed9 Updated changelog 2017-08-30 23:18:03 -05:00
1b64adc77c Updated shard texture for Warlocks 2017-08-30 23:10:22 -05:00
35e56ebec6 Updated shard display for Destro Warlocks
Ticket #234, thanks stencil!
2017-06-17 20:38:12 -05:00
5fe8776249 Updated changelog 2017-06-14 16:56:29 -05:00
08e8d3a087 Updated GetLFGProposal return values 2017-06-14 10:18:02 -05:00
2eae8fa419 Updated TOC to 7.2 2017-03-28 14:28:00 -05:00
94850e53dd Fixed error in 7.2 where a cvar has been removed 2017-03-25 14:03:47 -05:00
a739b7ba99 Set stagger max to 100 by request 2017-01-11 16:04:41 -06:00
176603ec51 Updated changelog 2016-12-24 01:04:57 -06:00
0cdfde1758 Fixed Holy Word: Serenity not being trackable in CD modules
Pre-7.0 the Holy Word spells did not work with GetSpellCooldown. They do now.
2016-12-24 01:04:09 -06:00
2f7b081790 Updated changelog 2016-12-22 13:53:18 -06:00
b7883036fd Fixed existing counters showing 0 on the screen
For any user that had existing counters (such as anyone who had savedata from before the time that Maelstrom, Lacerate, and Sunder were converted to custom counters automatically) in numeric mode, a 0 or faded graphical icon was showing up all the time after the recent change to enable showing empty counters. Now there's a checkbox for whether you want the empty/0 count to show or not.
2016-12-22 13:27:14 -06:00
dd3371c22c Updated changelog 2016-12-22 00:28:19 -06:00
7e65e506c5 Updated compatible-with to 7.0
Updated wowace project URL
Updated changelog
2016-12-07 23:34:59 -06:00
ce1558a18e Inverted alpha settings for custom counters watching spell charges
For charges, being full is the default state, so we need to treat full the same as health or mana being full. (ticket #231)
Also fixed the "target" variable never getting set on custom counters or custom counter bars because they were overriding the PLAYER_TARGET_CHANGED event that the base class was registering.
Also also fixed numeric display mode for custom counters not using the correct gradient scaling when the number hit 0. It was using the same scaling as graphical mode where 0 displays nothing and needs to be accounted for separately.
2016-12-07 23:28:44 -06:00
49f8a6c6b2 Fixed numeric custom count not hiding appropriately
The numeric frame needed to be parented to the module's frame so it hides and shows itself along with the module.
2016-12-07 23:20:05 -06:00
d9bd5e3f36 Changed default DogTags to shorten values
This change is potentially contentious because it's a very old default, but with health and power values being so incredibly high in Legion, the shortened form of values is immensely more readable. This change will not affect those who have modified their text settings and the Short form only kicks in when values hit 10,000 or higher.
2016-11-06 14:17:37 -06:00
151e54746f Fixed possible error generated in custom counters
Somehow even though "maxCount" is forced to a number any time it's configured in the UI, a user ended up with maxCount as a string in his saved variables. The mod was then trying to compare a string to a number and failing, causing a cascade of errors.
2016-11-06 13:39:20 -06:00
d7505b73b1 Fixed possible infinite loop in custom counters
Only try to redraw if the maximum count exceeds the numbers of frames we have to display the count. If the maximum drops below the number of frames we have to display it, that's fine because the excess frames will just be hidden.
2016-11-05 21:12:13 -05:00
f10a647590 Updated a few CC spells 2016-11-02 00:06:06 -05:00
54bd441f16 Updated changelog 2016-10-28 10:42:35 -05:00
4a7212fc00 Updated TOC for options module 2016-10-28 10:42:35 -05:00
e6f87b52bb Speculative fix for reported problem
There's a case where custom counters seemingly get stuck with an outdated maximum number of charges (perhaps only when augmented by a talent such as with Throw Glaive). This may catch and fix it (I couldn't reproduce the problem with a starter DH since you need level 108 or something to get the second charge for Throw Glaive).
2016-10-27 23:24:14 -05:00
d38c32cf34 Updated changelog 2016-10-26 11:42:34 -05:00
82 changed files with 4968 additions and 1271 deletions

64
.github/workflows/release.yml vendored Normal file
View File

@ -0,0 +1,64 @@
# description of this workflow, can be anything you want
name: Package and release
# we need to let GitHub know _when_ we want to release, typically only when we create a new tag.
# this will target only tags, and not all pushes to the master branch.
# this part can be heavily customized to your liking, like targeting only tags that match a certain word,
# other branches or even pullrequests.
on:
push:
tags:
- '**'
# a workflow is built up as jobs, and within these jobs are steps
jobs:
# "release" is a job, you can name it anything you want
release:
# we can run our steps on pretty much anything, but the "ubuntu-latest" image is a safe bet
runs-on: ubuntu-latest
# specify the environment variables used by the packager, matching the secrets from the project on GitHub
env:
CF_API_KEY: ${{ secrets.CF_API_KEY }}
WOWI_API_TOKEN: ${{ secrets.WOWI_API_TOKEN }}
WAGO_API_TOKEN: ${{ secrets.WAGO_API_TOKEN }}
GITHUB_OAUTH: ${{ secrets.GITHUB_TOKEN }} # "GITHUB_TOKEN" is a secret always provided to the workflow
# for your own token, the name cannot start with "GITHUB_"
# "steps" holds a list of all the steps needed to package and release our AddOn
steps:
# we first have to clone the AddOn project, this is a required step
- name: Clone project
uses: actions/checkout@v4
with:
fetch-depth: 0 # gets git history for changelogs
# once cloned, we just run the GitHub Action for the packager project
- name: Package and release
uses: BigWigsMods/packager@v2
# another example where we supply additional arguments, this example is specifically to release
# for the Classic version of the game
- name: Package and release for Classic
uses: BigWigsMods/packager@v2
with:
args: -g classic -w 0
- name: Package and release for TBC
uses: BigWigsMods/packager@v2
with:
args: -g bcc -w 0
- name: Package and release for Wrath
uses: BigWigsMods/packager@v2
with:
args: -g wrath -w 0
- name: Package and release for Cataclysm
uses: BigWigsMods/packager@v2
with:
args: -g cata -w 0

View File

@ -1,2 +1,3 @@
Parnic <parnic@parnic.com> Parnic <chris@parnic.com> Parnic <parnic@parnic.com> Parnic <chris@parnic.com>
rokiyo <rokiyo@example.com> Rokiyo <Rokiyo@example.com> rokiyo <rokiyo@example.com> Rokiyo <Rokiyo@example.com>
Parnic <parnic@parnic.com> Chris Pickett <chris@perniciousgames.com>

View File

@ -10,6 +10,9 @@ externals:
libs/AceEvent-3.0: libs/AceEvent-3.0:
url: svn://svn.wowace.com/wow/ace3/mainline/trunk/AceEvent-3.0 url: svn://svn.wowace.com/wow/ace3/mainline/trunk/AceEvent-3.0
tag: latest tag: latest
libs/AceSerializer-3.0:
url: svn://svn.wowace.com/wow/ace3/mainline/trunk/AceSerializer-3.0
tag: latest
libs/AceTimer-3.0: libs/AceTimer-3.0:
url: svn://svn.wowace.com/wow/ace3/mainline/trunk/AceTimer-3.0 url: svn://svn.wowace.com/wow/ace3/mainline/trunk/AceTimer-3.0
tag: latest tag: latest
@ -24,7 +27,7 @@ externals:
tag: latest tag: latest
libs/AceGUI-3.0: libs/AceGUI-3.0:
url: svn://svn.wowace.com/wow/ace3/mainline/trunk/AceGUI-3.0 url: svn://svn.wowace.com/wow/ace3/mainline/trunk/AceGUI-3.0
tag: latest tag: latest
libs/AceGUI-3.0-SharedMediaWidgets: libs/AceGUI-3.0-SharedMediaWidgets:
url: svn://svn.wowace.com/wow/ace-gui-3-0-shared-media-widgets/mainline/trunk/AceGUI-3.0-SharedMediaWidgets url: svn://svn.wowace.com/wow/ace-gui-3-0-shared-media-widgets/mainline/trunk/AceGUI-3.0-SharedMediaWidgets
tag: latest tag: latest
@ -37,15 +40,18 @@ externals:
libs/AceLocale-3.0: libs/AceLocale-3.0:
url: svn://svn.wowace.com/wow/ace3/mainline/trunk/AceLocale-3.0 url: svn://svn.wowace.com/wow/ace3/mainline/trunk/AceLocale-3.0
tag: latest tag: latest
libs/LibRangeCheck-2.0: libs/AceHook-3.0:
url: svn://svn.wowace.com/wow/librangecheck-2-0/mainline/trunk/LibRangeCheck-2.0 url: svn://svn.wowace.com/wow/ace3/mainline/trunk/AceHook-3.0
tag: latest
libs/LibRangeCheck-3.0:
url: https://github.com/WeakAuras/LibRangeCheck-3.0/
libs/LibSharedMedia-3.0: libs/LibSharedMedia-3.0:
url: svn://svn.wowace.com/wow/libsharedmedia-3-0/mainline/trunk url: svn://svn.wowace.com/wow/libsharedmedia-3-0/mainline/trunk
tag: latest tag: latest
libs/LibDogTag-3.0: libs/LibDogTag-3.0:
url: git://git.wowace.com/wow/libdogtag-3-0/mainline.git url: https://github.com/parnic/LibDogTag-3.0
libs/LibDogTag-Unit-3.0: libs/LibDogTag-Unit-3.0:
url: git://git.wowace.com/wow/libdogtag-unit-3-0/mainline.git url: https://github.com/parnic/LibDogTag-Unit-3.0
libs/LibDBIcon-1.0: libs/LibDBIcon-1.0:
url: svn://svn.wowace.com/wow/libdbicon-1-0/mainline/trunk/LibDBIcon-1.0 url: svn://svn.wowace.com/wow/libdbicon-1-0/mainline/trunk/LibDBIcon-1.0
libs/LibDualSpec-1.0: libs/LibDualSpec-1.0:
@ -54,15 +60,20 @@ externals:
optional-dependencies: optional-dependencies:
- libdogtag-3-0 - libdogtag-3-0
- libdogtag-unit-3-0 - libdogtag-unit-3-0
- librangecheck-2-0 - librangecheck-3-0
move-folders: move-folders:
IceHUD/IceHUD_Options: IceHUD_Options IceHUD/IceHUD_Options: IceHUD_Options
IceHUD/libs/LibRangeCheck-3.0/LibRangeCheck-3.0: IceHUD/libs/LibRangeCheck-3.0
tools-used: tools-used:
- libdatabroker-1-1 - libdatabroker-1-1
ignore: ignore:
- readme.md - readme.md
- FUNDING.yml
- this_version.md
manual-changelog: changelog.txt manual-changelog: this_version.md
enable-nolib-creation: yes

3
FUNDING.yml Normal file
View File

@ -0,0 +1,3 @@
github: parnic
ko_fi: parnic
custom: "https://www.paypal.me/parnic"

View File

@ -171,6 +171,7 @@ function IceBarElement.prototype:GetDefaultSettings()
settings["rotateBar"] = false settings["rotateBar"] = false
settings["markers"] = {} settings["markers"] = {}
settings["bAllowExpand"] = true settings["bAllowExpand"] = true
settings["textVerticalGap"] = 0
return settings return settings
end end
@ -414,7 +415,7 @@ do
type='range', type='range',
name = L["Bar vertical offset"], name = L["Bar vertical offset"],
desc = L["Adjust the vertical placement of this bar"], desc = L["Adjust the vertical placement of this bar"],
min = -400, min = -600,
max = 600, max = 600,
step = 1, step = 1,
get = function() get = function()
@ -435,7 +436,7 @@ do
type='range', type='range',
name = L["Bar horizontal adjust"], name = L["Bar horizontal adjust"],
desc = L["This is a per-pixel horizontal adjustment. You should probably use the 'offset' setting above as it is designed to snap bars together. This may be used in the case of a horizontal bar needing to be positioned outside the normal bar locations."], desc = L["This is a per-pixel horizontal adjustment. You should probably use the 'offset' setting above as it is designed to snap bars together. This may be used in the case of a horizontal bar needing to be positioned outside the normal bar locations."],
min = -400, min = -600,
max = 600, max = 600,
step = 1, step = 1,
get = function() get = function()
@ -625,7 +626,7 @@ do
v = DogTag:CleanCode(v) v = DogTag:CleanCode(v)
end end
self.moduleSettings.upperText = v self.moduleSettings.upperText = strtrim(v)
self:RegisterFontStrings() self:RegisterFontStrings()
self:Redraw() self:Redraw()
end, end,
@ -654,7 +655,7 @@ do
v = DogTag:CleanCode(v) v = DogTag:CleanCode(v)
end end
self.moduleSettings.lowerText = v self.moduleSettings.lowerText = strtrim(v)
self:RegisterFontStrings() self:RegisterFontStrings()
self:Redraw() self:Redraw()
end, end,
@ -724,6 +725,26 @@ do
order = 11.3, order = 11.3,
}, },
textVerticalGap = {
type = 'range',
name = L["Text Vertical Gap"],
desc = L["Gap between Upper and Lower text vertically"],
min = 0,
max = 10,
step = 1,
get = function()
return self.moduleSettings.textVerticalGap
end,
set = function(info, v)
self.moduleSettings.textVerticalGap = v
self:Redraw()
end,
disabled = function()
return not self.moduleSettings.enabled
end,
order = 11.4,
},
textHeader = { textHeader = {
type = 'header', type = 'header',
name = L["Upper Text"], name = L["Upper Text"],
@ -975,7 +996,7 @@ function IceBarElement.prototype:CreateBackground()
self.frame = CreateFrame("Frame", "IceHUD_"..self.elementName, self.masterFrame) self.frame = CreateFrame("Frame", "IceHUD_"..self.elementName, self.masterFrame)
end end
self.frame:SetFrameStrata("BACKGROUND") self.frame:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
self.frame:SetWidth(self.settings.barWidth + (self.moduleSettings.widthModifier or 0)) self.frame:SetWidth(self.settings.barWidth + (self.moduleSettings.widthModifier or 0))
self.frame:SetHeight(self.settings.barHeight) self.frame:SetHeight(self.settings.barHeight)
@ -1019,7 +1040,8 @@ end
-- Creates the actual bar -- Creates the actual bar
function IceBarElement.prototype:CreateBar() function IceBarElement.prototype:CreateBar()
self.barFrame = self:BarFactory(self.barFrame, "LOW", "ARTWORK") self.barFrame = self:BarFactory(self.barFrame, "LOW", "ARTWORK", "Bar")
self:SetBarCoord(self.barFrame) self:SetBarCoord(self.barFrame)
self.barFrame.bar:SetBlendMode(self.settings.barBlendMode) self.barFrame.bar:SetBlendMode(self.settings.barBlendMode)
@ -1029,12 +1051,12 @@ end
-- Returns a barFrame & barFrame.bar -- Returns a barFrame & barFrame.bar
-- Rokiyo: Currently keeping old behaviour of running through bar creation on every Redraw, but I'm not convinced we need to. -- Rokiyo: Currently keeping old behaviour of running through bar creation on every Redraw, but I'm not convinced we need to.
function IceBarElement.prototype:BarFactory(barFrame, frameStrata, textureLayer) function IceBarElement.prototype:BarFactory(barFrame, frameStrata, textureLayer, nameSuffix)
if not (barFrame) then if not (barFrame) then
barFrame = CreateFrame("Frame", nil, self.frame) barFrame = CreateFrame("Frame", "IceHUD_"..self.elementName.."_"..(nameSuffix or "Bar"), self.frame)
end end
barFrame:SetFrameStrata(frameStrata and frameStrata or "LOW") barFrame:SetFrameStrata(IceHUD.IceCore:DetermineStrata(frameStrata and frameStrata or "LOW"))
barFrame:SetWidth(self.settings.barWidth + (self.moduleSettings.widthModifier or 0)) barFrame:SetWidth(self.settings.barWidth + (self.moduleSettings.widthModifier or 0))
barFrame:SetHeight(self.settings.barHeight) barFrame:SetHeight(self.settings.barHeight)
self:SetBarFramePoints(barFrame) self:SetBarFramePoints(barFrame)
@ -1116,8 +1138,13 @@ function IceBarElement.prototype:CreateTexts()
offy = self.moduleSettings.textVerticalOffset offy = self.moduleSettings.textVerticalOffset
end end
local offgap = 0
if self.moduleSettings.textVerticalGap ~= nil then
offgap = self.moduleSettings.textVerticalGap
end
self.frame.bottomUpperText:SetPoint("TOP"..ownPoint , self.frame, "BOTTOM"..parentPoint, offx, offy) self.frame.bottomUpperText:SetPoint("TOP"..ownPoint , self.frame, "BOTTOM"..parentPoint, offx, offy)
self.frame.bottomLowerText:SetPoint("TOP"..ownPoint , self.frame, "BOTTOM"..parentPoint, offx, offy - 14) self.frame.bottomLowerText:SetPoint("TOP"..ownPoint , self.frame, "BOTTOM"..parentPoint, offx, offy - (14 + offgap))
if (self.moduleSettings.textVisible["upper"]) then if (self.moduleSettings.textVisible["upper"]) then
self.frame.bottomUpperText:Show() self.frame.bottomUpperText:Show()
@ -1433,6 +1460,16 @@ function IceBarElement.prototype:SetScaledColor(colorVar, percent, maxColor, min
colorVar.b = ((maxColor.b - minColor.b) * percent) + minColor.b colorVar.b = ((maxColor.b - minColor.b) * percent) + minColor.b
end end
function IceBarElement.prototype:Round(num)
if (num > 1000000) then
return IceHUD:MathRound(num/1000000, 1) .. "M"
end
if (num > 1000) then
return IceHUD:MathRound(num/1000, 1) .. "k"
end
return num
end
-- To be overridden -- To be overridden
function IceBarElement.prototype:Update() function IceBarElement.prototype:Update()
end end
@ -1548,7 +1585,7 @@ function IceBarElement.prototype:CreateMarker(idx)
self.Markers[idx] = nil self.Markers[idx] = nil
end end
self.Markers[idx] = self:BarFactory(self.Markers[idx], "MEDIUM", "OVERLAY") self.Markers[idx] = self:BarFactory(self.Markers[idx], "MEDIUM", "OVERLAY", "Marker"..idx)
local color = self.moduleSettings.markers[idx].color local color = self.moduleSettings.markers[idx].color
self.Markers[idx].bar:SetVertexColor(color.r, color.g, color.b, self.alpha) self.Markers[idx].bar:SetVertexColor(color.r, color.g, color.b, self.alpha)

View File

@ -3,7 +3,7 @@ IceCastBar = IceCore_CreateClass(IceBarElement)
local IceHUD = _G.IceHUD local IceHUD = _G.IceHUD
IceCastBar.Actions = { None = 0, Cast = 1, Channel = 2, Instant = 3, Success = 4, Failure = 5 } IceCastBar.Actions = { None = 0, Cast = 1, Channel = 2, Instant = 3, Success = 4, Failure = 5, ReverseChannel = 6 }
IceCastBar.prototype.action = nil IceCastBar.prototype.action = nil
IceCastBar.prototype.actionStartTime = nil IceCastBar.prototype.actionStartTime = nil
@ -12,6 +12,51 @@ IceCastBar.prototype.actionMessage = nil
IceCastBar.prototype.unit = nil IceCastBar.prototype.unit = nil
IceCastBar.prototype.current = nil IceCastBar.prototype.current = nil
local SPELL_POWER_MANA = SPELL_POWER_MANA
if Enum and Enum.PowerType then
SPELL_POWER_MANA = Enum.PowerType.Mana
end
local UnitCastingInfo, UnitChannelInfo = UnitCastingInfo, UnitChannelInfo
if not UnitCastingInfo then
UnitCastingInfo = CastingInfo
UnitChannelInfo = ChannelInfo
end
local GetSpellName = GetSpellInfo
if C_Spell and C_Spell.GetSpellName then
GetSpellName = C_Spell.GetSpellName
end
local GetSpellInfo = GetSpellInfo
if not GetSpellInfo and C_Spell and C_Spell.GetSpellInfo then
GetSpellInfo = function(spellID)
if not spellID then
return nil
end
local spellInfo = C_Spell.GetSpellInfo(spellID)
if spellInfo then
return spellInfo.name, nil, spellInfo.iconID, spellInfo.castTime, spellInfo.minRange, spellInfo.maxRange, spellInfo.spellID, spellInfo.originalIconID
end
end
end
-- Fulzamoth 2019-09-27 : Use LibClassicCasterino if it's there so we can use TargetCast
-- module in Classic WoW
if IceHUD.WowClassic then
LibClassicCasterino = LibStub("LibClassicCasterino", true)
if LibClassicCasterino then
UnitCastingInfo = function(unit)
return LibClassicCasterino:UnitCastingInfo(unit)
end
UnitChannelInfo = function(unit)
return LibClassicCasterino:UnitChannelInfo(unit)
end
end
end
-- end Fulzamoth change
local AuraIconWidth = 20 local AuraIconWidth = 20
local AuraIconHeight = 20 local AuraIconHeight = 20
@ -23,6 +68,13 @@ function IceCastBar.prototype:init(name)
self:SetDefaultColor("CastChanneling", 242, 242, 10) self:SetDefaultColor("CastChanneling", 242, 242, 10)
self:SetDefaultColor("CastSuccess", 242, 242, 70) self:SetDefaultColor("CastSuccess", 242, 242, 70)
self:SetDefaultColor("CastFail", 1, 0, 0) self:SetDefaultColor("CastFail", 1, 0, 0)
if GetUnitEmpowerMinHoldTime then
self:SetDefaultColor("EmpowerStage0", 165, 165, 165)
self:SetDefaultColor("EmpowerStage1", 242, 42, 10)
self:SetDefaultColor("EmpowerStage2", 242, 142, 10)
self:SetDefaultColor("EmpowerStage3", 242, 242, 10)
self:SetDefaultColor("EmpowerStage4", 242, 242, 242)
end
self.unit = "player" self.unit = "player"
self.delay = 0 self.delay = 0
@ -35,21 +87,61 @@ end
function IceCastBar.prototype:Enable(core) function IceCastBar.prototype:Enable(core)
IceCastBar.super.prototype.Enable(self, core) IceCastBar.super.prototype.Enable(self, core)
self:RegisterEvent("UNIT_SPELLCAST_SENT", "SpellCastSent") -- "player", spell, rank, target -- Fulzamoth 2019-09-27 : LibClassicCasterino support
self:RegisterEvent("CURRENT_SPELL_CAST_CHANGED", "SpellCastChanged") -- Setup callback to the library, and route events to
self:RegisterEvent("UNIT_SPELLCAST_START", "SpellCastStart") -- unit, spell, rank -- IceHUD's handler functions.
self:RegisterEvent("UNIT_SPELLCAST_STOP", "SpellCastStop") -- unit, spell, rank if LibClassicCasterino then
local CastbarEventHandler = function(event, ...) -- unitTarget, castGUID, spellID
if (event == "UNIT_SPELLCAST_START") then
return IceCastBar.prototype.SpellCastStart(self, event, ...)
elseif (event == "UNIT_SPELLCAST_DELAYED") then
return IceCastBar.prototype.SpellCastDelayed(self, event, ...)
elseif (event == "UNIT_SPELLCAST_STOP") then
return IceCastBar.prototype.SpellCastStop(self, event, ...)
elseif (event == "UNIT_SPELLCAST_FAILED") then
return IceCastBar.prototype.SpellCastFailed(self, event, ...)
elseif (event == "UNIT_SPELLCAST_INTERRUPTED") then
return IceCastBar.prototype.SpellCastInterrupted(self, event, ...)
elseif (event == "UNIT_SPELLCAST_CHANNEL_START") then
return IceCastBar.prototype.SpellCastChannelStart(self, event, ...)
elseif (event == "UNIT_SPELLCAST_CHANNEL_UPDATE") then
return IceCastBar.prototype.SpellCastChannelUpdate(self, event, ...)
elseif (event == "UNIT_SPELLCAST_CHANNEL_STOP") then
return IceCastBar.prototype.SpellCastChannelStop(self, event, ...)
end
end
LibClassicCasterino.RegisterCallback(self,"UNIT_SPELLCAST_START", CastbarEventHandler)
LibClassicCasterino.RegisterCallback(self,"UNIT_SPELLCAST_DELAYED", CastbarEventHandler) -- only for player
LibClassicCasterino.RegisterCallback(self,"UNIT_SPELLCAST_STOP", CastbarEventHandler)
LibClassicCasterino.RegisterCallback(self,"UNIT_SPELLCAST_FAILED", CastbarEventHandler)
LibClassicCasterino.RegisterCallback(self,"UNIT_SPELLCAST_INTERRUPTED", CastbarEventHandler)
LibClassicCasterino.RegisterCallback(self,"UNIT_SPELLCAST_CHANNEL_START", CastbarEventHandler)
LibClassicCasterino.RegisterCallback(self,"UNIT_SPELLCAST_CHANNEL_UPDATE", CastbarEventHandler) -- only for player
LibClassicCasterino.RegisterCallback(self,"UNIT_SPELLCAST_CHANNEL_STOP", CastbarEventHandler)
else -- No LibClassicCasterino, or we're not on Classic, so use IceHUD's normal event handlers.
self:RegisterEvent("UNIT_SPELLCAST_FAILED", "SpellCastFailed") -- unit, spell, rank self:RegisterEvent("UNIT_SPELLCAST_SENT", "SpellCastSent") -- "player", spell, rank, target
self:RegisterEvent("UNIT_SPELLCAST_INTERRUPTED", "SpellCastInterrupted") -- unit, spell, rank self:RegisterEvent("CURRENT_SPELL_CAST_CHANGED", "SpellCastChanged")
self:RegisterEvent("UNIT_SPELLCAST_START", "SpellCastStart") -- unit, spell, rank
self:RegisterEvent("UNIT_SPELLCAST_STOP", "SpellCastStop") -- unit, spell, rank
self:RegisterEvent("UNIT_SPELLCAST_DELAYED", "SpellCastDelayed") -- unit, spell, rank self:RegisterEvent("UNIT_SPELLCAST_FAILED", "SpellCastFailed") -- unit, spell, rank
self:RegisterEvent("UNIT_SPELLCAST_SUCCEEDED", "SpellCastSucceeded") -- "player", spell, rank self:RegisterEvent("UNIT_SPELLCAST_INTERRUPTED", "SpellCastInterrupted") -- unit, spell, rank
self:RegisterEvent("UNIT_SPELLCAST_CHANNEL_START", "SpellCastChannelStart") -- unit, spell, rank self:RegisterEvent("UNIT_SPELLCAST_DELAYED", "SpellCastDelayed") -- unit, spell, rank
self:RegisterEvent("UNIT_SPELLCAST_CHANNEL_UPDATE", "SpellCastChannelUpdate") -- unit, spell, rank self:RegisterEvent("UNIT_SPELLCAST_SUCCEEDED", "SpellCastSucceeded") -- "player", spell, rank
self:RegisterEvent("UNIT_SPELLCAST_CHANNEL_STOP", "SpellCastChannelStop") -- unit, spell, rank
self:RegisterEvent("UNIT_SPELLCAST_CHANNEL_START", "SpellCastChannelStart") -- unit, spell, rank
self:RegisterEvent("UNIT_SPELLCAST_CHANNEL_UPDATE", "SpellCastChannelUpdate") -- unit, spell, rank
self:RegisterEvent("UNIT_SPELLCAST_CHANNEL_STOP", "SpellCastChannelStop") -- unit, spell, rank
if GetUnitEmpowerHoldAtMaxTime then
self:RegisterEvent("UNIT_SPELLCAST_EMPOWER_START", "SpellCastChannelStart")
self:RegisterEvent("UNIT_SPELLCAST_EMPOWER_UPDATE", "SpellCastChannelUpdate")
self:RegisterEvent("UNIT_SPELLCAST_EMPOWER_STOP", "SpellCastChannelStop")
end
end
self:Show(false) self:Show(false)
end end
@ -86,7 +178,7 @@ function IceCastBar.prototype:GetOptions()
end, end,
order = 39.998 order = 39.998
} }
if IceHUD.SpellFunctionsReturnRank then
opts["showSpellRank"] = opts["showSpellRank"] =
{ {
type = 'toggle', type = 'toggle',
@ -103,7 +195,7 @@ function IceCastBar.prototype:GetOptions()
end, end,
order = 39.999 order = 39.999
} }
end
opts["iconSettings"] = { opts["iconSettings"] = {
type = 'group', type = 'group',
name = "|c"..self.configColor..L["Icon Settings"].."|r", name = "|c"..self.configColor..L["Icon Settings"].."|r",
@ -251,7 +343,13 @@ function IceCastBar.prototype:PositionIcons()
self.barFrame.icon:SetHeight(AuraIconHeight * self.moduleSettings.auraIconScale) self.barFrame.icon:SetHeight(AuraIconHeight * self.moduleSettings.auraIconScale)
end end
function IceCastBar.prototype:GetRemainingCastTime()
return self.actionStartTime + self.actionDuration - GetTime()
end
function IceCastBar.prototype:GetCurrentCastDurationMs()
return (GetTime() - (self.actionStartTime or GetTime())) * 1000
end
-- OnUpdate handler -- OnUpdate handler
function IceCastBar.prototype:MyOnUpdate() function IceCastBar.prototype:MyOnUpdate()
@ -262,17 +360,15 @@ function IceCastBar.prototype:MyOnUpdate()
return return
end end
local time = GetTime()
self:Update() self:Update()
self:SetTextAlpha() self:SetTextAlpha()
-- handle casting and channeling -- handle casting and channeling
if (self.action == IceCastBar.Actions.Cast or self.action == IceCastBar.Actions.Channel) then if (self.action == IceCastBar.Actions.Cast or self.action == IceCastBar.Actions.Channel or self.action == IceCastBar.Actions.ReverseChannel) then
local remainingTime = self.actionStartTime + self.actionDuration - time local remainingTime = self:GetRemainingCastTime()
local scale = 1 - (self.actionDuration ~= 0 and remainingTime / self.actionDuration or 0) local scale = 1 - (self.actionDuration ~= 0 and remainingTime / self.actionDuration or 0)
if (self.moduleSettings.reverseChannel and self.action == IceCastBar.Actions.Channel) then if self.action == IceCastBar.Actions.ReverseChannel then
scale = self.actionDuration ~= 0 and remainingTime / self.actionDuration or 0 scale = self.actionDuration ~= 0 and remainingTime / self.actionDuration or 0
end end
@ -283,14 +379,22 @@ function IceCastBar.prototype:MyOnUpdate()
end end
local timeString = self.moduleSettings.showCastTime and string.format("%.1fs ", remainingTime) or "" local timeString = self.moduleSettings.showCastTime and string.format("%.1fs ", remainingTime) or ""
self:SetBottomText1(timeString .. self.actionMessage) local empowerString = self.NumStages ~= nil and (L["Stage %d"]):format(self:GetCurrentStage()) or ""
local line1 = timeString .. (self.actionMessage or "")
if self.moduleSettings.empowerStageTextDisplay == "TOPLINE" then
line1 = line1 .. " " .. empowerString
end
if self.moduleSettings.empowerStageTextDisplay == "BOTTOMLINE" then
self:SetBottomText2(empowerString)
end
self:SetBottomText1(line1)
return return
end end
-- stop bar if casting or channeling is done (in theory this should not be needed) -- stop bar if casting or channeling is done (in theory this should not be needed)
if (self.action == IceCastBar.Actions.Cast or self.action == IceCastBar.Actions.Channel) then if (self.action == IceCastBar.Actions.Cast or self.action == IceCastBar.Actions.Channel or self.action == IceCastBar.Actions.ReverseChannel) then
self:StopBar() self:StopBar()
return return
end end
@ -301,17 +405,24 @@ function IceCastBar.prototype:MyOnUpdate()
self.action == IceCastBar.Actions.Success or self.action == IceCastBar.Actions.Success or
self.action == IceCastBar.Actions.Failure) self.action == IceCastBar.Actions.Failure)
then then
local scale = time - self.actionStartTime local scale
if self.actionStartTime then
scale = GetTime() - self.actionStartTime
end
if (scale > 1) then if scale and (scale > 1) then
self:StopBar() self:StopBar()
return return
end end
if (self.action == IceCastBar.Actions.Failure) then self:UpdateBar(1, self:GetCurrentCastingColor())
self:FlashBar("CastFail", 1-scale, self.actionMessage, "CastFail")
else if scale then
self:FlashBar("CastSuccess", 1-scale, self.actionMessage) if (self.action == IceCastBar.Actions.Failure) then
self:FlashBar("CastFail", 1-scale, self.actionMessage, "CastFail")
else
self:FlashBar("CastSuccess", 1-scale, self.actionMessage)
end
end end
return return
end end
@ -321,16 +432,70 @@ function IceCastBar.prototype:MyOnUpdate()
self:StopBar() self:StopBar()
end end
function IceCastBar.prototype:GetCurrentCastingColor() function IceCastBar.prototype:GetStageDuration(stage)
local updateColor = "CastCasting" if not GetUnitEmpowerMinHoldTime then
if self.action == IceCastBar.Actions.Channel then return 0
updateColor = "CastChanneling"
end end
return updateColor
if stage == 0 then
return GetUnitEmpowerMinHoldTime(self.unit)
end
return GetUnitEmpowerStageDuration(self.unit, stage);
end
function IceCastBar.prototype:GetDurationUpToStage(stage)
if stage == nil or stage < 0 then
return 0
end
local total = 0
for i=0,stage-1 do
total = total + self:GetStageDuration(i)
end
return total
end
function IceCastBar.prototype:GetCurrentStage()
if not GetUnitEmpowerMinHoldTime then
return 0
end
local castDuration = self:GetCurrentCastDurationMs()
for i=1,self.NumStages do
if castDuration < self:GetDurationUpToStage(i) then
return i - 1
end
end
return self.NumStages
end
function IceCastBar.prototype:IsCastingEmpowerSpell()
return self.NumStages ~= nil
end
function IceCastBar.prototype:GetCurrentCastingColor()
if self:IsCastingEmpowerSpell() then
return ("EmpowerStage%d"):format(self:GetCurrentStage())
end
if self.action == IceCastBar.Actions.Channel or self.action == IceCastBar.Actions.ReverseChannel then
return "CastChanneling"
end
return "CastCasting"
end end
function IceCastBar.prototype:FlashBar(color, alpha, text, textColor) function IceCastBar.prototype:FlashBar(color, alpha, text, textColor)
self.frame:SetAlpha(alpha) if self.moduleSettings.flashInstants == "Never" then
return
end
if alpha then
self.frame:SetAlpha(alpha)
end
local r, g, b = self.settings.backgroundColor.r, self.settings.backgroundColor.g, self.settings.backgroundColor.b local r, g, b = self.settings.backgroundColor.r, self.settings.backgroundColor.g, self.settings.backgroundColor.b
if (self.settings.backgroundToggle) then if (self.settings.backgroundToggle) then
@ -345,13 +510,46 @@ function IceCastBar.prototype:FlashBar(color, alpha, text, textColor)
end end
function IceCastBar.prototype:StartBar(action, message) function IceCastBar.prototype:StartBar(action, message, spellId)
local spell, rank, displayName, icon, startTime, endTime, isTradeSkill = UnitCastingInfo(self.unit) local spell, rank, displayName, icon, startTime, endTime, isTradeSkill, numStages
if IceHUD.SpellFunctionsReturnRank then
spell, rank, displayName, icon, startTime, endTime, isTradeSkill = UnitCastingInfo(self.unit)
else
spell, displayName, icon, startTime, endTime, isTradeSkill = UnitCastingInfo(self.unit)
end
if not (spell) then if not (spell) then
spell, rank, displayName, icon, startTime, endTime = UnitChannelInfo(self.unit) if IceHUD.SpellFunctionsReturnRank then
spell, rank, displayName, icon, startTime, endTime = UnitChannelInfo(self.unit)
else
spell, displayName, icon, startTime, endTime, isTradeSkill, _, _, _, numStages = UnitChannelInfo(self.unit)
end
end end
if not spell then if spellId and not spell then
spell, rank, icon = GetSpellInfo(spellId)
end
local isChargeSpell = numStages and numStages > 0
if isChargeSpell then
self.NumStages = numStages
endTime = endTime + GetUnitEmpowerHoldAtMaxTime(self.unit)
action = IceCastBar.Actions.ReverseChannel
else
self.NumStages = nil
end
if self.moduleSettings.reverseChannel then
if action == IceCastBar.Actions.Channel then
action = IceCastBar.Actions.ReverseChannel
elseif action == IceCastBar.Actions.ReverseChannel then
action = IceCastBar.Actions.Channel
end
end
-- Fulzamoth 2019-09-27 : LibClassicCasterino won't return spell info on target's failed or interrupted cast
if LibClassicCasterino and not spell then
self:StopBar()
elseif not spell then
return return
end end
@ -378,7 +576,7 @@ function IceCastBar.prototype:StartBar(action, message)
self.actionDuration = 1 -- instants/failures self.actionDuration = 1 -- instants/failures
end end
if not (message) then if not (message) and spell then
self.actionMessage = spell .. (self.moduleSettings.showSpellRank and self:GetShortRank(rank) or "") self.actionMessage = spell .. (self.moduleSettings.showSpellRank and self:GetShortRank(rank) or "")
end end
@ -393,12 +591,13 @@ function IceCastBar.prototype:StopBar()
self.actionDuration = nil self.actionDuration = nil
self:SetBottomText1() self:SetBottomText1()
self:SetBottomText2()
self:SetScale(0) self:SetScale(0)
self:Show(false) self:Show(false)
end end
function IceCastBar.prototype:GetShortRank(rank) function IceCastBar.prototype:GetShortRank(rank)
if (rank) then if IceHUD.SpellFunctionsReturnRank and rank then
local _, _, sRank = string.find(rank, "(%d+)") local _, _, sRank = string.find(rank, "(%d+)")
if (sRank) then if (sRank) then
return " (" .. sRank .. ")" return " (" .. sRank .. ")"
@ -413,54 +612,56 @@ end
-- NORMAL SPELLS -- -- NORMAL SPELLS --
------------------------------------------------------------------------------- -------------------------------------------------------------------------------
function IceCastBar.prototype:SpellCastSent(event, unit, spell, rank, target, lineId) function IceCastBar.prototype:SpellCastSent(event, unit, target, castGuid, spellId)
if (unit ~= self.unit) then return end if (unit ~= self.unit) then return end
IceHUD:Debug("SpellCastSent", unit, spell, rank, target, lineId) IceHUD:Debug("SpellCastSent", unit, target, castGuid, spellId)
end end
function IceCastBar.prototype:SpellCastChanged(event, arg1) function IceCastBar.prototype:SpellCastChanged(event, cancelled)
IceHUD:Debug("SpellCastChanged", arg1) IceHUD:Debug("SpellCastChanged", cancelled)
end end
function IceCastBar.prototype:SpellCastStart(event, unit, spell, rank, lineId, spellId) function IceCastBar.prototype:SpellCastStart(event, unit, castGuid, spellId)
if (unit ~= self.unit) then return end if (unit ~= self.unit) then return end
IceHUD:Debug("SpellCastStart", unit, spell, rank, lineId, spellId) IceHUD:Debug("SpellCastStart", unit, castGuid, spellId)
--UnitCastingInfo(unit) --UnitCastingInfo(unit)
self:StartBar(IceCastBar.Actions.Cast) self:StartBar(IceCastBar.Actions.Cast, nil, spellId)
self.current = lineId self.current = castGuid
end end
function IceCastBar.prototype:SpellCastStop(event, unit, spell, rank, lineId, spellId) function IceCastBar.prototype:SpellCastStop(event, unit, castGuid, spellId)
if (unit ~= self.unit) then return end if (unit ~= self.unit) then return end
IceHUD:Debug("SpellCastStop", unit, spell, self.current, rank, lineId, spellId) IceHUD:Debug("SpellCastStop", unit, castGuid, spellId)
-- ignore if not coming from current spell -- ignore if not coming from current spell
if (self.current and lineId and self.current ~= lineId) then if (self.current and castGuid and self.current ~= castGuid) then
return return
end end
if (self.action ~= IceCastBar.Actions.Success and if (self.action ~= IceCastBar.Actions.Success and
self.action ~= IceCastBar.Actions.Failure and self.action ~= IceCastBar.Actions.Failure and
self.action ~= IceCastBar.Actions.Channel) self.action ~= IceCastBar.Actions.Channel and
self.action ~= IceCastBar.Actions.ReverseChannel)
then then
self:StopBar() self:StopBar()
self.current = nil
end end
self.current = nil
end end
function IceCastBar.prototype:SpellCastFailed(event, unit, spell, rank, lineId, spellId) function IceCastBar.prototype:SpellCastFailed(event, unit, castGuid, spellId)
if (unit ~= self.unit) then return end if (unit ~= self.unit) then return end
IceHUD:Debug("SpellCastFailed", unit, self.current, lineId, spellId) IceHUD:Debug("SpellCastFailed", unit, castGuid, spellId)
-- ignore if not coming from current spell -- ignore if not coming from current spell
if (self.current and lineId and self.current ~= lineId) then if (self.current and castGuid and self.current ~= castGuid) then
return return
end end
-- channeled spells will call ChannelStop, not cast failed -- channeled spells will call ChannelStop, not cast failed
if self.action == IceCastBar.Actions.Channel then if self.action == IceCastBar.Actions.Channel or self.action == IceCastBar.Actions.ReverseChannel then
return return
end end
@ -475,28 +676,28 @@ function IceCastBar.prototype:SpellCastFailed(event, unit, spell, rank, lineId,
end end
end end
self:StartBar(IceCastBar.Actions.Failure, "Failed") self:StartBar(IceCastBar.Actions.Failure, "Failed", nil, spellId)
end end
function IceCastBar.prototype:SpellCastInterrupted(event, unit, spell, rank, lineId, spellId) function IceCastBar.prototype:SpellCastInterrupted(event, unit, castGuid, spellId)
if (unit ~= self.unit) then return end if (unit ~= self.unit) then return end
IceHUD:Debug("SpellCastInterrupted", unit, self.current, lineId, spellId) IceHUD:Debug("SpellCastInterrupted", unit, castGuid, spellId)
-- ignore if not coming from current spell -- ignore if not coming from current spell
if (self.current and lineId and self.current ~= lineId) then if (self.current and castGuid and self.current ~= castGuid) then
return return
end end
self.current = nil self.current = nil
self:StartBar(IceCastBar.Actions.Failure, "Interrupted") self:StartBar(IceCastBar.Actions.Failure, "Interrupted", spellId)
end end
function IceCastBar.prototype:SpellCastDelayed(event, unit, delay) function IceCastBar.prototype:SpellCastDelayed(event, unit, castGuid, spellId)
if (unit ~= self.unit) then return end if (unit ~= self.unit) then return end
--IceHUD:Debug("SpellCastDelayed", unit, UnitCastingInfo(unit)) --IceHUD:Debug("SpellCastDelayed", unit, UnitCastingInfo(unit))
local spell, rank, displayName, icon, startTime, endTime, isTradeSkill = UnitCastingInfo(self.unit) local endTime = select(IceHUD.SpellFunctionsReturnRank and 6 or 5, UnitCastingInfo(self.unit))
if (endTime and self.actionStartTime) then if (endTime and self.actionStartTime) then
-- apparently this check is needed, got nils during a horrible lag spike -- apparently this check is needed, got nils during a horrible lag spike
@ -505,23 +706,25 @@ function IceCastBar.prototype:SpellCastDelayed(event, unit, delay)
end end
function IceCastBar.prototype:SpellCastSucceeded(event, unit, spell, rank, lineId, spellId) function IceCastBar.prototype:SpellCastSucceeded(event, unit, castGuid, spellId)
if (unit ~= self.unit) then return end if (unit ~= self.unit) then return end
--IceHUD:Debug("SpellCastSucceeded", unit, spell, rank) --IceHUD:Debug("SpellCastSucceeded", unit, castGuid, spellId)
-- never show on channeled (why on earth does this event even fire when channeling starts?) -- never show on channeled (why on earth does this event even fire when channeling starts?)
if (self.action == IceCastBar.Actions.Channel) then if (self.action == IceCastBar.Actions.Channel or self.action == IceCastBar.Actions.ReverseChannel) then
return return
end end
-- ignore if not coming from current spell -- ignore if not coming from current spell
if (self.current and self.current ~= lineId) then if (self.current and self.current ~= castGuid) then
return return
end end
local spell = GetSpellName(spellId)
-- show after normal successfull cast -- show after normal successfull cast
if (self.action == IceCastBar.Actions.Cast) then if (self.action == IceCastBar.Actions.Cast) then
self:StartBar(IceCastBar.Actions.Success, spell.. self:GetShortRank(rank)) self:StartBar(IceCastBar.Actions.Success, spell, spellId)
return return
end end
@ -534,7 +737,12 @@ function IceCastBar.prototype:SpellCastSucceeded(event, unit, spell, rank, lineI
end end
end end
self:StartBar(IceCastBar.Actions.Success, spell.. self:GetShortRank(rank)) -- handle special spells that are used for quests or other things that don't apply to the player
if self.unit == "player" and not IsPlayerSpell(spellId) then
return
end
self:StartBar(IceCastBar.Actions.Success, spell, spellId)
end end
@ -554,7 +762,12 @@ function IceCastBar.prototype:SpellCastChannelUpdate(event, unit)
if (unit ~= self.unit or not self.actionStartTime) then return end if (unit ~= self.unit or not self.actionStartTime) then return end
--IceHUD:Debug("SpellCastChannelUpdate", unit, UnitChannelInfo(unit)) --IceHUD:Debug("SpellCastChannelUpdate", unit, UnitChannelInfo(unit))
local spell, rank, displayName, icon, startTime, endTime = UnitChannelInfo(unit) local spell, rank, displayName, icon, startTime, endTime
if IceHUD.SpellFunctionsReturnRank then
spell, rank, displayName, icon, startTime, endTime = UnitChannelInfo(unit)
else
spell, displayName, icon, startTime, endTime = UnitChannelInfo(unit)
end
if not spell then if not spell then
self.actionDuration = 0 self.actionDuration = 0
else else

View File

@ -19,6 +19,25 @@ end
local DogTag = LibStub("LibDogTag-3.0", true) local DogTag = LibStub("LibDogTag-3.0", true)
local GetSpellInfo = GetSpellInfo
if not GetSpellInfo and C_Spell and C_Spell.GetSpellInfo then
GetSpellInfo = function(spellID)
if not spellID then
return nil
end
local spellInfo = C_Spell.GetSpellInfo(spellID)
if spellInfo then
return spellInfo.name, nil, spellInfo.iconID, spellInfo.castTime, spellInfo.minRange, spellInfo.maxRange, spellInfo.spellID, spellInfo.originalIconID
end
end
end
local GetSpellName = GetSpellInfo
if C_Spell and C_Spell.GetSpellName then
GetSpellName = C_Spell.GetSpellName
end
IceCore = IceCore_CreateClass() IceCore = IceCore_CreateClass()
IceCore.Side = { Left = "LEFT", Right = "RIGHT" } IceCore.Side = { Left = "LEFT", Right = "RIGHT" }
@ -41,6 +60,26 @@ IceCore.TextDecorationStyle = {
NoDecoration = L["No decoration"], NoDecoration = L["No decoration"],
} }
local ZM_MAP_ID = 1970
IceCore.zmPuzzleIds = {
--Fugueal Protolock
366046,
366108,
359488,
--Mezzonic Protolock
366042,
366106,
351405,
--Cantaric Protolock
365840,
366107,
348792,
}
IceCore.zmPuzzleMap = {}
for i=1, #IceCore.zmPuzzleIds do
IceCore.zmPuzzleMap[IceCore.zmPuzzleIds[i]] = true
end
local SUNDER_SPELL_ID = 7386 local SUNDER_SPELL_ID = 7386
local LACERATE_SPELL_ID = 33745 local LACERATE_SPELL_ID = 33745
local MAELSTROM_SPELL_ID = 53817 local MAELSTROM_SPELL_ID = 53817
@ -94,6 +133,10 @@ function IceCore.prototype:SetupDefaults()
bHideDuringPetBattles = true, bHideDuringPetBattles = true,
bHideInBarberShop = true, bHideInBarberShop = true,
bHideDuringShellGame = true,
bHideDuringCataloging = true,
addedStrata = 0,
}, },
global = { global = {
lastRunVersion = 0, lastRunVersion = 0,
@ -173,6 +216,13 @@ function IceCore.prototype:CheckDisplayUpdateMessage()
self.settings.modules["DruidMana"] = nil self.settings.modules["DruidMana"] = nil
end end
end end
if self.accountSettings.lastRunVersion <= 20180720033008 then
if self.settings.modules["HarmonyPower"] ~= nil then
self.settings.modules["Chi"] = self.settings.modules["HarmonyPower"]
self.settings.modules["HarmonyPower"] = nil
self.settings.colors["ChiNumeric"] = self.settings.colors["HarmonyPowerNumeric"]
end
end
self.accountSettings.lastRunVersion = thisVersion self.accountSettings.lastRunVersion = thisVersion
end end
end end
@ -243,10 +293,22 @@ function IceCore.prototype:Enable(userToggle)
IceHUD_Options:GenerateModuleOptions() IceHUD_Options:GenerateModuleOptions()
end end
self.IceHUDFrame:RegisterEvent("PET_BATTLE_OPENING_START") if UnitCanPetBattle then
self.IceHUDFrame:RegisterEvent("PET_BATTLE_OVER") self.IceHUDFrame:RegisterEvent("PET_BATTLE_OPENING_START")
self.IceHUDFrame:RegisterEvent("BARBER_SHOP_OPEN") self.IceHUDFrame:RegisterEvent("PET_BATTLE_OVER")
self.IceHUDFrame:RegisterEvent("BARBER_SHOP_CLOSE") end
if GetBarberShopStyleInfo then
self.IceHUDFrame:RegisterEvent("BARBER_SHOP_OPEN")
self.IceHUDFrame:RegisterEvent("BARBER_SHOP_CLOSE")
end
if C_Map then
self.IceHUDFrame:RegisterEvent("PLAYER_ENTERING_WORLD")
self.IceHUDFrame:RegisterEvent("ZONE_CHANGED")
end
self.IceHUDFrame:RegisterEvent("UNIT_AURA")
self.IceHUDFrame:RegisterEvent("UNIT_ENTERED_VEHICLE")
self.IceHUDFrame:RegisterEvent("PLAYER_REGEN_ENABLED", IceHUD.PLAYER_REGEN_ENABLED)
self.IceHUDFrame:RegisterEvent("PLAYER_REGEN_DISABLED", IceHUD.PLAYER_REGEN_DISABLED)
self.IceHUDFrame:SetScript("OnEvent", function(self, event, ...) self.IceHUDFrame:SetScript("OnEvent", function(self, event, ...)
if (event == "PET_BATTLE_OPENING_START") then if (event == "PET_BATTLE_OPENING_START") then
if IceHUD.IceCore.settings.bHideDuringPetBattles then if IceHUD.IceCore.settings.bHideDuringPetBattles then
@ -264,6 +326,58 @@ function IceCore.prototype:Enable(userToggle)
if IceHUD.IceCore.settings.bHideInBarberShop then if IceHUD.IceCore.settings.bHideInBarberShop then
self:Show() self:Show()
end end
elseif event == "UNIT_ENTERED_VEHICLE" then
if IceHUD.IceCore.settings.bHideDuringCataloging and IceHUD:HasAnyBuff("player", IceHUD.CatalogingSpellIDs) then
self:RegisterEvent("UNIT_EXITED_VEHICLE")
self:Hide()
end
elseif (event == "UNIT_AURA") then
local unit = ...
if unit ~= "player" then
return
end
if IceHUD.IceCore.settings.bHideDuringShellGame and IceHUD:HasAnyDebuff("player", {IceHUD.ShellGameSpellID}) and UnitInVehicle("player") then
self:RegisterEvent("UNIT_EXITED_VEHICLE")
self:Hide()
elseif IceHUD.IceCore.settings.bHideDuringCataloging and IceHUD:HasAnyBuff("player", IceHUD.CatalogingSpellIDs) and UnitInVehicle("player") then
self:RegisterEvent("UNIT_EXITED_VEHICLE")
self:Hide()
elseif C_Map then
local bestMapID = C_Map.GetBestMapForUnit("player")
if bestMapID ~= ZM_MAP_ID then
return
end
if IceHUD:HasAnyBuff("player", IceCore.zmPuzzleIds) then
self:RegisterEvent("COMBAT_LOG_EVENT_UNFILTERED")
self:Hide()
end
end
elseif (event == "UNIT_EXITED_VEHICLE") then
self:UnregisterEvent("UNIT_EXITED_VEHICLE")
self:Show()
elseif (event == "PLAYER_ENTERING_WORLD" or event == "ZONE_CHANGED") then
if C_Map then
local bestMapID = C_Map.GetBestMapForUnit("player")
if bestMapID == ZM_MAP_ID then
if IceHUD:HasAnyBuff("player", IceCore.zmPuzzleIds) then
self:RegisterEvent("COMBAT_LOG_EVENT_UNFILTERED")
self:Hide()
end
end
end
elseif (event == "COMBAT_LOG_EVENT_UNFILTERED") then
local _,subevent,_,_,_,_,_,_,destName,_,_,spellId = CombatLogGetCurrentEventInfo()
if subevent == "SPELL_AURA_REMOVED" then
if destName == UnitName("player") then
if IceCore.zmPuzzleMap[spellId] then
self:Show()
self:UnregisterEvent("COMBAT_LOG_EVENT_UNFILTERED")
end
end
end
end end
end) end)
@ -272,13 +386,13 @@ end
function IceCore.prototype:RedirectRemovedModules() function IceCore.prototype:RedirectRemovedModules()
local _, class = UnitClass("player") local _, class = UnitClass("player")
if class == "WARRIOR" and self.settings.modules["SunderCount"] and GetSpellInfo(SUNDER_SPELL_ID) and IceHUD.WowVer < 60000 then if class == "WARRIOR" and self.settings.modules["SunderCount"] and GetSpellName(SUNDER_SPELL_ID) and IceHUD.WowVer < 60000 then
if self.settings.modules["SunderCount"].enabled or self.settings.modules["SunderCount"].enabled == nil then if self.settings.modules["SunderCount"].enabled or self.settings.modules["SunderCount"].enabled == nil then
local bFound = false local bFound = false
for k,v in pairs(self.elements) do for k,v in pairs(self.elements) do
if v.moduleSettings.customBarType == "Counter" and v.moduleSettings.auraName if v.moduleSettings.customBarType == "Counter" and v.moduleSettings.auraName
and string.upper(v.moduleSettings.auraName) == string.upper(GetSpellInfo(SUNDER_SPELL_ID)) then and string.upper(v.moduleSettings.auraName) == string.upper(GetSpellName(SUNDER_SPELL_ID)) then
bFound = true bFound = true
break break
end end
@ -301,7 +415,7 @@ function IceCore.prototype:RedirectRemovedModules()
newCounter.moduleSettings.maxCount = 3 newCounter.moduleSettings.maxCount = 3
newCounter.moduleSettings.auraTarget = "target" newCounter.moduleSettings.auraTarget = "target"
newCounter.moduleSettings.auraType = "debuff" newCounter.moduleSettings.auraType = "debuff"
newCounter.moduleSettings.auraName = GetSpellInfo(SUNDER_SPELL_ID) newCounter.moduleSettings.auraName = GetSpellName(SUNDER_SPELL_ID)
newCounter:Enable() newCounter:Enable()
end end
end end
@ -309,12 +423,12 @@ function IceCore.prototype:RedirectRemovedModules()
self.settings.modules["SunderCount"] = nil self.settings.modules["SunderCount"] = nil
end end
if class == "DRUID" and self.settings.modules["LacerateCount"] and GetSpellInfo(LACERATE_SPELL_ID) then if class == "DRUID" and self.settings.modules["LacerateCount"] and GetSpellName(LACERATE_SPELL_ID) then
if self.settings.modules["LacerateCount"].enabled or self.settings.modules["LacerateCount"].enabled == nil then if self.settings.modules["LacerateCount"].enabled or self.settings.modules["LacerateCount"].enabled == nil then
local bFound = false local bFound = false
for k,v in pairs(self.elements) do for k,v in pairs(self.elements) do
if v.moduleSettings.customBarType == "Counter" and v.moduleSettings.auraName if v.moduleSettings.customBarType == "Counter" and v.moduleSettings.auraName
and string.upper(v.moduleSettings.auraName) == string.upper(GetSpellInfo(LACERATE_SPELL_ID)) then and string.upper(v.moduleSettings.auraName) == string.upper(GetSpellName(LACERATE_SPELL_ID)) then
bFound = true bFound = true
break break
end end
@ -338,7 +452,7 @@ function IceCore.prototype:RedirectRemovedModules()
newCounter.moduleSettings.maxCount = 3 newCounter.moduleSettings.maxCount = 3
newCounter.moduleSettings.auraTarget = "target" newCounter.moduleSettings.auraTarget = "target"
newCounter.moduleSettings.auraType = "debuff" newCounter.moduleSettings.auraType = "debuff"
newCounter.moduleSettings.auraName = GetSpellInfo(LACERATE_SPELL_ID) newCounter.moduleSettings.auraName = GetSpellName(LACERATE_SPELL_ID)
newCounter:Enable() newCounter:Enable()
end end
end end
@ -346,12 +460,12 @@ function IceCore.prototype:RedirectRemovedModules()
self.settings.modules["LacerateCount"] = nil self.settings.modules["LacerateCount"] = nil
end end
if class == "SHAMAN" and self.settings.modules["MaelstromCount"] and GetSpellInfo(MAELSTROM_SPELL_ID) then if class == "SHAMAN" and self.settings.modules["MaelstromCount"] and GetSpellName(MAELSTROM_SPELL_ID) then
if self.settings.modules["MaelstromCount"].enabled or self.settings.modules["MaelstromCount"].enabled == nil then if self.settings.modules["MaelstromCount"].enabled or self.settings.modules["MaelstromCount"].enabled == nil then
local bFound = false local bFound = false
for k,v in pairs(self.elements) do for k,v in pairs(self.elements) do
if v.moduleSettings.customBarType == "Counter" and v.moduleSettings.auraName if v.moduleSettings.customBarType == "Counter" and v.moduleSettings.auraName
and string.upper(v.moduleSettings.auraName) == string.upper(GetSpellInfo(MAELSTROM_SPELL_ID)) then and string.upper(v.moduleSettings.auraName) == string.upper(GetSpellName(MAELSTROM_SPELL_ID)) then
bFound = true bFound = true
break break
end end
@ -371,7 +485,7 @@ function IceCore.prototype:RedirectRemovedModules()
newCounter.moduleSettings.countMode = self.settings.modules["MaelstromCount"].maelstromMode or newCounter.moduleSettings.countMode newCounter.moduleSettings.countMode = self.settings.modules["MaelstromCount"].maelstromMode or newCounter.moduleSettings.countMode
newCounter.moduleSettings.countGap = self.settings.modules["MaelstromCount"].maelstromGap or newCounter.moduleSettings.countGap newCounter.moduleSettings.countGap = self.settings.modules["MaelstromCount"].maelstromGap or newCounter.moduleSettings.countGap
newCounter.moduleSettings.gradient = self.settings.modules["MaelstromCount"].gradient or newCounter.moduleSettings.gradient newCounter.moduleSettings.gradient = self.settings.modules["MaelstromCount"].gradient or newCounter.moduleSettings.gradient
newCounter.moduleSettings.auraName = GetSpellInfo(MAELSTROM_SPELL_ID) newCounter.moduleSettings.auraName = GetSpellName(MAELSTROM_SPELL_ID)
newCounter:Enable() newCounter:Enable()
end end
end end
@ -498,10 +612,14 @@ function IceCore.prototype:Disable(userToggle)
end end
end end
self.IceHUDFrame:UnregisterEvent("PET_BATTLE_OPENING_START") if UnitCanPetBattle then
self.IceHUDFrame:UnregisterEvent("PET_BATTLE_OVER") self.IceHUDFrame:UnregisterEvent("PET_BATTLE_OPENING_START")
self.IceHUDFrame:UnregisterEvent("BARBER_SHOP_OPEN") self.IceHUDFrame:UnregisterEvent("PET_BATTLE_OVER")
self.IceHUDFrame:UnregisterEvent("BARBER_SHOP_CLOSE") end
if GetBarberShopStyleInfo then
self.IceHUDFrame:UnregisterEvent("BARBER_SHOP_OPEN")
self.IceHUDFrame:UnregisterEvent("BARBER_SHOP_CLOSE")
end
self.IceHUDFrame:SetScript("OnEvent", nil) self.IceHUDFrame:SetScript("OnEvent", nil)
self.enabled = false self.enabled = false
@ -513,7 +631,7 @@ function IceCore.prototype:IsEnabled()
end end
function IceCore.prototype:DrawFrame() function IceCore.prototype:DrawFrame()
self.IceHUDFrame:SetFrameStrata("BACKGROUND") self.IceHUDFrame:SetFrameStrata(self:DetermineStrata("BACKGROUND"))
self.IceHUDFrame:SetWidth(self.settings.gap) self.IceHUDFrame:SetWidth(self.settings.gap)
self.IceHUDFrame:SetHeight(20) self.IceHUDFrame:SetHeight(20)
@ -558,10 +676,11 @@ function IceCore.prototype:GetModuleOptions()
for i = 1, table.getn(self.elements) do for i = 1, table.getn(self.elements) do
local modName = self.elements[i]:GetElementName() local modName = self.elements[i]:GetElementName()
local modDesc = self.elements[i]:GetElementDescription()
local opt = self.elements[i]:GetOptions() local opt = self.elements[i]:GetOptions()
options[modName] = { options[modName] = {
type = 'group', type = 'group',
desc = L["Module options"], desc = modDesc,
name = modName, name = modName,
args = opt args = opt
} }
@ -833,6 +952,48 @@ function IceCore.prototype:SetColor(color, r, g, b)
self:Redraw() self:Redraw()
end end
function IceCore.prototype:GetAddedStrata()
return self.settings.addedStrata
end
function IceCore.prototype:SetAddedStrata(value)
self.settings.addedStrata = value
end
-- Preventing ugly if-else blocks in module creations
-- (but could probably itself be smarter/prettier)
-- Frisbees/AddonWhiner
function IceCore.prototype:DetermineStrata(baseStrata)
if self.settings.addedStrata == 0 then
return baseStrata
end
if self.settings.addedStrata == 1 then
if baseStrata == "BACKGROUND" then
return "LOW"
elseif baseStrata == "LOW" then
return "MEDIUM"
elseif baseStrata == "MEDIUM" then
return "HIGH"
elseif baseStrata == "HIGH" then
return "DIALOG"
end
end
if self.settings.addedStrata == 2 then
if baseStrata == "BACKGROUND" then
return "MEDIUM"
elseif baseStrata == "LOW" then
return "HIGH"
elseif baseStrata == "MEDIUM" then
return "DIALOG"
elseif baseStrata == "HIGH" then
return "FULLSCREEN"
end
end
return baseStrata -- failsafe
end
function IceCore.prototype:IsInConfigMode() function IceCore.prototype:IsInConfigMode()
return self.bConfigMode return self.bConfigMode

View File

@ -63,14 +63,18 @@ function IceElement.prototype:GetElementName()
return self.elementName return self.elementName
end end
function IceElement.prototype:GetElementDescription()
return L["Module options"]
end
function IceElement.prototype:Create(parent) function IceElement.prototype:Create(parent)
assert(parent, "IceElement 'parent' can't be nil") assert(parent, "IceElement 'parent' can't be nil")
self.parent = parent self.parent = parent
if not self.masterFrame then if not self.masterFrame then
self.masterFrame = CreateFrame("Frame", nil, self.parent) self.masterFrame = CreateFrame("Frame", "IceHUD_Element_"..self.elementName, self.parent)
self.masterFrame:SetFrameStrata("MEDIUM") self.masterFrame:SetFrameStrata(IceHUD.IceCore:DetermineStrata("MEDIUM"))
end end
self:CreateFrame() self:CreateFrame()
self:Show(false) self:Show(false)

View File

@ -1,22 +1,107 @@
local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false) local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false)
IceHUD = LibStub("AceAddon-3.0"):NewAddon("IceHUD", "AceConsole-3.0") IceHUD = LibStub("AceAddon-3.0"):NewAddon("IceHUD", "AceConsole-3.0", "AceHook-3.0")
local IceHUD = IceHUD local IceHUD = IceHUD
local SML = LibStub("LibSharedMedia-3.0") local SML = LibStub("LibSharedMedia-3.0")
local ACR = LibStub("AceConfigRegistry-3.0") local ACR = LibStub("AceConfigRegistry-3.0")
local ConfigDialog = LibStub("AceConfigDialog-3.0") local ConfigDialog = LibStub("AceConfigDialog-3.0")
local icon = LibStub("LibDBIcon-1.0") local icon = LibStub("LibDBIcon-1.0", true)
local AceGUI = LibStub("AceGUI-3.0")
local AceSerializer = LibStub("AceSerializer-3.0", 1)
local pendingModuleLoads = {} local pendingModuleLoads = {}
local bReadyToRegisterModules = false local bReadyToRegisterModules = false
local LoadAddOn = C_AddOns and C_AddOns.LoadAddOn or LoadAddOn
IceHUD.UnitAura = UnitAura
if not IceHUD.UnitAura then
IceHUD.UnitAura = function(unitToken, index, filter)
local auraData = C_UnitAuras.GetAuraDataByIndex(unitToken, index, filter)
if not auraData then
return nil
end
return AuraUtil.UnpackAuraData(auraData)
end
end
IceHUD.CurrTagVersion = 3 IceHUD.CurrTagVersion = 3
IceHUD.debugging = false IceHUD.debugging = false
IceHUD.WowVer = select(4, GetBuildInfo()) IceHUD.WowVer = select(4, GetBuildInfo())
IceHUD.WowMain = not WOW_PROJECT_ID or WOW_PROJECT_ID == WOW_PROJECT_MAINLINE
if GetClassicExpansionLevel then
IceHUD.WowClassic = GetClassicExpansionLevel() == 0
IceHUD.WowClassicBC = GetClassicExpansionLevel() == 1
IceHUD.WowClassicWrath = GetClassicExpansionLevel() == 2
IceHUD.WowClassicCataclysm = GetClassicExpansionLevel() == 3
else
IceHUD.WowClassic = WOW_PROJECT_ID and WOW_PROJECT_ID == WOW_PROJECT_CLASSIC
IceHUD.WowClassicBC = false
IceHUD.WowClassicWrath = false
IceHUD.WowClassicCataclysm = false
if WOW_PROJECT_ID and WOW_PROJECT_ID == WOW_PROJECT_BURNING_CRUSADE_CLASSIC then
if not LE_EXPANSION_LEVEL_CURRENT or LE_EXPANSION_LEVEL_CURRENT == LE_EXPANSION_BURNING_CRUSADE then
IceHUD.WowClassicBC = true
elseif LE_EXPANSION_LEVEL_CURRENT == LE_EXPANSION_WRATH_OF_THE_LICH_KING then
IceHUD.WowClassicWrath = true
end
elseif WOW_PROJECT_WRATH_CLASSIC and WOW_PROJECT_ID == WOW_PROJECT_WRATH_CLASSIC then
IceHUD.WowClassicWrath = true
elseif WOW_PROJECT_CATACLYSM_CLASSIC and WOW_PROJECT_ID == WOW_PROJECT_CATACLYSM_CLASSIC then
IceHUD.WowClassicCataclysm = true
end
end
local GetSpellInfo = GetSpellInfo
if not GetSpellInfo and C_Spell and C_Spell.GetSpellInfo then
GetSpellInfo = function(spellID)
if not spellID then
return nil
end
local spellInfo = C_Spell.GetSpellInfo(spellID)
if spellInfo then
return spellInfo.name, nil, spellInfo.iconID, spellInfo.castTime, spellInfo.minRange, spellInfo.maxRange, spellInfo.spellID, spellInfo.originalIconID
end
end
end
local GetSpellName = GetSpellInfo
if C_Spell and C_Spell.GetSpellName then
GetSpellName = C_Spell.GetSpellName
end
-- compatibility/feature flags
IceHUD.CanShowTargetCasting = not IceHUD.WowClassic or LibClassicCasterino or (IceHUD.WowClassic and IceHUD.WowVer >= 11500)
IceHUD.GetPlayerAuraBySpellID = _G["C_UnitAuras"] and C_UnitAuras.GetPlayerAuraBySpellID
IceHUD.SpellFunctionsReturnRank = IceHUD.WowMain and IceHUD.WowVer < 80000
IceHUD.EventExistsPlayerPetChanged = IceHUD.WowMain and IceHUD.WowVer < 80000
IceHUD.EventExistsPetBarChanged = IceHUD.WowMain and IceHUD.WowVer < 80000
IceHUD.EventExistsPlayerComboPoints = IceHUD.WowMain and IceHUD.WowVer < 30000
IceHUD.EventExistsUnitComboPoints = IceHUD.WowMain and IceHUD.WowVer < 70000
IceHUD.EventExistsUnitMaxPower = IceHUD.WowMain and IceHUD.WowVer >= 40000
IceHUD.EventExistsGroupRosterUpdate = IceHUD.WowVer >= 50000 or not IceHUD.WowMain
IceHUD.EventExistsUnitDynamicFlags = IceHUD.WowMain and IceHUD.WowVer < 80000
IceHUD.EventExistsUnitHealthFrequent = not IceHUD.WowMain or (IceHUD.WowVer >= 40000 and IceHUD.WowVer < 90000)
IceHUD.PerPowerEventsExist = IceHUD.WowMain and IceHUD.WowVer < 40000
IceHUD.PerTargetComboPoints = IceHUD.WowVer < 60000
IceHUD.CanTrackOtherUnitBuffs = not IceHUD.WowClassic or IceHUD.WowVer >= 11500
IceHUD.CanTrackGCD = not IceHUD.WowClassic or IceHUD.WowVer >= 11500
IceHUD.GetSpellInfoReturnsFunnel = IceHUD.WowMain and IceHUD.WowVer < 60000
IceHUD.CanHookDestroyTotem = IceHUD.WowClassic or IceHUD.WowClassicBC or IceHUD.WowClassicWrath or IceHUD.WowClassicCataclysm
IceHUD.ShouldUpdateTargetHealthEveryTick = (IceHUD.WowClassic or IceHUD.WowClassicBC) and GetCVarBool("predictedHealth")
IceHUD.UsesUIPanelButtonTemplate = IceHUD.WowVer >= 50000 or not IceHUD.WowMain
IceHUD.EventExistsSpellcastInterruptible = IceHUD.WowVer >= 30200 and not IceHUD.WowClassicWrath
IceHUD.DeathKnightUnholyFrostRunesSwapped = IceHUD.WowVer < 70300 and not IceHUD.WowClassicWrath and not IceHUD.WowClassicCataclysm
IceHUD.SupportsHealPrediction = IceHUD.WowVer >= 40000 or IceHUD.WowClassicWrath
IceHUD.UnitGroupRolesReturnsRoleString = IceHUD.WowVer >= 40000 or IceHUD.WowClassicWrath
IceHUD.ShellGameSpellID = 271571
IceHUD.HasShellGame = GetSpellName(IceHUD.ShellGameSpellID)
IceHUD.CatalogingSpellIDs = {366290, 372817, 385025, 385635, 386070, 386504, 400043, 403115}
IceHUD.HasCataloging = GetSpellName(366290)
IceHUD.UnitPowerEvent = "UNIT_POWER_UPDATE"
IceHUD.validBarList = { "Bar", "HiBar", "RoundBar", "ColorBar", "RivetBar", "RivetBar2", "CleanCurves", "GlowArc", IceHUD.validBarList = { "Bar", "HiBar", "RoundBar", "ColorBar", "RivetBar", "RivetBar2", "CleanCurves", "GlowArc",
"BloodGlaives", "ArcHUD", "FangRune", "DHUD", "CleanCurvesOut", "CleanTank", "PillTank", "GemTank" } "BloodGlaives", "ArcHUD", "FangRune", "DHUD", "CleanCurvesOut", "CleanTank", "PillTank", "GemTank" }
@ -46,6 +131,43 @@ end
IceHUD.deepcopy = deepcopy IceHUD.deepcopy = deepcopy
function IceHUD:removeDefaults(db, defaults, blocker)
-- remove all metatables from the db, so we don't accidentally create new sub-tables through them
setmetatable(db, nil)
-- loop through the defaults and remove their content
for k,v in pairs(defaults) do
if type(v) == "table" and type(db[k]) == "table" then
-- if a blocker was set, dive into it, to allow multi-level defaults
self:removeDefaults(db[k], v, blocker and blocker[k])
if next(db[k]) == nil then
db[k] = nil
end
else
-- check if the current value matches the default, and that its not blocked by another defaults table
if db[k] == defaults[k] and (not blocker or blocker[k] == nil) then
db[k] = nil
end
end
end
end
function IceHUD:populateDefaults(db, defaults, blocker)
-- remove all metatables from the db, so we don't accidentally create new sub-tables through them
setmetatable(db, nil)
-- loop through the defaults and add their content
for k,v in pairs(defaults) do
if type(v) == "table" and type(db[k]) == "table" then
-- if a blocker was set, dive into it, to allow multi-level defaults
self:populateDefaults(db[k], v, blocker and blocker[k])
else
-- check if the current value matches the default, and that its not blocked by another defaults table
if db[k] == nil then
db[k] = defaults[k]
end
end
end
end
IceHUD.Location = "Interface\\AddOns\\IceHUD" IceHUD.Location = "Interface\\AddOns\\IceHUD"
StaticPopupDialogs["ICEHUD_CUSTOM_BAR_CREATED"] = StaticPopupDialogs["ICEHUD_CUSTOM_BAR_CREATED"] =
@ -256,6 +378,10 @@ function IceHUD:NotifyOptionsChange()
end end
function IceHUD:OnEnable(isFirst) function IceHUD:OnEnable(isFirst)
-- if isFirst then
self:SetDebugging(self.IceCore:GetDebug())
self.debugFrame = ChatFrame1
-- end
self:Debug("IceHUD:OnEnable()") self:Debug("IceHUD:OnEnable()")
if self.db.profile.enable then if self.db.profile.enable then
@ -271,11 +397,6 @@ function IceHUD:OnEnable(isFirst)
--@debug@ --@debug@
IceHUD_Options:OnLoad() IceHUD_Options:OnLoad()
--@end-debug@ --@end-debug@
-- if isFirst then
self:SetDebugging(self.IceCore:GetDebug())
self.debugFrame = ChatFrame1
-- end
end end
-- add settings changes/updates here so that existing users don't lose their settings -- add settings changes/updates here so that existing users don't lose their settings
@ -322,13 +443,18 @@ end
-- blizzard interface options -- blizzard interface options
local blizOptionsPanel = CreateFrame("FRAME", "IceHUDConfigPanel", UIParent) local blizOptionsPanel = CreateFrame("FRAME", "IceHUDConfigPanel", UIParent)
blizOptionsPanel.name = "IceHUD" blizOptionsPanel.name = "IceHUD"
blizOptionsPanel.button = CreateFrame("BUTTON", "IceHUDOpenConfigButton", blizOptionsPanel, IceHUD.WowVer >= 50000 and "UIPanelButtonTemplate" or "UIPanelButtonTemplate2") blizOptionsPanel.button = CreateFrame("BUTTON", "IceHUDOpenConfigButton", blizOptionsPanel, IceHUD.UsesUIPanelButtonTemplate and "UIPanelButtonTemplate" or "UIPanelButtonTemplate2")
blizOptionsPanel.button:SetText("Open IceHUD configuration") blizOptionsPanel.button:SetText("Open IceHUD configuration")
blizOptionsPanel.button:SetWidth(240) blizOptionsPanel.button:SetWidth(240)
blizOptionsPanel.button:SetHeight(30) blizOptionsPanel.button:SetHeight(30)
blizOptionsPanel.button:SetScript("OnClick", function(self) HideUIPanel(InterfaceOptionsFrame) HideUIPanel(GameMenuFrame) IceHUD:OpenConfig() end) blizOptionsPanel.button:SetScript("OnClick", function(self) HideUIPanel(InterfaceOptionsFrame) HideUIPanel(GameMenuFrame) IceHUD:OpenConfig() end)
blizOptionsPanel.button:SetPoint('TOPLEFT', blizOptionsPanel, 'TOPLEFT', 20, -20) blizOptionsPanel.button:SetPoint('TOPLEFT', blizOptionsPanel, 'TOPLEFT', 20, -20)
InterfaceOptions_AddCategory(blizOptionsPanel) if InterfaceOptions_AddCategory then
InterfaceOptions_AddCategory(blizOptionsPanel)
elseif Settings then
local category = Settings.RegisterCanvasLayoutCategory(blizOptionsPanel, "IceHUD")
Settings.RegisterAddOnCategory(category)
end
function IceHUD:OpenConfig() function IceHUD:OpenConfig()
if not ConfigDialog then return end if not ConfigDialog then return end
@ -364,7 +490,11 @@ function IceHUD:Debug(...)
for n=1,select('#', ...) do for n=1,select('#', ...) do
msg = msg .. tostring(select(n, ...)) .. " " msg = msg .. tostring(select(n, ...)) .. " "
end end
self.debugFrame:AddMessage(msg) if self.debugFrame then
self.debugFrame:AddMessage(msg)
else
print(msg)
end
end end
end end
@ -392,7 +522,7 @@ end
function IceHUD:GetAuraCount(auraType, unit, ability, onlyMine, matchByName) function IceHUD:GetAuraCount(auraType, unit, ability, onlyMine, matchByName)
if not unit or not ability then if not unit or not ability then
return 0 return 0, nil
end end
if unit == "main hand weapon" or unit == "off hand weapon" then if unit == "main hand weapon" or unit == "off hand weapon" then
@ -400,39 +530,63 @@ function IceHUD:GetAuraCount(auraType, unit, ability, onlyMine, matchByName)
= GetWeaponEnchantInfo() = GetWeaponEnchantInfo()
if unit == "main hand weapon" and hasMainHandEnchant then if unit == "main hand weapon" and hasMainHandEnchant then
return mainHandCharges return mainHandCharges, nil
elseif unit == "off hand weapon" and hasOffHandEnchant then elseif unit == "off hand weapon" and hasOffHandEnchant then
return offHandCharges return offHandCharges, nil
end end
return 0 return 0, nil
end
-- Support for Spell IDs
if (IceHUD.GetPlayerAuraBySpellID and tonumber(ability) ~= nil) then
local aura = C_UnitAuras.GetPlayerAuraBySpellID(ability)
if aura ~= nil then
return aura.applications, nil
else
return 0, nil
end
end end
local i = 1 local i = 1
local name, _, texture, applications = UnitAura(unit, i, auraType..(onlyMine and "|PLAYER" or "")) local name, _, texture, applications
if IceHUD.SpellFunctionsReturnRank then
name, _, texture, applications = IceHUD.UnitAura(unit, i, auraType..(onlyMine and "|PLAYER" or ""))
else
name, texture, applications = IceHUD.UnitAura(unit, i, auraType..(onlyMine and "|PLAYER" or ""))
end
while name do while name do
if (not matchByName and string.match(texture:upper(), ability:upper())) if (not matchByName and string.match(texture:upper(), ability:upper()))
or (matchByName and string.match(name:upper(), ability:upper())) then or (matchByName and string.match(name:upper(), ability:upper())) then
return applications return applications, i
end end
i = i + 1 i = i + 1
name, _, texture, applications = UnitAura(unit, i, auraType..(onlyMine and "|PLAYER" or "")) if IceHUD.SpellFunctionsReturnRank then
name, _, texture, applications = IceHUD.UnitAura(unit, i, auraType..(onlyMine and "|PLAYER" or ""))
else
name, texture, applications = IceHUD.UnitAura(unit, i, auraType..(onlyMine and "|PLAYER" or ""))
end
end end
return 0 return 0, nil
end end
do do
local retval = {} local retval = {}
function IceHUD:HasBuffs(unit, spellIDs) function IceHUD:HasBuffs(unit, spellIDs, filter)
for i=1, #spellIDs do for i=1, #spellIDs do
retval[i] = false retval[i] = false
end end
local i = 1 local i = 1
local name, _, texture, applications, _, _, _, _, _, _, auraID = UnitAura(unit, i) local name, _, texture, applications, _, _, _, _, _, _, auraID
if IceHUD.SpellFunctionsReturnRank then
name, _, texture, applications, _, _, _, _, _, _, auraID = IceHUD.UnitAura(unit, i, filter)
else
name, texture, applications, _, _, _, _, _, _, auraID = IceHUD.UnitAura(unit, i, filter)
end
while name do while name do
for i=1, #spellIDs do for i=1, #spellIDs do
if spellIDs[i] == auraID then if spellIDs[i] == auraID then
@ -442,11 +596,43 @@ do
end end
i = i + 1 i = i + 1
name, _, texture, applications, _, _, _, _, _, _, auraID = UnitAura(unit, i) if IceHUD.SpellFunctionsReturnRank then
name, _, texture, applications, _, _, _, _, _, _, auraID = IceHUD.UnitAura(unit, i, filter)
else
name, texture, applications, _, _, _, _, _, _, auraID = IceHUD.UnitAura(unit, i, filter)
end
end end
return retval return retval
end end
function IceHUD:HasDebuffs(unit, spellIDs, filter)
return IceHUD:HasBuffs(unit, spellIDs, filter and filter.."|HARMFUL" or "HARMFUL")
end
function IceHUD:HasAnyBuff(unit, spellIDs, filter)
local buffs = IceHUD:HasBuffs(unit, spellIDs, filter)
for i=1, #buffs do
if buffs[i] then
return true
end
end
return false
end
function IceHUD:HasAnyDebuff(unit, spellIDs, filter)
local debuffs = IceHUD:HasDebuffs(unit, spellIDs, filter)
for i=1, #debuffs do
if debuffs[i] then
return true
end
end
return false
end
end end
function IceHUD:OnDisable() function IceHUD:OnDisable()
@ -581,15 +767,19 @@ local function CheckLFGMode(mode)
end end
function IceHUD:GetIsInLFGGroup() function IceHUD:GetIsInLFGGroup()
if not GetLFGMode then
return false
end
local mode, submode local mode, submode
if IceHUD.WowVer >= 50000 then if LE_LFG_CATEGORY_LFD then
mode, submode = GetLFGMode(LE_LFG_CATEGORY_LFD) mode, submode = GetLFGMode(LE_LFG_CATEGORY_LFD)
else else
mode, submode = GetLFGMode() mode, submode = GetLFGMode()
end end
local IsInLFGGroup = CheckLFGMode(mode) local IsInLFGGroup = CheckLFGMode(mode)
if IceHUD.WowVer < 50000 then if not LE_LFG_CATEGORY_LFD then
return IsInLFGGroup return IsInLFGGroup
end end
@ -609,132 +799,52 @@ function IceHUD:GetIsInLFGGroup()
return IsInLFGGroup return IsInLFGGroup
end end
local BLACKLISTED_UNIT_MENU_OPTIONS = { function IceHUD:OutOfCombatWrapper(func)
SET_FOCUS = "ICEHUD_SET_FOCUS", return function(...)
CLEAR_FOCUS = "ICEHUD_CLEAR_FOCUS", return IceHUD:RunOnLeaveCombat(func, ...)
PET_DISMISS = "ICEHUD_PET_DISMISS",
LOCK_FOCUS_FRAME = true,
UNLOCK_FOCUS_FRAME = true,
}
UnitPopupButtons["ICEHUD_SET_FOCUS"] = {
text = L["Type %s to set focus"]:format(SLASH_FOCUS1),
tooltipText = L["Blizzard currently does not provide a proper way to right-click focus with custom unit frames."],
dist = 0,
}
UnitPopupButtons["ICEHUD_CLEAR_FOCUS"] = {
text = L["Type %s to clear focus"]:format(SLASH_CLEARFOCUS1),
tooltipText = L["Blizzard currently does not provide a proper way to right-click focus with custom unit frames."],
dist = 0,
}
UnitPopupButtons["ICEHUD_PET_DISMISS"] = {
text = L["Use your Dismiss Pet spell to dismiss a pet"],
tooltipText = L["Blizzard currently does not provide a proper way to right-click dismiss a pet with custom unit frames."],
dist = 0,
}
local munged_unit_menus = {}
local function munge_unit_menu(menu)
local result = munged_unit_menus[menu]
if result then
return result
end end
if not UnitPopupMenus then
munged_unit_menus[menu] = menu
return menu
end
local data = UnitPopupMenus[menu]
if not data then
munged_unit_menus[menu] = menu
return menu
end
local found = false
local _, v
for _, v in ipairs(data) do
if BLACKLISTED_UNIT_MENU_OPTIONS[v] then
found = true
break
end
end
if not found then
-- nothing to remove or add, we're all fine here.
munged_unit_menus[menu] = menu
return menu
end
local new_data = {}
for _, v in ipairs(data) do
local blacklisted = BLACKLISTED_UNIT_MENU_OPTIONS[v]
if v == "PET_DISMISS" and select(2, UnitClass("player")) == "WARLOCK" then
blacklisted = false
end
if not blacklisted then
new_data[#new_data+1] = v
elseif blacklisted ~= true then
new_data[#new_data+1] = blacklisted
end
end
local new_menu_name = "ICEHUD_" .. menu
UnitPopupMenus[new_menu_name] = new_data
munged_unit_menus[menu] = new_menu_name
return new_menu_name
end
IceHUD.MungeUnitMenu = munge_unit_menu
local function figure_unit_menu(unit)
if unit == "focus" then
return "FOCUS"
end
if UnitIsUnit(unit, "player") then
return "SELF"
end
if UnitIsUnit(unit, "vehicle") then
-- NOTE: vehicle check must come before pet check for accuracy's sake because
-- a vehicle may also be considered your pet
return "VEHICLE"
end
if UnitIsUnit(unit, "pet") then
return "PET"
end
if not UnitIsPlayer(unit) then
return "TARGET"
end
local id = UnitInRaid(unit)
if id then
return "RAID_PLAYER", id
end
if UnitInParty(unit) then
return "PARTY"
end
return "PLAYER"
end end
IceHUD_UnitFrame_DropDown = CreateFrame("Frame", "IceHUD_UnitFrame_DropDown", UIParent, "UIDropDownMenuTemplate") do
UnitPopupFrames[#UnitPopupFrames+1] = "IceHUD_UnitFrame_DropDown" local in_combat = false
local in_lockdown = false
IceHUD.DropdownUnit = nil local actions_to_perform = {}
UIDropDownMenu_Initialize(IceHUD_UnitFrame_DropDown, function() local pool = setmetatable({}, {__mode='k'})
if not IceHUD.DropdownUnit then function IceHUD:PLAYER_REGEN_ENABLED()
return in_combat = false
in_lockdown = false
for i, t in ipairs(actions_to_perform) do
t.f(unpack(t, 1, t.n))
actions_to_perform[i] = nil
wipe(t)
pool[t] = true
end
end end
function IceHUD:PLAYER_REGEN_DISABLED()
local menu, id = figure_unit_menu(IceHUD.DropdownUnit) in_combat = true
if menu then
menu = IceHUD.MungeUnitMenu(menu)
UnitPopup_ShowMenu(IceHUD_UnitFrame_DropDown, menu, IceHUD.DropdownUnit, nil, id)
end end
end, "MENU", nil) function IceHUD:RunOnLeaveCombat(func, ...)
if not in_combat then
-- out of combat, call right away and return
func(...)
return
end
if not in_lockdown then
in_lockdown = InCombatLockdown() -- still in PLAYER_REGEN_DISABLED
if not in_lockdown then
func(...)
return
end
end
local t = next(pool) or {}
pool[t] = nil
t.f = func
local n = select('#', ...)
t.n = n
for i = 1, n do
t[i] = select(i, ...)
end
actions_to_perform[#actions_to_perform+1] = t
end
end

View File

@ -1,15 +1,27 @@
## Interface: 70100 ## Interface: 110007
## Interface-Retail: 110007
## Interface-Classic: 11505
## Interface-BCC: 20504
## Interface-Wrath: 30403
## Interface-Cata: 40401
## Author: Parnic, originally created by Iceroth ## Author: Parnic, originally created by Iceroth
## Name: IceHUD ## Name: IceHUD
## Title: IceHUD |cff7fff7f-Ace3-|r ## Title: IceHUD |cff7fff7f-Ace3-|r
## Notes: Another HUD addon ## Notes: Another HUD addon
## Version: @project-version@ #@debug@
## Version: development
#@end-debug@
#@non-debug@
# ## Version: @project-version@
#@end-non-debug@
## SavedVariables: IceCoreDB ## SavedVariables: IceCoreDB
## OptionalDeps: Ace3, LibSharedMedia-3.0, LibDogTag-3.0, LibDogTag-Unit-3.0, LibRangeCheck-2.0, LibDualSpec-1.0, LibDBIcon-1.0, AceGUI-3.0-SharedMediaWidgets ## IconTexture: Interface\Icons\Spell_Frost_Frost
## X-Compatible-With: 60200 ## OptionalDeps: Ace3, LibSharedMedia-3.0, LibDogTag-3.0, LibDogTag-Unit-3.0, LibRangeCheck-3.0, LibDualSpec-1.0, LibDBIcon-1.0, AceGUI-3.0-SharedMediaWidgets
## X-Category: HUDs ## X-Category: HUDs
## X-Website: http://www.wowace.com/addons/ice-hud/ ## X-Website: https://www.wowace.com/projects/ice-hud
## X-Curse-Project-ID: 5394
## X-WoWI-ID: 8149 ## X-WoWI-ID: 8149
## X-Wago-ID: 5bGolJN0
#@no-lib-strip@ #@no-lib-strip@
# Libraries # Libraries
@ -29,7 +41,6 @@ IceCastBar.lua
IceStackCounter.lua IceStackCounter.lua
# IceHUD modules # IceHUD modules
# - Feel free to comment these out if you like
modules\PlayerHealth.lua modules\PlayerHealth.lua
modules\PlayerMana.lua modules\PlayerMana.lua
modules\TargetHealth.lua modules\TargetHealth.lua
@ -90,7 +101,13 @@ modules\Stagger.lua
modules\PlayerAltMana.lua modules\PlayerAltMana.lua
modules\ArcaneCharges.lua modules\ArcaneCharges.lua
modules\RollTheBones.lua modules\RollTheBones.lua
modules\EssencePower.lua
modules\DruidEnergy.lua
modules\DragonridingVigor.lua
#@do-not-package@ #@do-not-package@
IceHUD_Options\Json.lua
IceHUD_Options\JsonDecode.lua
IceHUD_Options\JsonEncode.lua
IceHUD_Options\Options.lua IceHUD_Options\Options.lua
#@end-do-not-package@ #@end-do-not-package@

View File

@ -1,4 +1,9 @@
## Interface: 70000 ## Interface: 110007
## Interface-Retail: 110007
## Interface-Classic: 11505
## Interface-BCC: 20504
## Interface-Wrath: 30403
## Interface-Cata: 40401
## Title: IceHUD |cff7fff7f-Options-|r ## Title: IceHUD |cff7fff7f-Options-|r
## Author: Parnic ## Author: Parnic
## Version: @project-version@ ## Version: @project-version@
@ -6,5 +11,9 @@
## OptionalDeps: AceGUI-3.0-SharedMediaWidgets ## OptionalDeps: AceGUI-3.0-SharedMediaWidgets
## Dependencies: IceHUD ## Dependencies: IceHUD
## LoadOnDemand: 1 ## LoadOnDemand: 1
## IconTexture: Interface\Icons\Spell_Frost_Frost
Json.lua
JsonDecode.lua
JsonEncode.lua
Options.lua Options.lua

1
IceHUD_Options/Json.lua Normal file
View File

@ -0,0 +1 @@
IceHUD.json = {}

View File

@ -0,0 +1,241 @@
local parse
local function create_set(...)
local res = {}
for i = 1, select("#", ...) do
res[select(i, ...)] = true
end
return res
end
local space_chars = create_set(" ", "\t", "\r", "\n")
local delim_chars = create_set(" ", "\t", "\r", "\n", "]", "}", ",")
local escape_chars = create_set("\\", "/", '"', "b", "f", "n", "r", "t", "u")
local literals = create_set("true", "false", "null")
local literal_map = {
["true"] = true,
["false"] = false,
["null"] = nil,
}
local function next_char(str, idx, set, negate)
for i = idx, #str do
if set[str:sub(i, i)] ~= negate then
return i
end
end
return #str + 1
end
local function decode_error(str, idx, msg)
local line_count = 1
local col_count = 1
for i = 1, idx - 1 do
col_count = col_count + 1
if str:sub(i, i) == "\n" then
line_count = line_count + 1
col_count = 1
end
end
return string.format("%s at line %d col %d", msg, line_count, col_count)
end
local function codepoint_to_utf8(n)
-- http://scripts.sil.org/cms/scripts/page.php?site_id=nrsi&id=iws-appendixa
local f = math.floor
if n <= 0x7f then
return string.char(n)
elseif n <= 0x7ff then
return string.char(f(n / 64) + 192, n % 64 + 128)
elseif n <= 0xffff then
return string.char(f(n / 4096) + 224, f(n % 4096 / 64) + 128, n % 64 + 128)
elseif n <= 0x10ffff then
return string.char(f(n / 262144) + 240, f(n % 262144 / 4096) + 128,
f(n % 4096 / 64) + 128, n % 64 + 128)
end
return "", string.format("invalid unicode codepoint '%x'", n)
end
local function parse_unicode_escape(s)
local n1 = tonumber(s:sub(1, 4), 16)
local n2 = tonumber(s:sub(7, 10), 16)
-- Surrogate pair?
if n2 then
return codepoint_to_utf8((n1 - 0xd800) * 0x400 + (n2 - 0xdc00) + 0x10000)
else
return codepoint_to_utf8(n1)
end
end
local function parse_string(str, i)
local res = ""
local j = i + 1
local k = j
while j <= #str do
local x = str:byte(j)
if x < 32 then
return str, j, decode_error(str, j, "control character in string")
elseif x == 92 then -- `\`: Escape
res = res .. str:sub(k, j - 1)
j = j + 1
local c = str:sub(j, j)
if c == "u" then
local hex = str:match("^[dD][89aAbB]%x%x\\u%x%x%x%x", j + 1)
or str:match("^%x%x%x%x", j + 1)
or false
if hex == false then
return str, j-1, decode_error(str, j - 1, "invalid unicode escape in string")
end
res = res .. parse_unicode_escape(hex)
j = j + #hex
else
if not escape_chars[c] then
return str, j-1, decode_error(str, j - 1, "invalid escape char '" .. c .. "' in string")
end
res = res .. escape_char_map_inv[c]
end
k = j + 1
elseif x == 34 then -- `"`: End of string
res = res .. str:sub(k, j - 1)
return res, j + 1
end
j = j + 1
end
return str, i, decode_error(str, i, "expected closing quote for string")
end
local function parse_number(str, i)
local x = next_char(str, i, delim_chars)
local s = str:sub(i, x - 1)
local n = tonumber(s)
if not n then
return -1, -1, decode_error(str, i, "invalid number '" .. s .. "'")
end
return n, x
end
local function parse_literal(str, i)
local x = next_char(str, i, delim_chars)
local word = str:sub(i, x - 1)
if not literals[word] then
return false, -1, decode_error(str, i, "invalid literal '" .. word .. "'")
end
return literal_map[word], x
end
local function parse_array(str, i)
local res = {}
local n = 1
i = i + 1
while 1 do
local x
i = next_char(str, i, space_chars, true)
-- Empty / end of array?
if str:sub(i, i) == "]" then
i = i + 1
break
end
-- Read token
x, i = parse(str, i)
res[n] = x
n = n + 1
-- Next token
i = next_char(str, i, space_chars, true)
local chr = str:sub(i, i)
i = i + 1
if chr == "]" then break end
if chr ~= "," then return nil, -1, decode_error(str, i, "expected ']' or ','") end
end
return res, i
end
local function parse_object(str, i)
local res = {}
i = i + 1
while 1 do
local key, val
i = next_char(str, i, space_chars, true)
-- Empty / end of object?
if str:sub(i, i) == "}" then
i = i + 1
break
end
-- Read key
if str:sub(i, i) ~= '"' then
return nil, -1, decode_error(str, i, "expected string for key")
end
key, i = parse(str, i)
-- Read ':' delimiter
i = next_char(str, i, space_chars, true)
if str:sub(i, i) ~= ":" then
return nil, -1, decode_error(str, i, "expected ':' after key")
end
i = next_char(str, i + 1, space_chars, true)
-- Read value
val, i = parse(str, i)
-- Set
res[key] = val
-- Next token
i = next_char(str, i, space_chars, true)
local chr = str:sub(i, i)
i = i + 1
if chr == "}" then break end
if chr ~= "," then return nil, -1, decode_error(str, i, "expected '}' or ','") end
end
return res, i
end
local char_func_map = {
['"'] = parse_string,
["0"] = parse_number,
["1"] = parse_number,
["2"] = parse_number,
["3"] = parse_number,
["4"] = parse_number,
["5"] = parse_number,
["6"] = parse_number,
["7"] = parse_number,
["8"] = parse_number,
["9"] = parse_number,
["-"] = parse_number,
["t"] = parse_literal,
["f"] = parse_literal,
["n"] = parse_literal,
["["] = parse_array,
["{"] = parse_object,
}
parse = function(str, idx)
local chr = str:sub(idx, idx)
local f = char_func_map[chr]
if f then
return f(str, idx)
end
return false, -1, decode_error(str, idx, "unexpected character '" .. chr .. "'")
end
function IceHUD.json.decode(str)
if type(str) ~= "string" then
return nil, "expected argument of type string, got " .. type(str)
end
local res, idx, err = parse(str, next_char(str, 1, space_chars, true))
if err ~= nil then
return nil, err
end
idx = next_char(str, idx, space_chars, true)
if idx <= #str then
return nil, decode_error(str, idx, "trailing garbage")
end
return res, nil
end

View File

@ -0,0 +1,100 @@
local encode
local escape_char_map = {
["\\"] = "\\",
["\""] = "\"",
["\b"] = "b",
["\f"] = "f",
["\n"] = "n",
["\r"] = "r",
["\t"] = "t",
}
local escape_char_map_inv = { ["/"] = "/" }
for k, v in pairs(escape_char_map) do
escape_char_map_inv[v] = k
end
local function escape_char(c)
return "\\" .. (escape_char_map[c] or string.format("u%04x", c:byte()))
end
local function encode_nil(val)
return "null"
end
local function encode_table(val, stack)
local res = {}
stack = stack or {}
-- Circular reference?
if stack[val] then error("circular reference") end
stack[val] = true
if rawget(val, 1) ~= nil or next(val) == nil then
-- Treat as array -- check keys are valid and it is not sparse
local n = 0
for k in pairs(val) do
if type(k) ~= "number" then
error("invalid table: mixed or invalid key types")
end
n = n + 1
end
if n ~= #val then
error("invalid table: sparse array")
end
-- Encode
for i, v in ipairs(val) do
table.insert(res, encode(v, stack))
end
stack[val] = nil
return "[" .. table.concat(res, ",") .. "]"
else
-- Treat as an object
for k, v in pairs(val) do
if type(k) ~= "string" then
error("invalid table: mixed or invalid key types")
end
table.insert(res, encode(k, stack) .. ":" .. encode(v, stack))
end
stack[val] = nil
return "{" .. table.concat(res, ",") .. "}"
end
end
local function encode_string(val)
return '"' .. val:gsub('[%z\1-\31\\"]', escape_char) .. '"'
end
local function encode_number(val)
-- Check for NaN, -inf and inf
if val ~= val or val <= -math.huge or val >= math.huge then
error("unexpected number value '" .. tostring(val) .. "'")
end
return string.format("%.14g", val)
end
local type_func_map = {
["nil"] = encode_nil,
["table"] = encode_table,
["string"] = encode_string,
["number"] = encode_number,
["boolean"] = tostring,
}
encode = function(val, stack)
local t = type(val)
local f = type_func_map[t]
if f then
return f(val, stack)
end
error("unexpected type '" .. t .. "'")
end
function IceHUD.json.encode(val)
return (encode(val))
end

View File

@ -1,6 +1,8 @@
local LibDualSpec = LibStub('LibDualSpec-1.0', true) local LibDualSpec = LibStub('LibDualSpec-1.0', true)
local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false) local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false)
local icon = LibStub("LibDBIcon-1.0") local icon = LibStub("LibDBIcon-1.0", true)
local AceGUI = LibStub("AceGUI-3.0")
local AceSerializer = LibStub("AceSerializer-3.0", 1)
local lastCustomModule = "Bar" local lastCustomModule = "Bar"
IceHUD_Options = {} IceHUD_Options = {}
@ -71,7 +73,7 @@ This isn't |cff9999ffIceHUD|r - it's Blizzard's Spell Alerts they added in 4.0.1
Expand "|cffffdc42Module Settings|r", expand whatever module you want to move (e.g. PlayerHealth, PlayerMana), and adjust the "Side" and "Offset" settings. "Side" controls whether it's on the left or the right and "Offset" controls how far from center it is. Expand "|cffffdc42Module Settings|r", expand whatever module you want to move (e.g. PlayerHealth, PlayerMana), and adjust the "Side" and "Offset" settings. "Side" controls whether it's on the left or the right and "Offset" controls how far from center it is.
|cff9999ff14. Which module displays Monk Chi power?|r |cff9999ff14. Which module displays Monk Chi power?|r
This module is called |cffdcff42HarmonyPower|r. Harmony was the original name for Chi back when 5.0 was in beta, so I used Blizzard's name for it while I was developing for Cataclysm. I feel like it's too late to change now that many people are familiar with the Harmony name. Prior to |cff9999ffIceHUD|r v1.11.2, this module was called |cffdcff42HarmonyPower|r. Harmony was the original name for Chi back when 5.0 was in beta, so I used Blizzard's name for it while I was developing for Cataclysm. |cff9999ffIceHUD|r v1.11.2 changed this module to be called |cffdcff42Chi|r.
|cff9999ff15. How do I add commas/periods into big numbers like health?|r |cff9999ff15. How do I add commas/periods into big numbers like health?|r
If you have |cff42ffffDogTags|r enabled, you can open the Text Settings for the module in question and add SeparateDigits() around the tag you're trying to split up. To display Health/MaxHealth with commas, use: [(SeparateDigits(HP):HPColor "/" SeparateDigits(MaxHP):HPColor):Bracket]. To use periods instead of commas, use: [(SeparateDigits(HP, "."):HPColor "/" SeparateDigits(MaxHP, "."):HPColor):Bracket]. Use the /dog help menu to build your own similar tags for Mana, etc. If you have |cff42ffffDogTags|r enabled, you can open the Text Settings for the module in question and add SeparateDigits() around the tag you're trying to split up. To display Health/MaxHealth with commas, use: [(SeparateDigits(HP):HPColor "/" SeparateDigits(MaxHP):HPColor):Bracket]. To use periods instead of commas, use: [(SeparateDigits(HP, "."):HPColor "/" SeparateDigits(MaxHP, "."):HPColor):Bracket]. Use the /dog help menu to build your own similar tags for Mana, etc.
@ -83,7 +85,13 @@ If you have |cff42ffffDogTags|r enabled, you can open the Text Settings for the
This is a side effect of the animation API that I'm co-opting to force a rotation without having to provide duplicates of every bar texture in the mod. Any bar moving sufficiently quickly and updating rapidly will cause this. |cff9999ffIceHUD|r is intended to be a vertically-oriented mod, so the rotation feature is there for people who are willing to accept the side effects that come with it. My suggestion is to use one of the many horizontally-oriented bar mods out there if you're wanting horizontal bars. |cff42ffffQuartz|r is a good castbar replacement that you can use and disable |cff9999ffIceHUD|r's built-in castbar, for example. This is a side effect of the animation API that I'm co-opting to force a rotation without having to provide duplicates of every bar texture in the mod. Any bar moving sufficiently quickly and updating rapidly will cause this. |cff9999ffIceHUD|r is intended to be a vertically-oriented mod, so the rotation feature is there for people who are willing to accept the side effects that come with it. My suggestion is to use one of the many horizontally-oriented bar mods out there if you're wanting horizontal bars. |cff42ffffQuartz|r is a good castbar replacement that you can use and disable |cff9999ffIceHUD|r's built-in castbar, for example.
|cff9999ff18. How do I get rid of the bars that showed up beneath the player in the 7.0 patch?|r |cff9999ff18. How do I get rid of the bars that showed up beneath the player in the 7.0 patch?|r
Blizzard added a "Personal Resource Display" feature in the 7.0 game client. You can disable it in the Game options -> Interface -> Names -> Personal Resource Display.]] Blizzard added a "Personal Resource Display" feature in the 7.0 game client. You can disable it in the Game options -> |cffffdc42Interface|r -> |cffffdc42Names|r -> |cffffdc42Personal Resource Display|r (or Options -> |cffffdc42Combat|r -> |cffffdc42Personal Resource Display|r, in 10.0+).
|cff9999ff19. Why is there no target castbar for Classic?|r
The Classic game client doesn't offer a reliable way to show castbars for anyone except the player. You can install the |cff42ffffLibCasterCasterino|r addon to enable support, but it's a best guess and not at all accurate.
|cff9999ff20. Why do buff/debuff timers not work in Classic?|r
The Classic game client doesn't provide this information to addons because it wasn't a feature when the game first released. You can install the |cff42ffffLibClassicDurations|r addon to enable support, but it's a best guess and not at all accurate.]]
} }
} }
}, },
@ -153,7 +161,7 @@ Blizzard added a "Personal Resource Display" feature in the 7.0 game client. You
IceHUD.IceCore:SetScale(v) IceHUD.IceCore:SetScale(v)
end, end,
min = 0.2, min = 0.2,
max = 2.0, max = 4.0,
step = 0.05, step = 0.05,
isPercent = true, isPercent = true,
order = 14, order = 14,
@ -379,6 +387,7 @@ Blizzard added a "Personal Resource Display" feature in the 7.0 game client. You
IceHUD.IceCore.IceHUDFrame:Show() IceHUD.IceCore.IceHUDFrame:Show()
end end
end, end,
hidden = not UnitCanPetBattle,
order = 34, order = 34,
}, },
@ -396,31 +405,65 @@ Blizzard added a "Personal Resource Display" feature in the 7.0 game client. You
IceHUD.IceCore.IceHUDFrame:Show() IceHUD.IceCore.IceHUDFrame:Show()
end end
end, end,
hidden = not GetBarberShopStyleInfo,
order = 35, order = 35,
}, },
bHideDuringShellGame = {
type = 'toggle',
name = L["Hide during shell game"],
desc = L["This will hide the entire mod when playing the BfA Tortollan shell game world quest."],
width = 'double',
get = function()
return IceHUD.IceCore.settings.bHideDuringShellGame
end,
set = function(info, value)
IceHUD.IceCore.settings.bHideDuringShellGame = value
if not value then
IceHUD.IceCore.IceHUDFrame:Show()
end
end,
hidden = not IceHUD.HasShellGame,
order = 36,
},
bHideDuringCataloging = {
type = 'toggle',
name = L["Hide during cataloging"],
desc = L["This will hide the entire mod when using the Dragonflight Cataloging camera."],
width = 'double',
get = function()
return IceHUD.IceCore.settings.bHideDuringCataloging
end,
set = function(info, value)
IceHUD.IceCore.settings.bHideDuringCataloging = value
if not value then
IceHUD.IceCore.IceHUDFrame:Show()
end
end,
hidden = not IceHUD.HasCataloging,
order = 36,
},
bIncreaseStrata = {
type = 'range',
name = L["Added strata"],
desc = L["Push IceHUD modules to the foreground. Increase if other addons are covering IceHUD. Requires reload."],
get = function()
return IceHUD.IceCore:GetAddedStrata()
end,
set = function(info, v)
IceHUD.IceCore:SetAddedStrata(v)
end,
min = 0,
max = 2,
step = 1,
order = 37,
},
} }
}, },
textSettings = {
type = 'select',
dialogControl = "LSM30_Font",
name = L["Font"],
desc = L["IceHUD Font"],
order = 19,
get = function(info)
return IceHUD.IceCore:GetFontFamily()
end,
set = function(info, value)
IceHUD.IceCore:SetFontFamily(value)
end,
disabled = function()
return not IceHUD.IceCore:IsEnabled()
end,
values = AceGUIWidgetLSMlists.font,
order = 94.75,
},
barSettings = { barSettings = {
type = 'group', type = 'group',
name = L["Bar Settings"], name = L["Bar Settings"],
@ -718,6 +761,26 @@ Blizzard added a "Personal Resource Display" feature in the 7.0 game client. You
} }
} }
if AceGUIWidgetLSMlists then
options.args.textSettings = {
type = 'select',
dialogControl = "LSM30_Font",
name = L["Font"],
desc = L["IceHUD Font"],
get = function(info)
return IceHUD.IceCore:GetFontFamily()
end,
set = function(info, value)
IceHUD.IceCore:SetFontFamily(value)
end,
disabled = function()
return not IceHUD.IceCore:IsEnabled()
end,
values = AceGUIWidgetLSMlists.font,
order = 94.75,
}
end
IceHUD_Options.options = options IceHUD_Options.options = options
function IceHUD_Options:GenerateModuleOptions(firstLoad) function IceHUD_Options:GenerateModuleOptions(firstLoad)
@ -727,23 +790,6 @@ function IceHUD_Options:GenerateModuleOptions(firstLoad)
end end
end end
function IceHUD_Options:OnLoad()
self:GenerateModuleOptions(true)
self.options.args.colors.args = IceHUD.IceCore:GetColorOptions()
self.options.args.profiles = LibStub("AceDBOptions-3.0"):GetOptionsTable(IceHUD.db)
-- Add dual-spec support
if IceHUD.db ~= nil and LibDualSpec then
LibDualSpec:EnhanceOptions(IceHUD_Options.options.args.profiles, IceHUD.db)
end
LibStub("AceConfig-3.0"):RegisterOptionsTable("IceHUD", options, "icehudcl")
end
if IceHUD and IceHUD.IceCore then
IceHUD_Options:OnLoad()
end
function IceHUD_Options:SetupProfileImportButtons() function IceHUD_Options:SetupProfileImportButtons()
if AceSerializer then if AceSerializer then
AceSerializer:Embed(self) AceSerializer:Embed(self)
@ -761,30 +807,12 @@ function IceHUD_Options:SetupProfileImportButtons()
editbox:SetLabel("Profile") editbox:SetLabel("Profile")
editbox:SetFullWidth(true) editbox:SetFullWidth(true)
editbox:SetFullHeight(true) editbox:SetFullHeight(true)
local profileTable = deepcopy(IceHUD.db.profile) local profileTable = IceHUD.deepcopy(IceHUD.db.profile)
IceHUD:removeDefaults(profileTable, IceHUD.IceCore.defaults.profile) IceHUD:removeDefaults(profileTable, IceHUD.IceCore.defaults.profile)
editbox:SetText(IceHUD:Serialize(profileTable)) editbox:SetText(IceHUD.json.encode(profileTable))
editbox:DisableButton(true) editbox:DisableButton(true)
frame:AddChild(editbox) frame:AddChild(editbox)
end, end,
hidden =
-- hello, snooper! this feature doesn't actually work yet, so enabling it won't help you much :)
--[===[@non-debug@
true
--@end-non-debug@]===]
--@debug@
false
--@end-debug@
,
disabled =
-- hello, snooper! this feature doesn't actually work yet, so enabling it won't help you much :)
--[===[@non-debug@
true
--@end-non-debug@]===]
--@debug@
false
--@end-debug@
,
order = 98.1 order = 98.1
} }
@ -798,11 +826,14 @@ function IceHUD_Options:SetupProfileImportButtons()
frame:SetStatusText("Exported profile details") frame:SetStatusText("Exported profile details")
frame:SetLayout("Flow") frame:SetLayout("Flow")
frame:SetCallback("OnClose", function(widget) frame:SetCallback("OnClose", function(widget)
local success, newTable = IceHUD:Deserialize(widget.children[1]:GetText()) local newTable, err = IceHUD.json.decode(widget.children[1]:GetText())
if success then if err ~= nil then
print("failed to import profile: "..err)
else
print("importing profile")
IceHUD:PreProfileChanged() IceHUD:PreProfileChanged()
IceHUD:populateDefaults(newTable, IceHUD.IceCore.defaults.profile) IceHUD:populateDefaults(newTable, IceHUD.IceCore.defaults.profile)
IceHUD.db.profile = deepcopy(newTable) IceHUD.db.profile = IceHUD.deepcopy(newTable)
IceHUD:PostProfileChanged() IceHUD:PostProfileChanged()
end end
AceGUI:Release(widget) AceGUI:Release(widget)
@ -814,29 +845,25 @@ function IceHUD_Options:SetupProfileImportButtons()
editbox:DisableButton(true) editbox:DisableButton(true)
frame:AddChild(editbox) frame:AddChild(editbox)
end, end,
hidden =
-- hello, snooper! this feature doesn't actually work yet, so enabling it won't help you much :)
--[===[@non-debug@
true
--@end-non-debug@]===]
--@debug@
false
--@end-debug@
,
disabled =
-- hello, snooper! this feature doesn't actually work yet, so enabling it won't help you much :)
--[===[@non-debug@
true
--@end-non-debug@]===]
--@debug@
false
--@end-debug@
,
order = 98.2 order = 98.2
} }
end end
end end
--@debug@ function IceHUD_Options:OnLoad()
IceHUD_Options:SetupProfileImportButtons() self:GenerateModuleOptions(true)
--@end-debug@ self.options.args.colors.args = IceHUD.IceCore:GetColorOptions()
self.options.args.profiles = LibStub("AceDBOptions-3.0"):GetOptionsTable(IceHUD.db)
self:SetupProfileImportButtons()
-- Add dual-spec support
if IceHUD.db ~= nil and LibDualSpec then
LibDualSpec:EnhanceOptions(IceHUD_Options.options.args.profiles, IceHUD.db)
end
LibStub("AceConfig-3.0"):RegisterOptionsTable("IceHUD", options, "icehudcl")
end
if IceHUD and IceHUD.IceCore then
IceHUD_Options:OnLoad()
end

View File

@ -0,0 +1,37 @@
local function table_print(tt, indent, done)
done = done or {}
indent = indent or 0
if type(tt) == "table" then
local sb = {}
for key, value in pairs(tt) do
table.insert(sb, string.rep(" ", indent)) -- indent it
if type(value) == "table" and not done[value] then
done[value] = true
table.insert(sb, key .. " = {\n");
table.insert(sb, table_print(value, indent + 2, done))
table.insert(sb, string.rep(" ", indent)) -- indent it
table.insert(sb, "}\n");
elseif "number" == type(key) then
table.insert(sb, string.format("\"%s\"\n", tostring(value)))
else
table.insert(sb, string.format(
"%s = \"%s\"\n", tostring(key), tostring(value)))
end
end
return table.concat(sb)
else
return tt .. "\n"
end
end
local function to_string(tbl)
if "nil" == type(tbl) then
return tostring(nil)
elseif "table" == type(tbl) then
return table_print(tbl)
elseif "string" == type(tbl) then
return tbl
else
return tostring(tbl)
end
end

View File

@ -3,6 +3,21 @@ local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false)
local validUnits = {"player", "target", "focus", "pet", "vehicle", "targettarget", "main hand weapon", "off hand weapon"} local validUnits = {"player", "target", "focus", "pet", "vehicle", "targettarget", "main hand weapon", "off hand weapon"}
local buffOrDebuff = {"buff", "debuff", "charges", "spell count"} local buffOrDebuff = {"buff", "debuff", "charges", "spell count"}
local GetSpellCharges = GetSpellCharges
if not GetSpellCharges and C_Spell then
GetSpellCharges = function(spellID)
local spellChargeInfo = C_Spell.GetSpellCharges(spellID)
if spellChargeInfo then
return spellChargeInfo.currentCharges, spellChargeInfo.maxCharges, spellChargeInfo.cooldownStartTime, spellChargeInfo.cooldownDuration, spellChargeInfo.chargeModRate
end
end
end
local GetSpellCount = GetSpellCount
if not GetSpellCount and C_Spell then
GetSpellCount = C_Spell.GetSpellCastCount
end
-- OVERRIDE -- OVERRIDE
function IceStackCounter_GetOptions(frame, opts) function IceStackCounter_GetOptions(frame, opts)
opts["customHeader"] = { opts["customHeader"] = {
@ -52,7 +67,13 @@ function IceStackCounter_GetOptions(frame, opts)
opts["auraName"] = { opts["auraName"] = {
type = 'input', type = 'input',
name = L["Aura to track"], name = L["Aura to track"],
desc = L["Which buff/debuff this counter will be tracking. \n\nRemember to press ENTER after filling out this box with the name you want or it will not save."], desc = function()
if IceHUD.GetPlayerAuraBySpellID then
return L["Which buff/debuff this counter will be tracking. Can use the name or spell id. \n\nRemember to press ENTER after filling out this box with the name you want or it will not save."]
else
return L["Which buff/debuff this counter will be tracking. \n\nRemember to press ENTER after filling out this box with the name you want or it will not save."]
end
end,
get = function() get = function()
return frame.moduleSettings.auraName return frame.moduleSettings.auraName
end, end,
@ -112,7 +133,7 @@ function IceStackCounter_GetMaxCount(frame)
local _, max = GetSpellCharges(frame.moduleSettings.auraName) local _, max = GetSpellCharges(frame.moduleSettings.auraName)
return max or 1 return max or 1
else else
return frame.moduleSettings.maxCount return tonumber(frame.moduleSettings.maxCount)
end end
end end
@ -128,9 +149,12 @@ end
function IceStackCounter_Enable(frame) function IceStackCounter_Enable(frame)
frame:RegisterEvent("UNIT_AURA", "UpdateCustomCount") frame:RegisterEvent("UNIT_AURA", "UpdateCustomCount")
frame:RegisterEvent("UNIT_PET", "UpdateCustomCount") frame:RegisterEvent("UNIT_PET", "UpdateCustomCount")
frame:RegisterEvent("PLAYER_PET_CHANGED", "UpdateCustomCount") if IceHUD.EventExistsPlayerPetChanged then
frame:RegisterEvent("PLAYER_FOCUS_CHANGED", "UpdateCustomCount") frame:RegisterEvent("PLAYER_PET_CHANGED", "UpdateCustomCount")
frame:RegisterEvent("PLAYER_TARGET_CHANGED", "UpdateCustomCount") end
if FocusUnit then
frame:RegisterEvent("PLAYER_FOCUS_CHANGED", "UpdateCustomCount")
end
frame:RegisterEvent("PLAYER_DEAD", "UpdateCustomCount") frame:RegisterEvent("PLAYER_DEAD", "UpdateCustomCount")
frame:RegisterEvent("SPELL_UPDATE_CHARGES", "UpdateCustomCount") frame:RegisterEvent("SPELL_UPDATE_CHARGES", "UpdateCustomCount")
@ -171,5 +195,9 @@ function IceStackCounter_GetCount(frame)
end end
function IceStackCounter_UseTargetAlpha(frame) function IceStackCounter_UseTargetAlpha(frame)
return frame.lastPoints ~= nil and frame.lastPoints > 0 if frame.moduleSettings.auraType == "charges" then
return IceStackCounter_GetCount(frame) ~= IceStackCounter_GetMaxCount(frame) or frame.target or frame.combat
else
return frame.lastPoints ~= nil and frame.lastPoints > 0
end
end end

View File

@ -19,6 +19,13 @@ IceUnitBar.prototype.hasPet = nil
IceUnitBar.prototype.noFlash = nil IceUnitBar.prototype.noFlash = nil
local SPELL_POWER_INSANITY, SPELL_POWER_RAGE, SPELL_POWER_RUNIC_POWER = SPELL_POWER_INSANITY, SPELL_POWER_RAGE, SPELL_POWER_RUNIC_POWER
if Enum and Enum.PowerType then
SPELL_POWER_INSANITY = Enum.PowerType.Insanity
SPELL_POWER_RAGE = Enum.PowerType.Rage
SPELL_POWER_RUNIC_POWER = Enum.PowerType.RunicPower
end
-- Constructor -- -- Constructor --
function IceUnitBar.prototype:init(name, unit) function IceUnitBar.prototype:init(name, unit)
IceUnitBar.super.prototype.init(self, name) IceUnitBar.super.prototype.init(self, name)
@ -81,7 +88,7 @@ function IceUnitBar.prototype:GetOptions()
self:Redraw() self:Redraw()
end, end,
disabled = function() disabled = function()
return not self.moduleSettings.enabled or not self.moduleSettings.lowThresholdFlash return not self.moduleSettings.enabled or not (self.moduleSettings.lowThresholdFlash or self.moduleSettings.lowThresholdColor)
end, end,
min = 0, min = 0,
max = 1, max = 1,
@ -99,10 +106,14 @@ function IceUnitBar.prototype:GetOptions()
end, end,
set = function(info, v) set = function(info, v)
self.moduleSettings.lowThresholdFlash = v self.moduleSettings.lowThresholdFlash = v
self:Redraw()
end, end,
disabled = function() disabled = function()
return not self.moduleSettings.enabled return not self.moduleSettings.enabled
end, end,
hidden = function()
return self.noFlash
end,
order = 30.092 order = 30.092
} }
opts["lowThresholdColor"] = { opts["lowThresholdColor"] = {
@ -117,7 +128,7 @@ function IceUnitBar.prototype:GetOptions()
self:Redraw() self:Redraw()
end, end,
disabled = function() disabled = function()
return not self.moduleSettings.enabled or not (self.moduleSettings.scaleHealthColor and self.moduleSettings.scaleManaColor) return not self.moduleSettings.enabled
end, end,
order = 30.093 order = 30.093
} }
@ -165,10 +176,10 @@ end
-- Creates the low amount warning frame -- Creates the low amount warning frame
function IceUnitBar.prototype:CreateFlashFrame() function IceUnitBar.prototype:CreateFlashFrame()
if not (self.flashFrame) then if not (self.flashFrame) then
self.flashFrame = CreateFrame("Frame", nil, self.frame) self.flashFrame = CreateFrame("Frame", "IceHUD_"..self.elementName.."_Flash", self.frame)
end end
self.flashFrame:SetFrameStrata("BACKGROUND") self.flashFrame:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
self.flashFrame:SetWidth(self.settings.barWidth + (self.moduleSettings.widthModifier or 0)) self.flashFrame:SetWidth(self.settings.barWidth + (self.moduleSettings.widthModifier or 0))
self.flashFrame:SetHeight(self.settings.barHeight) self.flashFrame:SetHeight(self.settings.barHeight)
@ -215,7 +226,7 @@ end
function IceUnitBar.prototype:Update() function IceUnitBar.prototype:Update()
IceUnitBar.super.prototype.Update(self) IceUnitBar.super.prototype.Update(self)
if IceHUD.WowVer < 70000 then if UnitIsTapped then
self.tapped = UnitIsTapped(self.unit) and (not UnitIsTappedByPlayer(self.unit)) self.tapped = UnitIsTapped(self.unit) and (not UnitIsTappedByPlayer(self.unit))
else else
self.tapped = UnitIsTapDenied(self.unit) self.tapped = UnitIsTapDenied(self.unit)
@ -225,9 +236,28 @@ function IceUnitBar.prototype:Update()
self.maxHealth = UnitHealthMax(self.unit) self.maxHealth = UnitHealthMax(self.unit)
self.healthPercentage = self.maxHealth ~= 0 and (self.health/self.maxHealth) or 0 self.healthPercentage = self.maxHealth ~= 0 and (self.health/self.maxHealth) or 0
-- note that UnitPowerType returns 2 arguments and UnitPower[Max] accepts a third argument to get the values on a different scale
-- so this technically doesn't get us the answer we want most of the time. too risky to change at this point, though.
self.mana = UnitPower(self.unit, UnitPowerType(self.unit)) self.mana = UnitPower(self.unit, UnitPowerType(self.unit))
self.maxMana = UnitPowerMax(self.unit, UnitPowerType(self.unit)) self.maxMana = UnitPowerMax(self.unit, UnitPowerType(self.unit))
self.manaPercentage = self.maxMana ~= 0 and (self.mana/self.maxMana) or 0 local powerType = UnitPowerType(self.unit)
if (powerType == SPELL_POWER_RAGE and self.maxMana == 1000)
or (powerType == SPELL_POWER_RUNIC_POWER and self.maxMana >= 1000) then
self.mana = IceHUD:MathRound(self.mana / 10)
self.maxMana = IceHUD:MathRound(self.maxMana / 10)
end
if IceHUD.WowVer >= 70300 and UnitPowerType(self.unit) == SPELL_POWER_INSANITY then
self.mana = IceHUD:MathRound(self.mana / 100)
self.maxMana = IceHUD:MathRound(self.maxMana / 100)
end
-- account for cases where maxMana is 0, perhaps briefly (during certain spells, for example)
-- and properly handle it as full. this allows for proper alpha handling during these times.
if self.maxMana == self.mana then
self.manaPercentage = 1
else
self.manaPercentage = self.maxMana ~= 0 and (self.mana/self.maxMana) or 0
end
local locClass local locClass
locClass, self.unitClass = UnitClass(self.unit) locClass, self.unitClass = UnitClass(self.unit)
@ -255,14 +285,14 @@ function IceUnitBar.prototype:Update()
-- This looks slightly quirky. Basically the easiest way for me to achieve this is to have lowThresholdColor override -- This looks slightly quirky. Basically the easiest way for me to achieve this is to have lowThresholdColor override
-- the scaled color. You'll need to switch them both on to get things to work. -- the scaled color. You'll need to switch them both on to get things to work.
if( self.moduleSettings.lowThresholdColor ) then if( self.moduleSettings.lowThresholdColor ) then
if( self.healthPercentage < self.moduleSettings.lowThreshold ) then if( self.healthPercentage <= self.moduleSettings.lowThreshold ) then
self.settings.colors[ "ScaledHealthColor" ] = self.settings.colors[ "MinHealthColor" ] self.settings.colors[ "ScaledHealthColor" ] = self.settings.colors[ "MinHealthColor" ]
else elseif not self.moduleSettings.scaleHealthColor then
self.settings.colors[ "ScaledHealthColor" ] = self.settings.colors[ "MaxHealthColor" ] self.settings.colors[ "ScaledHealthColor" ] = self.settings.colors[ "MaxHealthColor" ]
end end
if( self.manaPercentage < self.moduleSettings.lowThreshold ) then if( self.manaPercentage <= self.moduleSettings.lowThreshold ) then
self.settings.colors[ "ScaledManaColor" ] = self.settings.colors[ "MinManaColor" ] self.settings.colors[ "ScaledManaColor" ] = self.settings.colors[ "MinManaColor" ]
else elseif not self.moduleSettings.scaleManaColor then
self.settings.colors[ "ScaledManaColor" ] = self.settings.colors[ "MaxManaColor" ] self.settings.colors[ "ScaledManaColor" ] = self.settings.colors[ "MaxManaColor" ]
end end
end end

21
LICENSE Normal file
View File

@ -0,0 +1,21 @@
MIT License
Copyright (c) 2021-2022 parnic
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.

File diff suppressed because it is too large Load Diff

View File

@ -1,4 +1,5 @@
<Ui xmlns="http://www.blizzard.com/wow/ui/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.blizzard.com/wow/ui/..\FrameXML\UI.xsd"> <Ui xmlns="http://www.blizzard.com/wow/ui/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.blizzard.com/wow/ui/..\FrameXML\UI.xsd">
<!--@non-debug@
<Script file="libs\LibStub\LibStub.lua"/> <Script file="libs\LibStub\LibStub.lua"/>
<Script file="libs\CallbackHandler-1.0\CallbackHandler-1.0.lua"/> <Script file="libs\CallbackHandler-1.0\CallbackHandler-1.0.lua"/>
<Include file="libs\AceDB-3.0\AceDB-3.0.xml"/> <Include file="libs\AceDB-3.0\AceDB-3.0.xml"/>
@ -6,16 +7,19 @@
<Include file="libs\AceGUI-3.0\AceGUI-3.0.xml"/> <Include file="libs\AceGUI-3.0\AceGUI-3.0.xml"/>
<Include file="libs\AceConfig-3.0\AceConfig-3.0.xml"/> <Include file="libs\AceConfig-3.0\AceConfig-3.0.xml"/>
<Include file="libs\AceEvent-3.0\AceEvent-3.0.xml"/> <Include file="libs\AceEvent-3.0\AceEvent-3.0.xml"/>
<Include file="libs\AceSerializer-3.0\AceSerializer-3.0.xml"/>
<Include file="libs\AceTimer-3.0\AceTimer-3.0.xml"/> <Include file="libs\AceTimer-3.0\AceTimer-3.0.xml"/>
<Include file="libs\AceConsole-3.0\AceConsole-3.0.xml"/> <Include file="libs\AceConsole-3.0\AceConsole-3.0.xml"/>
<Include file="libs\AceAddon-3.0\AceAddon-3.0.xml"/> <Include file="libs\AceAddon-3.0\AceAddon-3.0.xml"/>
<Include file="libs\AceLocale-3.0\AceLocale-3.0.xml"/> <Include file="libs\AceLocale-3.0\AceLocale-3.0.xml"/>
<Include file="libs\AceHook-3.0\AceHook-3.0.xml"/>
<Include file="libs\LibDogTag-3.0\lib.xml"/> <Include file="libs\LibDogTag-3.0\lib.xml"/>
<Include file="libs\LibDogTag-Unit-3.0\lib.xml"/> <Include file="libs\LibDogTag-Unit-3.0\lib.xml"/>
<Script file="libs\LibRangeCheck-2.0\LibRangeCheck-2.0.lua"/> <Script file="libs\LibRangeCheck-3.0\LibRangeCheck-3.0.lua"/>
<Include file="libs\LibSharedMedia-3.0\lib.xml"/> <Include file="libs\LibSharedMedia-3.0\lib.xml"/>
<Include file="libs\AceGUI-3.0-SharedMediaWidgets\widget.xml"/> <Include file="libs\AceGUI-3.0-SharedMediaWidgets\widget.xml"/>
<Script file="LibDataBroker-1.1.lua"/> <Script file="LibDataBroker-1.1.lua"/>
<Script file="libs\LibDBIcon-1.0\LibDBIcon-1.0.lua"/> <Script file="libs\LibDBIcon-1.0\LibDBIcon-1.0.lua"/>
<Script file="libs\LibDualSpec-1.0\LibDualSpec-1.0.lua"/> <Script file="libs\LibDualSpec-1.0\LibDualSpec-1.0.lua"/>
@end-non-debug@-->
</Ui> </Ui>

View File

@ -1,6 +1,11 @@
local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false) local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false)
local ArcaneCharges = IceCore_CreateClass(IceClassPowerCounter) local ArcaneCharges = IceCore_CreateClass(IceClassPowerCounter)
local SPELL_POWER_ARCANE_CHARGES = SPELL_POWER_ARCANE_CHARGES
if Enum and Enum.PowerType then
SPELL_POWER_ARCANE_CHARGES = Enum.PowerType.ArcaneCharges
end
function ArcaneCharges.prototype:init() function ArcaneCharges.prototype:init()
ArcaneCharges.super.prototype.init(self, "ArcaneCharges") ArcaneCharges.super.prototype.init(self, "ArcaneCharges")
@ -56,6 +61,6 @@ end
-- Load us up -- Load us up
local _, unitClass = UnitClass("player") local _, unitClass = UnitClass("player")
if (unitClass == "MAGE" and IceHUD.WowVer >= 70000) then if (unitClass == "MAGE" and MageArcaneChargesFrame) then
IceHUD.ArcaneCharges = ArcaneCharges:new() IceHUD.ArcaneCharges = ArcaneCharges:new()
end end

View File

@ -3,8 +3,27 @@ local CastBar = IceCore_CreateClass(IceCastBar)
local IceHUD = _G.IceHUD local IceHUD = _G.IceHUD
local CastingBarFrame = CastingBarFrame
if not CastingBarFrame then
CastingBarFrame = PlayerCastingBarFrame
end
local IsSpellInRange = IsSpellInRange
if not IsSpellInRange and C_Spell then
IsSpellInRange = C_Spell.IsSpellInRange
end
local GetSpellCooldown = GetSpellCooldown
if not GetSpellCooldown and C_Spell then
GetSpellCooldown = function(spellID)
local spellCooldownInfo = C_Spell.GetSpellCooldown(spellID)
if spellCooldownInfo then
return spellCooldownInfo.startTime, spellCooldownInfo.duration, spellCooldownInfo.isEnabled, spellCooldownInfo.modRate
end
end
end
CastBar.prototype.spellCastSent = nil CastBar.prototype.spellCastSent = nil
CastBar.prototype.sentSpell = nil
-- Constructor -- -- Constructor --
function CastBar.prototype:init() function CastBar.prototype:init()
@ -35,6 +54,9 @@ function CastBar.prototype:GetDefaultSettings()
settings["rangeColor"] = true settings["rangeColor"] = true
settings["bAllowExpand"] = false settings["bAllowExpand"] = false
settings["respectLagTolerance"] = true settings["respectLagTolerance"] = true
settings["lockUpperTextAlpha"] = true
settings["lockLowerTextAlpha"] = true
settings["empowerStageTextDisplay"] = "TOPLINE"
return settings return settings
end end
@ -232,6 +254,7 @@ function CastBar.prototype:GetOptions()
end, end,
set = function(info, v) set = function(info, v)
self.moduleSettings.lockUpperTextAlpha = v self.moduleSettings.lockUpperTextAlpha = v
self.moduleSettings.lockLowerTextAlpha = v
self:Redraw() self:Redraw()
end, end,
order = 13 order = 13
@ -304,7 +327,26 @@ function CastBar.prototype:GetOptions()
disabled = function() disabled = function()
return not self.moduleSettings.enabled return not self.moduleSettings.enabled
end, end,
} },
empowerStageText = {
type = 'select',
name = L["Empower stage label display"],
desc = L["How to display the stage of an empowered spell"],
get = function()
return self.moduleSettings.empowerStageTextDisplay
end,
set = function(info, value)
self.moduleSettings.empowerStageTextDisplay = value
end,
values = { NONE = L["Don't show"], TOPLINE = L["After spell name"], BOTTOMLINE = L["Below spell name"] },
disabled = function()
return not self.moduleSettings.enabled
end,
hidden = function()
return not GetUnitEmpowerMinHoldTime
end,
},
} }
} }
@ -314,8 +356,10 @@ end
function CastBar.prototype:Enable(core) function CastBar.prototype:Enable(core)
CastBar.super.prototype.Enable(self, core) CastBar.super.prototype.Enable(self, core)
self:RegisterEvent("UNIT_ENTERED_VEHICLE", "EnteringVehicle") if UnitHasVehicleUI then
self:RegisterEvent("UNIT_EXITED_VEHICLE", "ExitingVehicle") self:RegisterEvent("UNIT_ENTERED_VEHICLE", "EnteringVehicle")
self:RegisterEvent("UNIT_EXITED_VEHICLE", "ExitingVehicle")
end
self:RegisterEvent("PLAYER_ENTERING_WORLD", "CheckVehicle") self:RegisterEvent("PLAYER_ENTERING_WORLD", "CheckVehicle")
self:RegisterEvent("CVAR_UPDATE", "CVarUpdate") self:RegisterEvent("CVAR_UPDATE", "CVarUpdate")
@ -349,16 +393,21 @@ end
function CastBar.prototype:CheckVehicle() function CastBar.prototype:CheckVehicle()
if UnitHasVehicleUI("player") then if UnitHasVehicleUI then
self:EnteringVehicle(nil, "player", true) if UnitHasVehicleUI("player") then
else self:EnteringVehicle(nil, "player", true)
self:ExitingVehicle(nil, "player") else
self:ExitingVehicle(nil, "player")
end
end end
end end
function CastBar.prototype:CVarUpdate(...) function CastBar.prototype:CVarUpdate(...)
self.useFixedLatency = self.moduleSettings.respectLagTolerance and GetCVar("reducedLagTolerance") == "1" self.useFixedLatency = self.moduleSettings.respectLagTolerance and GetCVar("reducedLagTolerance") == "1"
self.fixedLatency = tonumber(GetCVar("maxSpellStartRecoveryoffset")) / 1000 local recoveryOffset = GetCVar("maxSpellStartRecoveryoffset")
if recoveryOffset ~= nil then
self.fixedLatency = tonumber(recoveryOffset) / 1000
end
end end
function CastBar.prototype:Disable(core) function CastBar.prototype:Disable(core)
@ -391,7 +440,9 @@ end
function CastBar.prototype:CreateLagBar() function CastBar.prototype:CreateLagBar()
self.lagBar = self:BarFactory(self.lagBar, "LOW", "OVERLAY") if self.lagBar == nil then
self.lagBar = self:BarFactory(self.lagBar, "LOW", "OVERLAY", "Lag")
end
local r, g, b = self:GetColor("CastLag") local r, g, b = self:GetColor("CastLag")
if (self.settings.backgroundToggle) then if (self.settings.backgroundToggle) then
@ -404,14 +455,13 @@ end
-- OVERRIDE -- OVERRIDE
function CastBar.prototype:SpellCastSent(event, unit, spell, rank, target, lineId) function CastBar.prototype:SpellCastSent(event, unit, target, castGuid, spellId)
CastBar.super.prototype.SpellCastSent(self, event, unit, spell, rank, target, lineId) CastBar.super.prototype.SpellCastSent(self, event, unit, target, castGuid, spellId)
if (unit ~= self.unit) then return end if (unit ~= self.unit) then return end
if IceHUD.WowVer < 70000 then if IceHUD.WowVer < 70000 then
self.spellCastSent = GetTime() self.spellCastSent = GetTime()
end end
self.sentSpell = lineId
end end
-- OVERRIDE -- OVERRIDE
@ -423,32 +473,18 @@ function CastBar.prototype:SpellCastChanged(event, arg1)
end end
-- OVERRIDE -- OVERRIDE
function CastBar.prototype:SpellCastStart(event, unit, spell, rank, lineId, spellId) function CastBar.prototype:SpellCastStart(event, unit, castGuid, spellId)
CastBar.super.prototype.SpellCastStart(self, event, unit, spell, rank, lineId, spellId) CastBar.super.prototype.SpellCastStart(self, event, unit, castGuid, spellId)
if (unit ~= self.unit) then return end if (unit ~= self.unit or not spellId) then return end
if not self:IsVisible() or not self.actionDuration then if not self:IsVisible() or not self.actionDuration then
return return
end end
if self.sentSpell ~= lineId then self:UpdateLagBar()
self.spellCastSent = nil if IceHUD.GlobalCoolDown then
self.nextLagUpdate = GetTime() + (select(2, GetSpellCooldown(IceHUD.GlobalCoolDown:GetSpellId())) / 2)
end end
local scale
if self.unit == "vehicle" then
scale = 0
elseif self.useFixedLatency then
scale = IceHUD:Clamp(self.fixedLatency / self.actionDuration, 0, 1)
else
local now = GetTime()
local lag = now - (self.spellCastSent or now)
scale = IceHUD:Clamp(lag / self.actionDuration, 0, 1)
end
self:SetBarCoord(self.lagBar, scale, true, true)
self.spellCastSent = nil
end end
@ -461,20 +497,45 @@ function CastBar.prototype:SpellCastChannelStart(event, unit)
return return
end end
self:UpdateLagBar(self.moduleSettings.reverseChannel)
end
-- OVERRIDE
function CastBar.prototype:SpellCastSucceeded(event, unit, castGuid, spellId)
CastBar.super.prototype.SpellCastSucceeded(self, event, unit, castGuid, spellId)
if not self.actionDuration or unit ~= self.unit then
return
end
self:UpdateLagBar()
if IceHUD.GlobalCoolDown then
self.nextLagUpdate = GetTime() + (select(2, GetSpellCooldown(IceHUD.GlobalCoolDown:GetSpellId())) / 2)
end
end
function CastBar.prototype:UpdateLagBar(isChannel)
local now = GetTime()
if self.nextLagUpdate and now <= self.nextLagUpdate then
return
end
local scale local scale
if self.unit == "vehicle" then if self.unit == "vehicle" then
scale = 0 scale = 0
elseif self.useFixedLatency then elseif self.useFixedLatency then
scale = IceHUD:Clamp(self.fixedLatency / self.actionDuration, 0, 1) scale = IceHUD:Clamp(self.fixedLatency / self.actionDuration, 0, 1)
else else
local now = GetTime()
local lag = now - (self.spellCastSent or now) local lag = now - (self.spellCastSent or now)
scale = IceHUD:Clamp(lag / self.actionDuration, 0, 1) if lag >= (self.actionDuration / 2) then
scale = 0
else
scale = IceHUD:Clamp(lag / self.actionDuration, 0, 1)
end
end end
local top = not self.moduleSettings.reverseChannel self:SetBarCoord(self.lagBar, scale, not isChannel, true)
self:SetBarCoord(self.lagBar, scale, top, true)
self.spellCastSent = nil self.spellCastSent = nil
end end

View File

@ -18,9 +18,10 @@ IceClassPowerCounter.prototype.requiredSpec = nil
IceClassPowerCounter.prototype.shouldShowUnmodified = false IceClassPowerCounter.prototype.shouldShowUnmodified = false
IceClassPowerCounter.prototype.unmodifiedMaxPerRune = 10 IceClassPowerCounter.prototype.unmodifiedMaxPerRune = 10
IceClassPowerCounter.prototype.unit = "player" IceClassPowerCounter.prototype.unit = "player"
IceClassPowerCounter.prototype.round = ceil
IceClassPowerCounter.prototype.growModes = { width = 1, height = 2 } IceClassPowerCounter.prototype.growModes = { width = 1, height = 2 }
IceClassPowerCounter.prototype.currentGrowMode = nil IceClassPowerCounter.prototype.currentGrowMode = IceClassPowerCounter.prototype.growModes["height"]
IceClassPowerCounter.prototype.shouldRegisterDisplayPower = true
-- Constructor -- -- Constructor --
function IceClassPowerCounter.prototype:init(name) function IceClassPowerCounter.prototype:init(name)
@ -101,7 +102,7 @@ function IceClassPowerCounter.prototype:GetOptions()
opts["displayMode"] = { opts["displayMode"] = {
type = 'select', type = 'select',
name = L["Display mode"], name = L["Display mode"],
desc = L["Choose whether you'd like a graphical or numeric representation of the runes.\n\nNOTE: The color of 'Numeric' mode can be controlled by the HolyPowerNumeric color."], desc = L["Choose whether you'd like a graphical or numeric representation of the runes."],
get = function(info) get = function(info)
return IceHUD:GetSelectValue(info, self.moduleSettings.runeMode) return IceHUD:GetSelectValue(info, self.moduleSettings.runeMode)
end, end,
@ -391,7 +392,7 @@ function IceClassPowerCounter.prototype:GetDefaultSettings()
defaults["hideFriendly"] = false defaults["hideFriendly"] = false
defaults["pulseWhenFull"] = true defaults["pulseWhenFull"] = true
defaults["overrideAlpha"] = true defaults["overrideAlpha"] = true
defaults["numericVerticalOffset"] = 0 defaults["numericVerticalOffset"] = -25
defaults["alwaysShowNumeric"] = false defaults["alwaysShowNumeric"] = false
return defaults return defaults
@ -462,12 +463,21 @@ function IceClassPowerCounter.prototype:CheckValidSpec()
end end
end end
function IceClassPowerCounter.prototype:GetPowerEvent()
return IceHUD.UnitPowerEvent
end
function IceClassPowerCounter.prototype:DisplayCounter() function IceClassPowerCounter.prototype:DisplayCounter()
self:UnregisterEvent("PLAYER_LEVEL_UP") self:UnregisterEvent("PLAYER_LEVEL_UP")
self:RegisterEvent("UNIT_POWER", "UpdateRunePower") self:RegisterEvent(self:GetPowerEvent(), "UpdateRunePower")
self:RegisterEvent("UNIT_DISPLAYPOWER", "UpdateRunePower") if self.shouldRegisterDisplayPower then
self:RegisterEvent("PLAYER_ENTERING_WORLD", "UpdateRunePower") self:RegisterEvent("UNIT_DISPLAYPOWER", "UpdateRunePower")
end
self:RegisterEvent("PLAYER_ENTERING_WORLD", "EnteringWorld")
if IceHUD.EventExistsUnitMaxPower then
self:RegisterEvent("UNIT_MAXPOWER", "UpdateRunePower")
end
if (self.moduleSettings.hideBlizz) then if (self.moduleSettings.hideBlizz) then
self:HideBlizz() self:HideBlizz()
@ -484,16 +494,35 @@ function IceClassPowerCounter.prototype:Disable(core)
end end
end end
function IceClassPowerCounter.prototype:EnteringWorld()
self:TargetChanged()
self:UpdateRunePower()
end
function IceClassPowerCounter.prototype:UpdateRunePower(event, arg1, arg2) function IceClassPowerCounter.prototype:UpdateRunePower(event, arg1, arg2)
if event and (event == "UNIT_POWER" or event == "UNIT_POWER_FREQUENT") and arg1 ~= "player" and arg1 ~= "vehicle" then if event and (event == self:GetPowerEvent() or event == "UNIT_POWER_FREQUENT") and arg1 ~= "player" and arg1 ~= "vehicle" then
return return
end end
if IceHUD.WowVer >= 70000 then if IceHUD.WowVer >= 70000 then
local numMax = UnitPowerMax(self.unit, self.unitPower) local numMax = UnitPowerMax(self.unit, self.unitPower)
if numMax ~= self.numRunes then if numMax ~= self.numRunes then
local oldMax = self.numRunes
self.numRunes = numMax self.numRunes = numMax
self:CreateFrame() self:CreateFrame()
self:SetDisplayMode()
for i=self.numRunes+1, oldMax do
if self.frame.graphical[i] then
self.frame.graphical[i]:Hide()
end
end
for i=oldMax+1, self.numRunes do
if self:GetRuneMode() ~= "Numeric" then
self.frame.graphical[i]:Show()
end
self:HideRune(i)
end
end end
end end
@ -501,15 +530,24 @@ function IceClassPowerCounter.prototype:UpdateRunePower(event, arg1, arg2)
local percentReady = self.shouldShowUnmodified and (UnitPower("player", self.unitPower, true) / self.unmodifiedMaxPerRune) or numReady local percentReady = self.shouldShowUnmodified and (UnitPower("player", self.unitPower, true) / self.unmodifiedMaxPerRune) or numReady
if self:GetRuneMode() == "Numeric" or self.moduleSettings.alsoShowNumeric then if self:GetRuneMode() == "Numeric" or self.moduleSettings.alsoShowNumeric then
self.frame.numeric:SetText(tostring(percentReady)) local displayPercent = percentReady
if self.partialReadyPercent then
displayPercent = percentReady + self.partialReadyPercent
end
if self.numericFormat then
self.frame.numeric:SetText(format(self.numericFormat, displayPercent))
else
self.frame.numeric:SetText(tostring(displayPercent))
end
self.frame.numeric:SetTextColor(self:GetColor(self.numericColor)) self.frame.numeric:SetTextColor(self:GetColor(self.numericColor))
end end
if self:GetRuneMode() ~= "Numeric" then if self:GetRuneMode() ~= "Numeric" then
for i=1, self.numRunes do for i=1, self.numRunes do
if i <= ceil(percentReady) then if i <= self.round(percentReady) then
if self:GetRuneMode() == "Graphical" then if self:GetRuneMode() == "Graphical" then
self.frame.graphical[i].rune:SetVertexColor(1, 1, 1) self:SetRuneGraphicalTexture(i)
else else
self:SetCustomColor(i) self:SetCustomColor(i)
end end
@ -519,33 +557,14 @@ function IceClassPowerCounter.prototype:UpdateRunePower(event, arg1, arg2)
end end
if i > numReady or self.numRunes == 1 then if i > numReady or self.numRunes == 1 then
local left, right, top, bottom = 0, 1, 0, 1
if self:GetRuneMode() == "Graphical" then
left, right, top, bottom = unpack(self.runeCoords[i])
end
local currPercent = percentReady - numReady local currPercent = percentReady - numReady
if self.numRunes == 1 then if self.numRunes == 1 then
currPercent = numReady / UnitPowerMax("player", self.unitPower) currPercent = numReady / UnitPowerMax("player", self.unitPower)
end end
if self.currentGrowMode == self.growModes["height"] then self:SetRuneCoords(i, currPercent)
top = bottom - (currPercent * (bottom - top))
self.frame.graphical[i].rune:SetHeight(currPercent * self.runeHeight)
elseif self.currentGrowMode == self.growModes["width"] then
right = left + (currPercent * (right - left))
self.frame.graphical[i].rune:SetWidth(currPercent * self.runeWidth)
end
self.frame.graphical[i].rune:SetTexCoord(left, right, top, bottom)
elseif i > self.lastNumReady then elseif i > self.lastNumReady then
if self.runeCoords ~= nil and #self.runeCoords >= i then self:SetRuneCoords(i, 1)
local left, right, top, bottom = 0, 1, 0, 1
if self:GetRuneMode() == "Graphical" then
left, right, top, bottom = unpack(self.runeCoords[i])
end
self.frame.graphical[i].rune:SetTexCoord(left, right, top, bottom)
self.frame.graphical[i].rune:SetHeight(self.runeHeight)
end
if self.moduleSettings.flashWhenBecomingReady then if self.moduleSettings.flashWhenBecomingReady then
local fadeInfo={ local fadeInfo={
@ -558,11 +577,18 @@ function IceClassPowerCounter.prototype:UpdateRunePower(event, arg1, arg2)
end end
end end
else else
if self.moduleSettings.inactiveDisplayMode == "Darkened" then if self.partialReady then
self.frame.graphical[i].rune:SetVertexColor(0, 0, 0) if i == self.partialReady then
elseif self.moduleSettings.inactiveDisplayMode == "Hidden" then self:SetRuneCoords(i, self.partialReadyPercent)
self.frame.graphical[i]:Hide() if self:GetRuneMode() == "Graphical" then
self:SetRuneGraphicalTexture(i, true)
end
else
self:SetRuneCoords(i, 0)
end
end end
self:HideRune(i)
end end
end end
end end
@ -583,6 +609,43 @@ function IceClassPowerCounter.prototype:UpdateRunePower(event, arg1, arg2)
end end
end end
function IceClassPowerCounter.prototype:SetRuneCoords(rune, percent)
if self.runeCoords == nil or #self.runeCoords < rune then
return
end
local left, right, top, bottom = 0, 1, 0, 1
if self:GetRuneMode() == "Graphical" then
local coords = self.runeCoords[rune]
if coords then
left, right, top, bottom = unpack(coords)
end
end
if self.currentGrowMode == self.growModes["height"] then
top = bottom - (percent * (bottom - top))
self.frame.graphical[rune].rune:SetHeight(percent * self.runeHeight)
elseif self.currentGrowMode == self.growModes["width"] then
right = left + (percent * (right - left))
self.frame.graphical[rune].rune:SetWidth(percent * self.runeWidth)
end
self.frame.graphical[rune].rune:SetTexCoord(left, right, top, bottom)
end
function IceClassPowerCounter.prototype:HideRune(i)
if self:GetRuneMode() == "Numeric" then
self.frame.graphical[i].Hide()
return
end
if self.moduleSettings.inactiveDisplayMode == "Darkened" then
self.frame.graphical[i].rune:SetVertexColor(0, 0, 0)
elseif self.moduleSettings.inactiveDisplayMode == "Hidden" then
self.frame.graphical[i]:Hide()
end
end
function IceClassPowerCounter.prototype:StartRunesFullAnimation() function IceClassPowerCounter.prototype:StartRunesFullAnimation()
if not self.AnimUpdate then if not self.AnimUpdate then
self.AnimUpdate = function() self:UpdateRuneAnimation() end self.AnimUpdate = function() self:UpdateRuneAnimation() end
@ -653,10 +716,22 @@ function IceClassPowerCounter.prototype:GetShineAtlas(rune)
return nil return nil
end end
function IceClassPowerCounter.prototype:GetFrameAtlas(rune)
return nil
end
function IceClassPowerCounter.prototype:GetBackgroundAtlas(rune)
return nil
end
function IceClassPowerCounter.prototype:GetPartialRuneAtlas(rune)
return nil
end
function IceClassPowerCounter.prototype:CreateFrame() function IceClassPowerCounter.prototype:CreateFrame()
IceClassPowerCounter.super.prototype.CreateFrame(self) IceClassPowerCounter.super.prototype.CreateFrame(self)
self.frame:SetFrameStrata("LOW") self.frame:SetFrameStrata(IceHUD.IceCore:DetermineStrata("LOW"))
self.frame:SetHeight(self.runeHeight) self.frame:SetHeight(self.runeHeight)
self.frame:ClearAllPoints() self.frame:ClearAllPoints()
self.frame:SetPoint("TOP", self.parent, "BOTTOM", self.moduleSettings.hpos, self.moduleSettings.vpos) self.frame:SetPoint("TOP", self.parent, "BOTTOM", self.moduleSettings.hpos, self.moduleSettings.vpos)
@ -673,6 +748,7 @@ end
function IceClassPowerCounter.prototype:SetDisplayMode() function IceClassPowerCounter.prototype:SetDisplayMode()
if self:GetRuneMode() == "Numeric" or self.moduleSettings.alsoShowNumeric then if self:GetRuneMode() == "Numeric" or self.moduleSettings.alsoShowNumeric then
self.frame.numeric:Show() self.frame.numeric:Show()
self.frame.numeric:SetPoint("CENTER", self.frame.numericParent, "CENTER", 0, self.moduleSettings.runeMode == "Numeric" and 0 or self.moduleSettings.numericVerticalOffset)
for i=1, self.numRunes do for i=1, self.numRunes do
self.frame.graphical[i]:Hide() self.frame.graphical[i]:Hide()
end end
@ -684,6 +760,21 @@ function IceClassPowerCounter.prototype:SetDisplayMode()
for i=1, self.numRunes do for i=1, self.numRunes do
self:SetupRuneTexture(i) self:SetupRuneTexture(i)
self.frame.graphical[i]:Show() self.frame.graphical[i]:Show()
if self.frame.graphical[i].frame then
if self:GetRuneMode() == "Graphical" then
self.frame.graphical[i].frame:Show()
else
self.frame.graphical[i].frame:Hide()
end
end
if self.frame.graphical[i].bg then
if self:GetRuneMode() == "Graphical" then
self.frame.graphical[i].bg:Show()
else
self.frame.graphical[i].bg:Hide()
end
end
end end
end end
end end
@ -698,7 +789,6 @@ function IceClassPowerCounter.prototype:CreateRuneFrame()
self.frame.numeric:SetJustifyH("CENTER") self.frame.numeric:SetJustifyH("CENTER")
self.frame.numeric:SetPoint("CENTER", self.frame.numericParent, "CENTER", 0, self.moduleSettings.numericVerticalOffset)
self.frame.numeric:Hide() self.frame.numeric:Hide()
if (not self.frame.graphical) then if (not self.frame.graphical) then
@ -708,15 +798,18 @@ function IceClassPowerCounter.prototype:CreateRuneFrame()
for i=1, self.numRunes do for i=1, self.numRunes do
self:CreateRune(i) self:CreateRune(i)
end end
for i=self.numRunes+1, #self.frame.graphical do
self.frame.graphical[i]:Hide()
end
end end
function IceClassPowerCounter.prototype:CreateRune(i) function IceClassPowerCounter.prototype:CreateRune(i)
-- create runes -- create runes
if (not self.frame.graphical[i]) then if (not self.frame.graphical[i]) then
self.frame.graphical[i] = CreateFrame("Frame", nil, self.frame) self.frame.graphical[i] = CreateFrame("Frame", nil, self.frame)
self.frame.graphical[i]:SetFrameStrata("BACKGROUND") self.frame.graphical[i]:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
self.frame.graphical[i].rune = self.frame.graphical[i]:CreateTexture(nil, "ARTWORK") self.frame.graphical[i].rune = self.frame.graphical[i]:CreateTexture(nil, "BORDER")
self.frame.graphical[i].rune:SetVertexColor(0, 0, 0) self.frame.graphical[i].rune:SetVertexColor(0, 0, 0)
self:SetupRuneTexture(i) self:SetupRuneTexture(i)
@ -725,7 +818,7 @@ function IceClassPowerCounter.prototype:CreateRune(i)
self.frame.graphical[i].shine:SetAtlas(self:GetShineAtlas(i)) self.frame.graphical[i].shine:SetAtlas(self:GetShineAtlas(i))
else else
self.frame.graphical[i].shine:SetTexture("Interface\\ComboFrame\\ComboPoint") self.frame.graphical[i].shine:SetTexture("Interface\\ComboFrame\\ComboPoint")
self.frame.graphical[i].shine:SetTexCoord(0.5625, 1, 0, 1) self.frame.graphical[i].shine:SetTexCoord(0.5625, 1, 0, 1)
end end
self.frame.graphical[i].shine:SetBlendMode("ADD") self.frame.graphical[i].shine:SetBlendMode("ADD")
self.frame.graphical[i].shine:ClearAllPoints() self.frame.graphical[i].shine:ClearAllPoints()
@ -735,6 +828,22 @@ function IceClassPowerCounter.prototype:CreateRune(i)
self.frame.graphical[i].shine:SetHeight(self.runeHeight + 10) self.frame.graphical[i].shine:SetHeight(self.runeHeight + 10)
self.frame.graphical[i].shine:Hide() self.frame.graphical[i].shine:Hide()
local frameAtlas = self:GetFrameAtlas(i)
if frameAtlas then
self.frame.graphical[i].frame = self.frame.graphical[i]:CreateTexture(nil, "ARTWORK")
self.frame.graphical[i].frame:SetAtlas(frameAtlas)
self.frame.graphical[i].frame:ClearAllPoints()
self.frame.graphical[i].frame:SetPoint("CENTER", self.frame.graphical[i], "CENTER")
end
local bgAtlas = self:GetBackgroundAtlas(i)
if bgAtlas then
self.frame.graphical[i].bg = self.frame.graphical[i]:CreateTexture(nil, "BACKGROUND")
self.frame.graphical[i].bg:SetAtlas(bgAtlas)
self.frame.graphical[i].bg:ClearAllPoints()
self.frame.graphical[i].bg:SetAllPoints(self.frame.graphical[i])
end
self.frame.graphical[i]:Hide() self.frame.graphical[i]:Hide()
end end
@ -742,6 +851,10 @@ function IceClassPowerCounter.prototype:CreateRune(i)
self.frame.graphical[i]:SetHeight(self.runeHeight) self.frame.graphical[i]:SetHeight(self.runeHeight)
self.frame.graphical[i].rune:SetWidth(self.runeWidth) self.frame.graphical[i].rune:SetWidth(self.runeWidth)
self.frame.graphical[i].rune:SetHeight(self.runeHeight) self.frame.graphical[i].rune:SetHeight(self.runeHeight)
if self.frame.graphical[i].frame then
self.frame.graphical[i].frame:SetWidth(self.runeWidth + 10)
self.frame.graphical[i].frame:SetHeight(self.runeHeight + 10)
end
if self.currentGrowMode == self.growModes["width"] then if self.currentGrowMode == self.growModes["width"] then
self.frame.graphical[i].rune:SetPoint("LEFT", self.frame.graphical[i], "LEFT") self.frame.graphical[i].rune:SetPoint("LEFT", self.frame.graphical[i], "LEFT")
else else
@ -749,7 +862,13 @@ function IceClassPowerCounter.prototype:CreateRune(i)
end end
end end
function IceClassPowerCounter.prototype:SetupNewRune(rune)
end
function IceClassPowerCounter.prototype:SetupRuneTexture(rune) function IceClassPowerCounter.prototype:SetupRuneTexture(rune)
if rune > #self.runeCoords then
self:SetupNewRune(rune)
end
if not rune or rune < 1 or rune > #self.runeCoords then if not rune or rune < 1 or rune > #self.runeCoords then
return return
end end
@ -758,7 +877,10 @@ function IceClassPowerCounter.prototype:SetupRuneTexture(rune)
local a,b,c,d = 0, 1, 0, 1 local a,b,c,d = 0, 1, 0, 1
if self:GetRuneMode() == "Graphical" then if self:GetRuneMode() == "Graphical" then
width = self.runeWidth width = self.runeWidth
a,b,c,d = unpack(self.runeCoords[rune]) local coords = self.runeCoords[rune]
if coords then
a,b,c,d = unpack(coords)
end
end end
-- make sure any texture aside from the special one is square and has the proper coordinates -- make sure any texture aside from the special one is square and has the proper coordinates
@ -773,12 +895,7 @@ function IceClassPowerCounter.prototype:SetupRuneTexture(rune)
end end
if self:GetRuneMode() == "Graphical" then if self:GetRuneMode() == "Graphical" then
local tex = self:GetRuneTexture(rune) self:SetRuneGraphicalTexture(rune)
if tex then
self.frame.graphical[rune].rune:SetTexture(tex)
else
self.frame.graphical[rune].rune:SetAtlas(self:GetRuneAtlas(rune), self:UseAtlasSize(rune))
end
elseif self:GetRuneMode() == "Graphical Bar" then elseif self:GetRuneMode() == "Graphical Bar" then
self.frame.graphical[rune].rune:SetTexture(IceElement.TexturePath .. "Combo") self.frame.graphical[rune].rune:SetTexture(IceElement.TexturePath .. "Combo")
elseif self:GetRuneMode() == "Graphical Circle" then elseif self:GetRuneMode() == "Graphical Circle" then
@ -790,6 +907,19 @@ function IceClassPowerCounter.prototype:SetupRuneTexture(rune)
end end
end end
function IceClassPowerCounter.prototype:SetRuneGraphicalTexture(rune, partial)
self.frame.graphical[rune].rune:SetVertexColor(1, 1, 1)
local tex = self:GetRuneTexture(rune)
if tex then
self.frame.graphical[rune].rune:SetTexture(tex)
else
local partialAtlas = self:GetPartialRuneAtlas(rune)
local atlas = (partial and partialAtlas) and partialAtlas or self:GetRuneAtlas(rune)
self.frame.graphical[rune].rune:SetAtlas(atlas, self:UseAtlasSize(rune))
end
end
function IceClassPowerCounter.prototype:GetAlphaAdd() function IceClassPowerCounter.prototype:GetAlphaAdd()
return 0.15 return 0.15
end end

View File

@ -3,16 +3,44 @@ local ComboPoints = IceCore_CreateClass(IceElement)
local IceHUD = _G.IceHUD local IceHUD = _G.IceHUD
local GetSpellInfo = GetSpellInfo
if not GetSpellInfo and C_Spell and C_Spell.GetSpellInfo then
GetSpellInfo = function(spellID)
if not spellID then
return nil
end
local spellInfo = C_Spell.GetSpellInfo(spellID)
if spellInfo then
return spellInfo.name, nil, spellInfo.iconID, spellInfo.castTime, spellInfo.minRange, spellInfo.maxRange, spellInfo.spellID, spellInfo.originalIconID
end
end
end
local GetSpellName = GetSpellInfo
if C_Spell and C_Spell.GetSpellName then
GetSpellName = C_Spell.GetSpellName
end
local AnticipationSpellId = 114015 local AnticipationSpellId = 114015
local AnticipationExists = GetSpellName(AnticipationSpellId) and IceHUD.WowVer < 70000
ComboPoints.prototype.comboSize = 20 ComboPoints.prototype.comboSize = 20
local SPELL_POWER_COMBO_POINTS = SPELL_POWER_COMBO_POINTS
if Enum and Enum.PowerType then
SPELL_POWER_COMBO_POINTS = Enum.PowerType.ComboPoints
end
-- Constructor -- -- Constructor --
function ComboPoints.prototype:init() function ComboPoints.prototype:init()
ComboPoints.super.prototype.init(self, "ComboPoints") ComboPoints.super.prototype.init(self, "ComboPoints")
self:SetDefaultColor("ComboPoints", 1, 1, 0) self:SetDefaultColor("ComboPoints", 1, 1, 0)
self:SetDefaultColor("AnticipationPoints", 1, 0, 1) if AnticipationExists then
self:SetDefaultColor("AnticipationPoints", 1, 0, 1)
end
self:SetDefaultColor("ChargedComboPoint", 0.3137254901960784, 0.3725490196078432, 1)
self.scalingEnabled = true self.scalingEnabled = true
end end
@ -158,7 +186,7 @@ function ComboPoints.prototype:GetOptions()
order = 33.2 order = 33.2
} }
if IceHUD.WowVer < 70000 then if AnticipationExists then
opts["anticipation"] = { opts["anticipation"] = {
type = "toggle", type = "toggle",
name = L["Show Anticipation"], name = L["Show Anticipation"],
@ -210,6 +238,28 @@ function ComboPoints.prototype:GetOptions()
disabled = function() disabled = function()
return not self.moduleSettings.enabled return not self.moduleSettings.enabled
end, end,
order = 35
}
opts["bShowCharged"] = {
type = 'toggle',
width = 'double',
name = L["Show Charged points"],
desc = L["Whether or not to color a charged combo point a separate color. Set the ChargedComboPoint color to the color you would like it to be."],
get = function()
return self.moduleSettings.bShowCharged
end,
set = function(info, v)
self.moduleSettings.bShowCharged = v
self:UpdateChargedComboPoints()
end,
disabled = function()
return not self.moduleSettings.enabled
end,
hidden = function()
return not GetUnitChargedPowerPoints
end,
order = 36
} }
return opts return opts
@ -230,6 +280,7 @@ function ComboPoints.prototype:GetDefaultSettings()
defaults["comboGap"] = 0 defaults["comboGap"] = 0
defaults["showAnticipation"] = true defaults["showAnticipation"] = true
defaults["bShowWithNoTarget"] = true defaults["bShowWithNoTarget"] = true
defaults["bShowCharged"] = true
return defaults return defaults
end end
@ -248,16 +299,20 @@ function ComboPoints.prototype:Enable(core)
ComboPoints.super.prototype.Enable(self, core) ComboPoints.super.prototype.Enable(self, core)
self:RegisterEvent("PLAYER_TARGET_CHANGED", "UpdateComboPoints") self:RegisterEvent("PLAYER_TARGET_CHANGED", "UpdateComboPoints")
if IceHUD.WowVer >= 30000 then if not IceHUD.EventExistsPlayerComboPoints then
if IceHUD.WowVer < 70000 then if IceHUD.EventExistsUnitComboPoints then
self:RegisterEvent("UNIT_COMBO_POINTS", "UpdateComboPoints") self:RegisterEvent("UNIT_COMBO_POINTS", "UpdateComboPoints")
else else
self:RegisterEvent("UNIT_POWER", "UpdateComboPoints") self:RegisterEvent(IceHUD.UnitPowerEvent, "UpdateComboPoints")
self:RegisterEvent("UNIT_MAXPOWER", "UpdateMaxComboPoints") if IceHUD.EventExistsUnitMaxPower then
self:RegisterEvent("UNIT_MAXPOWER", "UpdateMaxComboPoints")
end
end end
self:RegisterEvent("UNIT_ENTERED_VEHICLE", "UpdateComboPoints") if UnitHasVehicleUI then
self:RegisterEvent("UNIT_EXITED_VEHICLE", "UpdateComboPoints") self:RegisterEvent("UNIT_ENTERED_VEHICLE", "UpdateComboPoints")
if IceHUD.WowVer < 70000 then self:RegisterEvent("UNIT_EXITED_VEHICLE", "UpdateComboPoints")
end
if AnticipationExists then
self:RegisterEvent("PLAYER_TALENT_UPDATE", "AddAnticipation") self:RegisterEvent("PLAYER_TALENT_UPDATE", "AddAnticipation")
self:AddAnticipation() self:AddAnticipation()
end end
@ -265,11 +320,16 @@ function ComboPoints.prototype:Enable(core)
self:RegisterEvent("PLAYER_COMBO_POINTS", "UpdateComboPoints") self:RegisterEvent("PLAYER_COMBO_POINTS", "UpdateComboPoints")
end end
if GetUnitChargedPowerPoints then
self:RegisterEvent("UNIT_POWER_POINT_CHARGE", "UpdateChargedComboPoints")
end
if self.moduleSettings.comboMode == "Graphical" then if self.moduleSettings.comboMode == "Graphical" then
self.moduleSettings.comboMode = "Graphical Bar" self.moduleSettings.comboMode = "Graphical Bar"
end end
self:CreateComboFrame(true) self:CreateComboFrame(true)
self:UpdateChargedComboPoints()
end end
function ComboPoints.prototype:UpdateMaxComboPoints(event, unit, powerType) function ComboPoints.prototype:UpdateMaxComboPoints(event, unit, powerType)
@ -282,13 +342,21 @@ function ComboPoints.prototype:UpdateMaxComboPoints(event, unit, powerType)
end end
end end
function ComboPoints.prototype:UpdateChargedComboPoints()
if GetUnitChargedPowerPoints then
self.chargedPowerPoints = GetUnitChargedPowerPoints("player")
self:CreateComboFrame()
self:UpdateComboPoints()
end
end
-- 'Protected' methods -------------------------------------------------------- -- 'Protected' methods --------------------------------------------------------
-- OVERRIDE -- OVERRIDE
function ComboPoints.prototype:CreateFrame() function ComboPoints.prototype:CreateFrame()
ComboPoints.super.prototype.CreateFrame(self) ComboPoints.super.prototype.CreateFrame(self)
self.frame:SetFrameStrata("BACKGROUND") self.frame:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
if self.moduleSettings.graphicalLayout == "Horizontal" then if self.moduleSettings.graphicalLayout == "Horizontal" then
self.frame:SetWidth((self.comboSize - 5)*self:GetMaxComboPoints()) self.frame:SetWidth((self.comboSize - 5)*self:GetMaxComboPoints())
self.frame:SetHeight(1) self.frame:SetHeight(1)
@ -347,7 +415,7 @@ function ComboPoints.prototype:CreateComboFrame(forceTextureUpdate)
end end
end end
self.frame.graphicalBG[i]:SetFrameStrata("BACKGROUND") self.frame.graphicalBG[i]:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
self.frame.graphicalBG[i]:SetWidth(self.comboSize) self.frame.graphicalBG[i]:SetWidth(self.comboSize)
self.frame.graphicalBG[i]:SetHeight(self.comboSize) self.frame.graphicalBG[i]:SetHeight(self.comboSize)
if self.moduleSettings.graphicalLayout == "Horizontal" then if self.moduleSettings.graphicalLayout == "Horizontal" then
@ -383,20 +451,25 @@ function ComboPoints.prototype:CreateComboFrame(forceTextureUpdate)
end end
end end
self.frame.graphical[i]:SetFrameStrata("LOW") self.frame.graphical[i]:SetFrameStrata(IceHUD.IceCore:DetermineStrata("LOW"))
self.frame.graphical[i]:SetAllPoints(self.frame.graphicalBG[i]) self.frame.graphical[i]:SetAllPoints(self.frame.graphicalBG[i])
local r, g, b = self:GetColor("ComboPoints") local r, g, b = self:GetColor("ComboPoints")
if (self.moduleSettings.gradient) then if (self.moduleSettings.gradient) then
g = g - ((1 / maxComboPoints)*i) g = g - ((1 / maxComboPoints)*i)
end end
self.frame.graphical[i].texture:SetVertexColor(r, g, b)
if self.moduleSettings.bShowCharged and self:IsChargedPoint(i) then
self.frame.graphical[i].texture:SetVertexColor(self:GetColor("ChargedComboPoint"))
else
self.frame.graphical[i].texture:SetVertexColor(r, g, b)
end
self.frame.graphical[i]:Hide() self.frame.graphical[i]:Hide()
end end
-- create Anticipation points -- create Anticipation points
if IceHUD.WowVer < 70000 then if AnticipationExists then
for i = 1, 5 do for i = 1, 5 do
if (not self.frame.graphicalAnt[i]) then if (not self.frame.graphicalAnt[i]) then
local frame = CreateFrame("Frame", nil, self.frame) local frame = CreateFrame("Frame", nil, self.frame)
@ -417,7 +490,7 @@ function ComboPoints.prototype:CreateComboFrame(forceTextureUpdate)
end end
end end
self.frame.graphicalAnt[i]:SetFrameStrata("LOW") self.frame.graphicalAnt[i]:SetFrameStrata(IceHUD.IceCore:DetermineStrata("LOW"))
self.frame.graphicalAnt[i]:SetFrameLevel(self.frame.graphical[i]:GetFrameLevel() + 1) self.frame.graphicalAnt[i]:SetFrameLevel(self.frame.graphical[i]:GetFrameLevel() + 1)
self.frame.graphicalAnt[i]:SetWidth(math.floor(self.comboSize / 2)) self.frame.graphicalAnt[i]:SetWidth(math.floor(self.comboSize / 2))
self.frame.graphicalAnt[i]:SetHeight(math.floor(self.comboSize / 2)) self.frame.graphicalAnt[i]:SetHeight(math.floor(self.comboSize / 2))
@ -435,31 +508,45 @@ function ComboPoints.prototype:CreateComboFrame(forceTextureUpdate)
end end
end end
function ComboPoints.prototype:IsChargedPoint(point)
if not self.chargedPowerPoints then
return false
end
for i=1, #self.chargedPowerPoints do
if self.chargedPowerPoints[i] == point then
return true
end
end
return false
end
function ComboPoints.prototype:UpdateComboPoints(...) function ComboPoints.prototype:UpdateComboPoints(...)
if select('#', ...) >= 3 and select(1, ...) == "UNIT_POWER" and select(3, ...) ~= "COMBO_POINTS" then if select('#', ...) >= 3 and select(1, ...) == IceHUD.UnitPowerEvent and select(3, ...) ~= "COMBO_POINTS" then
return return
end end
local points, anticipate, _ local points, anticipate, _
if IceHUD.IceCore:IsInConfigMode() then if IceHUD.IceCore:IsInConfigMode() then
points = self:GetMaxComboPoints() points = self:GetMaxComboPoints()
elseif IceHUD.WowVer >= 30000 then elseif UnitHasVehicleUI then
-- Parnic: apparently some fights have combo points while the player is in a vehicle? -- Parnic: apparently some fights have combo points while the player is in a vehicle?
local isInVehicle = UnitHasVehicleUI("player") local isInVehicle = UnitHasVehicleUI and UnitHasVehicleUI("player")
local checkUnit = isInVehicle and "vehicle" or "player" local checkUnit = isInVehicle and "vehicle" or "player"
if IceHUD.WowVer >= 60000 then if IceHUD.PerTargetComboPoints then
points = UnitPower(checkUnit, SPELL_POWER_COMBO_POINTS)
else
points = GetComboPoints(checkUnit, "target") points = GetComboPoints(checkUnit, "target")
else
points = UnitPower(checkUnit, SPELL_POWER_COMBO_POINTS)
end end
if IceHUD.WowVer < 70000 then if AnticipationExists then
_, _, _, anticipate = UnitAura("player", GetSpellInfo(AnticipationSpellId)) _, _, _, anticipate = IceHUD.UnitAura("player", GetSpellName(AnticipationSpellId))
else else
anticipate = 0 anticipate = 0
end end
else else
points = GetComboPoints("target") points = GetComboPoints("player", "target")
end end
points = points or 0 points = points or 0
@ -477,6 +564,9 @@ function ComboPoints.prototype:UpdateComboPoints(...)
self.frame.numeric:SetTextColor(r, g, b, 0.7) self.frame.numeric:SetTextColor(r, g, b, 0.7)
local pointsText = tostring(points) local pointsText = tostring(points)
if self.moduleSettings.bShowCharged and self:IsChargedPoint(points) then
pointsText = pointsText.."@"
end
if anticipate > 0 then if anticipate > 0 then
pointsText = pointsText.."+"..tostring(anticipate) pointsText = pointsText.."+"..tostring(anticipate)
end end
@ -520,7 +610,12 @@ do
function ComboPoints.prototype:CheckAnticipation(e, unit) -- UNIT_AURA handler function ComboPoints.prototype:CheckAnticipation(e, unit) -- UNIT_AURA handler
if UnitIsUnit(unit, "player") then if UnitIsUnit(unit, "player") then
local _, _, _, newAntStacks = UnitAura("player", GetSpellInfo(AnticipationSpellId)) local _, _, _, newAntStacks
if IceHUD.SpellFunctionsReturnRank then
_, _, _, newAntStacks = IceHUD.UnitAura("player", GetSpellName(AnticipationSpellId))
else
_, _, newAntStacks = IceHUD.UnitAura("player", GetSpellName(AnticipationSpellId))
end
if newAntStacks ~= antStacks then if newAntStacks ~= antStacks then
antStacks = newAntStacks antStacks = newAntStacks
self:UpdateComboPoints() self:UpdateComboPoints()
@ -539,4 +634,7 @@ end
-- Load us up -- Load us up
IceHUD.ComboPoints = ComboPoints:new() local _, class = UnitClass("player")
if (not IceHUD.WowClassic and not IceHUD.WowClassicBC) or class == "ROGUE" or class == "DRUID" then
IceHUD.ComboPoints = ComboPoints:new()
end

View File

@ -1,11 +1,17 @@
local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false) local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false)
local ComboPointsBar = IceCore_CreateClass(IceBarElement) local ComboPointsBar = IceCore_CreateClass(IceBarElement)
local SPELL_POWER_COMBO_POINTS = SPELL_POWER_COMBO_POINTS
if Enum and Enum.PowerType then
SPELL_POWER_COMBO_POINTS = Enum.PowerType.ComboPoints
end
function ComboPointsBar.prototype:init() function ComboPointsBar.prototype:init()
ComboPointsBar.super.prototype.init(self, "ComboPointsBar") ComboPointsBar.super.prototype.init(self, "ComboPointsBar")
self:SetDefaultColor("ComboPointsBarMin", 1, 1, 0) self:SetDefaultColor("ComboPointsBarMin", 1, 1, 0)
self:SetDefaultColor("ComboPointsBarMax", 0, 1, 0) self:SetDefaultColor("ComboPointsBarMax", 0, 1, 0)
self:SetDefaultColor("ChargedComboPointBar", 0.3137254901960784, 0.3725490196078432, 1)
self.bTreatEmptyAsFull = true self.bTreatEmptyAsFull = true
end end
@ -47,17 +53,37 @@ function ComboPointsBar.prototype:GetOptions()
end, end,
} }
opts["bShowCharged"] = {
type = 'toggle',
width = 'double',
name = L["Show Charged points"],
desc = L["Whether or not to color a charged combo point a separate color and append an @ sign to the number. Set the ChargedComboPointBar color to the color you would like it to be."],
get = function()
return self.moduleSettings.bShowCharged
end,
set = function(info, v)
self.moduleSettings.bShowCharged = v
self:UpdateComboPoints()
end,
disabled = function()
return not self.moduleSettings.enabled
end,
hidden = function()
return not GetUnitChargedPowerPoints
end,
}
return opts return opts
end end
function ComboPointsBar.prototype:GetDefaultSettings() function ComboPointsBar.prototype:GetDefaultSettings()
local defaults = ComboPointsBar.super.prototype.GetDefaultSettings(self) local defaults = ComboPointsBar.super.prototype.GetDefaultSettings(self)
defaults.textVisible['lower'] = false
defaults.offset = 8 defaults.offset = 8
defaults.enabled = false defaults.enabled = false
defaults.alwaysDisplay = false defaults.alwaysDisplay = false
defaults.desiredLerpTime = 0.05 defaults.desiredLerpTime = 0.05
defaults.bShowWithNoTarget = true defaults.bShowWithNoTarget = true
defaults.bShowCharged = true
return defaults return defaults
end end
@ -65,17 +91,23 @@ function ComboPointsBar.prototype:Enable(core)
ComboPointsBar.super.prototype.Enable(self, core) ComboPointsBar.super.prototype.Enable(self, core)
self:RegisterEvent("PLAYER_TARGET_CHANGED", "UpdateComboPoints") self:RegisterEvent("PLAYER_TARGET_CHANGED", "UpdateComboPoints")
if IceHUD.WowVer >= 30000 then if not IceHUD.EventExistsPlayerComboPoints then
if IceHUD.WowVer < 70000 then if IceHUD.EventExistsUnitComboPoints then
self:RegisterEvent("UNIT_COMBO_POINTS", "UpdateComboPoints") self:RegisterEvent("UNIT_COMBO_POINTS", "UpdateComboPoints")
else else
self:RegisterEvent("UNIT_POWER", "UpdateComboPoints") self:RegisterEvent(IceHUD.UnitPowerEvent, "UpdateComboPoints")
end
if UnitHasVehicleUI then
self:RegisterEvent("UNIT_ENTERED_VEHICLE", "UpdateComboPoints")
self:RegisterEvent("UNIT_EXITED_VEHICLE", "UpdateComboPoints")
end end
self:RegisterEvent("UNIT_ENTERED_VEHICLE", "UpdateComboPoints")
self:RegisterEvent("UNIT_EXITED_VEHICLE", "UpdateComboPoints")
else else
self:RegisterEvent("PLAYER_COMBO_POINTS", "UpdateComboPoints") self:RegisterEvent("PLAYER_COMBO_POINTS", "UpdateComboPoints")
end end
if GetUnitChargedPowerPoints then
self:RegisterEvent("UNIT_POWER_POINT_CHARGE", "UpdateComboPoints")
end
end end
function ComboPointsBar.prototype:CreateFrame() function ComboPointsBar.prototype:CreateFrame()
@ -87,45 +119,77 @@ end
local color = {} local color = {}
function ComboPointsBar.prototype:UpdateComboPoints(...) function ComboPointsBar.prototype:UpdateComboPoints(...)
if select('#', ...) >= 3 and select(1, ...) == "UNIT_POWER" and select(3, ...) ~= "COMBO_POINTS" then if select('#', ...) >= 3 and select(1, ...) == IceHUD.UnitPowerEvent and select(3, ...) ~= "COMBO_POINTS" then
return return
end end
local points local points
if IceHUD.IceCore:IsInConfigMode() then if IceHUD.IceCore:IsInConfigMode() then
points = UnitPowerMax("player", SPELL_POWER_COMBO_POINTS) points = UnitPowerMax("player", SPELL_POWER_COMBO_POINTS)
elseif IceHUD.WowVer >= 30000 then elseif UnitHasVehicleUI then
-- Parnic: apparently some fights have combo points while the player is in a vehicle? -- Parnic: apparently some fights have combo points while the player is in a vehicle?
local isInVehicle = UnitHasVehicleUI("player") local isInVehicle = UnitHasVehicleUI and UnitHasVehicleUI("player")
local checkUnit = isInVehicle and "vehicle" or "player" local checkUnit = isInVehicle and "vehicle" or "player"
if IceHUD.WowVer >= 60000 then if IceHUD.PerTargetComboPoints then
points = UnitPower(checkUnit, SPELL_POWER_COMBO_POINTS)
else
points = GetComboPoints(checkUnit, "target") points = GetComboPoints(checkUnit, "target")
else
points = UnitPower(checkUnit, SPELL_POWER_COMBO_POINTS)
end end
else else
points = GetComboPoints("target") points = GetComboPoints("player", "target")
end end
if (points == 0) then if (points == 0) then
points = nil points = nil
end end
local isCharged = self:IsChargedPoint(points) and self.moduleSettings.bShowCharged
if points == nil or points == 0 or (not UnitExists("target") and not self.moduleSettings.bShowWithNoTarget) then if points == nil or points == 0 or (not UnitExists("target") and not self.moduleSettings.bShowWithNoTarget) then
self:Show(self.moduleSettings.alwaysDisplay) self:Show(self.moduleSettings.alwaysDisplay)
self:UpdateBar(0, "undef") self:UpdateBar(0, "undef")
else else
self:Show(true) self:Show(true)
self:SetScaledColor(color, (points - 1) / 4.0, self.settings.colors["ComboPointsBarMax"], self.settings.colors["ComboPointsBarMin"]) if isCharged then
color.r, color.g, color.b = self:GetColor("ChargedComboPointBar")
else
self:SetScaledColor(color, (points - 1) / 4.0, self.settings.colors["ComboPointsBarMax"], self.settings.colors["ComboPointsBarMin"])
end
self:UpdateBar(points / UnitPowerMax("player", SPELL_POWER_COMBO_POINTS), "undef") self:UpdateBar(points / UnitPowerMax("player", SPELL_POWER_COMBO_POINTS), "undef")
self.barFrame.bar:SetVertexColor(color.r, color.g, color.b, self.alpha) self.barFrame.bar:SetVertexColor(color.r, color.g, color.b, self.alpha)
end end
self:SetBottomText1(points or "0") local pointsText = tostring(points or 0)
if isCharged then
pointsText = pointsText .. "@"
end
self:SetBottomText1(pointsText or "0")
end
function ComboPointsBar.prototype:IsChargedPoint(point)
if not GetUnitChargedPowerPoints or not point then
return false
end
local chargedPoints = GetUnitChargedPowerPoints("player")
if not chargedPoints then
return false
end
for i=1, #chargedPoints do
if chargedPoints[i] == point then
return true
end
end
return false
end end
function ComboPointsBar.prototype:Update() function ComboPointsBar.prototype:Update()
self:UpdateComboPoints() self:UpdateComboPoints()
end end
IceHUD.ComboPointsBar = ComboPointsBar:new() local _, class = UnitClass("player")
if (not IceHUD.WowClassic and not IceHUD.WowClassicBC) or class == "ROGUE" or class == "DRUID" then
IceHUD.ComboPointsBar = ComboPointsBar:new()
end

View File

@ -10,6 +10,26 @@ local buffOrDebuff = {"buff", "debuff"}
local validBuffTimers = {"none", "seconds", "minutes:seconds", "minutes"} local validBuffTimers = {"none", "seconds", "minutes:seconds", "minutes"}
local AuraIconWidth = 20 local AuraIconWidth = 20
local AuraIconHeight = 20 local AuraIconHeight = 20
local displayModes = {NORMAL = L["When present"], ALWAYS = L["Always"], WHEN_TARGETING = L["Always, when targeting"], MISSING = L["When missing"]}
local GetSpellName = GetSpellInfo
if C_Spell and C_Spell.GetSpellName then
GetSpellName = C_Spell.GetSpellName
end
local GetSpellInfo = GetSpellInfo
if not GetSpellInfo and C_Spell and C_Spell.GetSpellInfo then
GetSpellInfo = function(id)
if not id then
return nil
end
local info = C_Spell.GetSpellInfo(id)
if info then
return info.name, nil, info.iconID
end
end
end
IceCustomBar.prototype.auraDuration = -1 IceCustomBar.prototype.auraDuration = -1
IceCustomBar.prototype.auraEndTime = -1 IceCustomBar.prototype.auraEndTime = -1
@ -19,6 +39,7 @@ IceCustomBar.prototype.bIsAura = false
function IceCustomBar.prototype:init() function IceCustomBar.prototype:init()
IceCustomBar.super.prototype.init(self, "MyCustomBar", "player") IceCustomBar.super.prototype.init(self, "MyCustomBar", "player")
self.textColorOverride = true self.textColorOverride = true
self.CustomBarUpdateFunc = function() self:UpdateCustomBar(self.unit, true) end
end end
-- 'Public' methods ----------------------------------------------------------- -- 'Public' methods -----------------------------------------------------------
@ -27,6 +48,16 @@ end
function IceCustomBar.prototype:Enable(core) function IceCustomBar.prototype:Enable(core)
IceCustomBar.super.prototype.Enable(self, core) IceCustomBar.super.prototype.Enable(self, core)
-- fix up for new display mode setting
if self.moduleSettings.displayWhenTargeting then
self.moduleSettings.displayMode = displayModes.WHEN_TARGETING
self.moduleSettings.displayWhenTargeting = nil
end
if self.moduleSettings.displayWhenEmpty then
self.moduleSettings.displayMode = displayModes.ALWAYS
self.moduleSettings.displayWhenEmpty = nil
end
if IceHUD.IceCore:ShouldUseDogTags() then if IceHUD.IceCore:ShouldUseDogTags() then
DogTag = LibStub("LibDogTag-3.0", true) DogTag = LibStub("LibDogTag-3.0", true)
if DogTag then if DogTag then
@ -36,8 +67,12 @@ function IceCustomBar.prototype:Enable(core)
self:RegisterEvent("UNIT_AURA", "UpdateCustomBarEvent") self:RegisterEvent("UNIT_AURA", "UpdateCustomBarEvent")
self:RegisterEvent("UNIT_PET", "UpdateCustomBarEvent") self:RegisterEvent("UNIT_PET", "UpdateCustomBarEvent")
self:RegisterEvent("PLAYER_PET_CHANGED", "UpdateCustomBarEvent") if IceHUD.EventExistsPlayerPetChanged then
self:RegisterEvent("PLAYER_FOCUS_CHANGED", "UpdateCustomBarEvent") self:RegisterEvent("PLAYER_PET_CHANGED", "UpdateCustomBarEvent")
end
if FocusUnit then
self:RegisterEvent("PLAYER_FOCUS_CHANGED", "UpdateCustomBarEvent")
end
if self.unitClass == "SHAMAN" then if self.unitClass == "SHAMAN" then
self:RegisterEvent("PLAYER_TOTEM_UPDATE", "UpdateTotems") self:RegisterEvent("PLAYER_TOTEM_UPDATE", "UpdateTotems")
end end
@ -67,6 +102,7 @@ function IceCustomBar.prototype:Enable(core)
self:FixupTextColors() self:FixupTextColors()
self:SetCustomTextColor(self.frame.bottomUpperText, self.moduleSettings.upperTextColor) self:SetCustomTextColor(self.frame.bottomUpperText, self.moduleSettings.upperTextColor)
self:SetCustomTextColor(self.frame.bottomLowerText, self.moduleSettings.lowerTextColor) self:SetCustomTextColor(self.frame.bottomLowerText, self.moduleSettings.lowerTextColor)
self:UpdateAuraIcon()
end end
function IceCustomBar.prototype:Disable(core) function IceCustomBar.prototype:Disable(core)
@ -77,6 +113,10 @@ function IceCustomBar.prototype:Disable(core)
end end
function IceCustomBar.prototype:GetUnitToTrack() function IceCustomBar.prototype:GetUnitToTrack()
if not IceHUD.CanTrackOtherUnitBuffs then
return "player"
end
if self.moduleSettings.myUnit == "other" then if self.moduleSettings.myUnit == "other" then
if self.moduleSettings.customUnit ~= nil and self.moduleSettings.customUnit ~= "" then if self.moduleSettings.customUnit ~= nil and self.moduleSettings.customUnit ~= "" then
return self.moduleSettings.customUnit return self.moduleSettings.customUnit
@ -99,11 +139,7 @@ end
function IceCustomBar.prototype:ConditionalSubscribe() function IceCustomBar.prototype:ConditionalSubscribe()
if self:ShouldAlwaysSubscribe() then if self:ShouldAlwaysSubscribe() then
if not IceHUD.IceCore:IsUpdateSubscribed(self) then if not IceHUD.IceCore:IsUpdateSubscribed(self, self.CustomBarUpdateFunc) then
if not self.CustomBarUpdateFunc then
self.CustomBarUpdateFunc = function() self:UpdateCustomBar() end
end
self.handlesOwnUpdates = true self.handlesOwnUpdates = true
IceHUD.IceCore:RequestUpdates(self, self.CustomBarUpdateFunc) IceHUD.IceCore:RequestUpdates(self, self.CustomBarUpdateFunc)
end end
@ -114,7 +150,7 @@ function IceCustomBar.prototype:ConditionalSubscribe()
end end
function IceCustomBar.prototype:ShouldAlwaysSubscribe() function IceCustomBar.prototype:ShouldAlwaysSubscribe()
return self.unit == "focustarget" or self.unit == "pettarget" return self.unit == "focustarget" or self.unit == "pettarget" or self.unit == "targettarget"
end end
function IceCustomBar.prototype:TargetChanged() function IceCustomBar.prototype:TargetChanged()
@ -144,8 +180,7 @@ function IceCustomBar.prototype:GetDefaultSettings()
settings["buffOrDebuff"] = "buff" settings["buffOrDebuff"] = "buff"
settings["barColor"] = {r=1, g=0, b=0, a=1} settings["barColor"] = {r=1, g=0, b=0, a=1}
settings["trackOnlyMine"] = true settings["trackOnlyMine"] = true
settings["displayWhenEmpty"] = false settings["displayMode"] = displayModes.NORMAL
settings["displayWhenTargeting"] = false
settings["hideAnimationSettings"] = true settings["hideAnimationSettings"] = true
settings["buffTimerDisplay"] = "minutes" settings["buffTimerDisplay"] = "minutes"
settings["maxDuration"] = 0 settings["maxDuration"] = 0
@ -166,9 +201,7 @@ function IceCustomBar.prototype:CreateBar()
IceCustomBar.super.prototype.CreateBar(self) IceCustomBar.super.prototype.CreateBar(self)
if not self.barFrame.icon then if not self.barFrame.icon then
self.barFrame.icon = self.masterFrame:CreateTexture(nil, "LOW") self.barFrame.icon = self.masterFrame:CreateTexture(nil, "BACKGROUND")
-- default texture so that 'config mode' can work without activating the bar first
self.barFrame.icon:SetTexture("Interface\\Icons\\Spell_Frost_Frost")
-- this cuts off the border around the buff icon -- this cuts off the border around the buff icon
self.barFrame.icon:SetTexCoord(0.1, 0.9, 0.1, 0.9) self.barFrame.icon:SetTexCoord(0.1, 0.9, 0.1, 0.9)
self.barFrame.icon:SetDrawLayer("OVERLAY") self.barFrame.icon:SetDrawLayer("OVERLAY")
@ -191,6 +224,7 @@ end
function IceCustomBar.prototype:Redraw() function IceCustomBar.prototype:Redraw()
IceCustomBar.super.prototype.Redraw(self) IceCustomBar.super.prototype.Redraw(self)
self:UpdateAuraIcon()
self:UpdateCustomBar(self.unit) self:UpdateCustomBar(self.unit)
end end
@ -256,51 +290,53 @@ function IceCustomBar.prototype:GetOptions()
order = 30.3, order = 30.3,
} }
opts["unitToTrack"] = { if IceHUD.CanTrackOtherUnitBuffs then
type = 'select', opts["unitToTrack"] = {
values = validUnits, type = 'select',
name = L["Unit to track"], values = validUnits,
desc = L["Select which unit that this bar should be looking for buffs/debuffs on"], name = L["Unit to track"],
get = function(info) desc = L["Select which unit that this bar should be looking for buffs/debuffs on"],
return IceHUD:GetSelectValue(info, self.moduleSettings.myUnit) get = function(info)
end, return IceHUD:GetSelectValue(info, self.moduleSettings.myUnit)
set = function(info, v) end,
self.moduleSettings.myUnit = info.option.values[v] set = function(info, v)
self.unit = self:GetUnitToTrack() self.moduleSettings.myUnit = info.option.values[v]
self:RegisterFontStrings() self.unit = self:GetUnitToTrack()
self:ConditionalSubscribe() self:RegisterFontStrings()
self:Redraw() self:ConditionalSubscribe()
self:UpdateCustomBar(self.unit) self:Redraw()
IceHUD:NotifyOptionsChange() self:UpdateCustomBar(self.unit)
end, IceHUD:NotifyOptionsChange()
disabled = function() end,
return not self.moduleSettings.enabled disabled = function()
end, return not self.moduleSettings.enabled
order = 30.4, end,
} order = 30.4,
}
opts["customUnitToTrack"] = { opts["customUnitToTrack"] = {
type = 'input', type = 'input',
name = L["Custom unit"], name = L["Custom unit"],
desc = L["Any valid unit id such as: party1, raid14, targettarget, etc. Not guaranteed to work with all unit ids.\n\nRemember to press ENTER after filling out this box with the name you want or it will not save."], desc = L["Any valid unit id such as: party1, raid14, targettarget, etc. Not guaranteed to work with all unit ids.\n\nRemember to press ENTER after filling out this box with the name you want or it will not save."],
get = function() get = function()
return self.moduleSettings.customUnit return self.moduleSettings.customUnit
end, end,
set = function(info, v) set = function(info, v)
self.moduleSettings.customUnit = v self.moduleSettings.customUnit = v
self.unit = self:GetUnitToTrack() self.unit = self:GetUnitToTrack()
self:RegisterFontStrings() self:RegisterFontStrings()
self:ConditionalSubscribe() self:ConditionalSubscribe()
self:Redraw() self:Redraw()
self:UpdateCustomBar(self.unit) self:UpdateCustomBar(self.unit)
IceHUD:NotifyOptionsChange() IceHUD:NotifyOptionsChange()
end, end,
hidden = function() hidden = function()
return self.moduleSettings.myUnit ~= "other" return self.moduleSettings.myUnit ~= "other"
end, end,
usage = "<what custom unit to track when unitToTrack is set to 'other'>", usage = "<what custom unit to track when unitToTrack is set to 'other'>",
order = 30.45, order = 30.45,
} }
end
opts["buffOrDebuff"] = { opts["buffOrDebuff"] = {
type = 'select', type = 'select',
@ -324,16 +360,18 @@ function IceCustomBar.prototype:GetOptions()
opts["buffToTrack"] = { opts["buffToTrack"] = {
type = 'input', type = 'input',
name = L["Aura to track"], name = L["Aura to track"],
desc = L["Which buff/debuff this bar will be tracking.\n\nRemember to press ENTER after filling out this box with the name you want or it will not save."], desc = function()
if IceHUD.GetPlayerAuraBySpellID then
return L["Which buff/debuff this bar will be tracking. Can use the name or spell id. \n\nRemember to press ENTER after filling out this box with the name you want or it will not save."]
else
return L["Which buff/debuff this bar will be tracking.\n\nRemember to press ENTER after filling out this box with the name you want or it will not save."]
end
end,
get = function() get = function()
return self.moduleSettings.buffToTrack return self.moduleSettings.buffToTrack
end, end,
set = function(info, v) set = function(info, v)
local orig = v local orig = v
--Parnic: we now allow spell IDs to be used directly
--if tonumber(v) ~= nil then
-- v = GetSpellInfo(tonumber(v))
--end
if v == nil then if v == nil then
v = orig v = orig
end end
@ -424,38 +462,39 @@ function IceCustomBar.prototype:GetOptions()
order = 30.8, order = 30.8,
} }
opts["displayWhenEmpty"] = { opts["displayMode"] = {
type = 'toggle', type = 'select',
name = L["Display when empty"], values = displayModes,
desc = L["Whether or not to display this bar even if the buff/debuff specified is not present."], name = L["Display mode"],
get = function() desc = L["When to show the bar"],
return self.moduleSettings.displayWhenEmpty get = function(info)
return IceHUD:GetSelectValue(info, self.moduleSettings.displayMode)
end, end,
set = function(info, v) set = function(info, v)
self.moduleSettings.displayWhenEmpty = v self.moduleSettings.displayMode = info.option.values[v]
self:UpdateCustomBar() self:UpdateCustomBar()
end, end,
disabled = function() disabled = function()
return not self.moduleSettings.enabled return not self.moduleSettings.enabled
end, end,
order = 30.9 order = 30.9,
} }
opts["displayWhenTargeting"] = { opts["displayWhenUnitExists"] = {
type = 'toggle', type = 'toggle',
name = L["Display when targeting"], name = L["Only if unit exists"],
desc = L["Whether to display this bar when you target a unit, even if the buff/debuff specified is not present."], desc = L["If checked, the bar will only be displayed (according to the 'Display mode' rules) when the Unit to Track exists (e.g. if set to Target and you're targeting something)."],
get = function() get = function(info)
return self.moduleSettings.displayWhenTargeting return self.moduleSettings.displayWhenUnitExists
end, end,
set = function(info, v) set = function(info, v)
self.moduleSettings.displayWhenTargeting = v self.moduleSettings.displayWhenUnitExists = v
self:UpdateCustomBar() self:UpdateCustomBar()
end, end,
disabled = function() disabled = function()
return not self.moduleSettings.enabled return not self.moduleSettings.enabled
end, end,
order = 30.91 order = 30.91,
} }
opts["buffTimerDisplay"] = { opts["buffTimerDisplay"] = {
@ -633,7 +672,7 @@ end
-- 'Protected' methods -------------------------------------------------------- -- 'Protected' methods --------------------------------------------------------
function IceCustomBar.prototype:GetAuraDuration(unitName, buffName) function IceCustomBar.prototype:GetAuraDuration(unitName, buffName)
if not unitName or not buffName then if not unitName or not buffName or buffName == "" then
return nil return nil
end end
@ -664,7 +703,12 @@ function IceCustomBar.prototype:GetAuraDuration(unitName, buffName)
local remaining local remaining
local isBuff = self.moduleSettings.buffOrDebuff == "buff" and true or false local isBuff = self.moduleSettings.buffOrDebuff == "buff" and true or false
local buffFilter = (isBuff and "HELPFUL" or "HARMFUL") .. (self.moduleSettings.trackOnlyMine and "|PLAYER" or "") local buffFilter = (isBuff and "HELPFUL" or "HARMFUL") .. (self.moduleSettings.trackOnlyMine and "|PLAYER" or "")
local buff, rank, texture, count, type, duration, endTime, unitCaster, _, _, spellId = UnitAura(unitName, i, buffFilter) local buff, rank, texture, count, type, duration, endTime, unitCaster, _, _, spellId
if IceHUD.SpellFunctionsReturnRank then
buff, rank, texture, count, type, duration, endTime, unitCaster, _, _, spellId = IceHUD.UnitAura(unitName, i, buffFilter)
else
buff, texture, count, type, duration, endTime, unitCaster, _, _, spellId = IceHUD.UnitAura(unitName, i, buffFilter)
end
local isMine = unitCaster == "player" local isMine = unitCaster == "player"
local mySpellId = tonumber(self.moduleSettings.buffToTrack) local mySpellId = tonumber(self.moduleSettings.buffToTrack)
local checkId = mySpellId ~= nil local checkId = mySpellId ~= nil
@ -690,7 +734,11 @@ function IceCustomBar.prototype:GetAuraDuration(unitName, buffName)
i = i + 1; i = i + 1;
buff, rank, texture, count, type, duration, endTime, unitCaster, _, _, spellId = UnitAura(unitName, i, buffFilter) if IceHUD.SpellFunctionsReturnRank then
buff, rank, texture, count, type, duration, endTime, unitCaster, _, _, spellId = IceHUD.UnitAura(unitName, i, buffFilter)
else
buff, texture, count, type, duration, endTime, unitCaster, _, _, spellId = IceHUD.UnitAura(unitName, i, buffFilter)
end
isMine = unitCaster == "player" isMine = unitCaster == "player"
end end
@ -738,13 +786,13 @@ function IceCustomBar.prototype:UpdateCustomBar(unit, fromUpdate)
local auraIcon = nil local auraIcon = nil
local endTime = 0 local endTime = 0
if not fromUpdate then --if not fromUpdate then
if tonumber(self.moduleSettings.buffToTrack) == nil then if tonumber(self.moduleSettings.buffToTrack) == nil then
self.auraDuration, remaining, self.auraBuffCount, auraIcon, endTime = self.auraDuration, remaining, self.auraBuffCount, auraIcon, endTime =
self:GetAuraDuration(self.unit, self.moduleSettings.buffToTrack) self:GetAuraDuration(self.unit, self.moduleSettings.buffToTrack)
else else
self.auraDuration, remaining, self.auraBuffCount, auraIcon, endTime = self.auraDuration, remaining, self.auraBuffCount, auraIcon, endTime =
self:GetAuraDuration(self.unit, GetSpellInfo(self.moduleSettings.buffToTrack)) self:GetAuraDuration(self.unit, GetSpellName(self.moduleSettings.buffToTrack))
end end
if endTime == 0 then if endTime == 0 then
@ -765,22 +813,22 @@ function IceCustomBar.prototype:UpdateCustomBar(unit, fromUpdate)
end end
if IceHUD.IceCore:IsInConfigMode() or self.moduleSettings.displayAuraIcon then if IceHUD.IceCore:IsInConfigMode() or self.moduleSettings.displayAuraIcon then
if IceHUD.IceCore:IsInConfigMode() and not self.barFrame.icon:GetTexture() then
self.barFrame.icon:SetTexture("Interface\\Icons\\Spell_Frost_Frost")
end
self.barFrame.icon:Show() self.barFrame.icon:Show()
else else
self.barFrame.icon:Hide() self.barFrame.icon:Hide()
end end
end --end
self.auraBuffCount = self.auraBuffCount or 0 self.auraBuffCount = self.auraBuffCount or 0
if self.auraEndTime ~= nil and (self.auraEndTime == 0 or self.auraEndTime >= now) and (not self.moduleSettings.minCount or self.auraBuffCount >= self.moduleSettings.minCount) then if self.auraEndTime ~= nil and (self.auraEndTime == 0 or self.auraEndTime >= now) and (not self.moduleSettings.minCount or self.auraBuffCount >= self.moduleSettings.minCount) then
if not self:ShouldAlwaysSubscribe() and not fromUpdate and not IceHUD.IceCore:IsUpdateSubscribed(self) then if not self:ShouldAlwaysSubscribe() and not fromUpdate and not IceHUD.IceCore:IsUpdateSubscribed(self, self.CustomBarUpdateFunc) then
if not self.UpdateCustomBarFunc then
self.UpdateCustomBarFunc = function() self:UpdateCustomBar(self.unit, true) end
end
self.handlesOwnUpdates = true self.handlesOwnUpdates = true
IceHUD.IceCore:RequestUpdates(self, self.UpdateCustomBarFunc) IceHUD.IceCore:RequestUpdates(self, self.CustomBarUpdateFunc)
end end
self:Show(true) self:Show(true)
@ -795,7 +843,11 @@ function IceCustomBar.prototype:UpdateCustomBar(unit, fromUpdate)
self:UpdateBar(self.auraDuration ~= 0 and remaining / self.auraDuration or 0, "undef") self:UpdateBar(self.auraDuration ~= 0 and remaining / self.auraDuration or 0, "undef")
else else
self:UpdateBar(0, "undef") local updateVal = 0
if self.moduleSettings.displayMode == displayModes.MISSING then
updateVal = 1
end
self:UpdateBar(updateVal, "undef")
self:Show(false) self:Show(false)
if not self:ShouldAlwaysSubscribe() then if not self:ShouldAlwaysSubscribe() then
self.handlesOwnUpdates = false self.handlesOwnUpdates = false
@ -850,9 +902,21 @@ function IceCustomBar.prototype:Show(bShouldShow, bForceHide)
return return
end end
if self.moduleSettings.displayWhenTargeting and self.target then if self.moduleSettings.displayWhenUnitExists and not UnitExists(self.unit) then
IceCustomBar.super.prototype.Show(self, true) IceCustomBar.super.prototype.Show(self, false)
elseif self.moduleSettings.displayWhenEmpty then return
end
if self.moduleSettings.displayMode == displayModes.MISSING then
local show = not bShouldShow
if show and not self:IsEnabled() then
show = false
end
IceCustomBar.super.prototype.Show(self, show)
elseif self.moduleSettings.displayMode == displayModes.WHEN_TARGETING and self.target then
IceCustomBar.super.prototype.Show(self, self:IsEnabled())
elseif self.moduleSettings.displayMode == displayModes.ALWAYS then
if not self.bIsVisible then if not self.bIsVisible then
IceCustomBar.super.prototype.Show(self, true) IceCustomBar.super.prototype.Show(self, true)
end end
@ -860,3 +924,13 @@ function IceCustomBar.prototype:Show(bShouldShow, bForceHide)
IceCustomBar.super.prototype.Show(self, bShouldShow) IceCustomBar.super.prototype.Show(self, bShouldShow)
end end
end end
function IceCustomBar.prototype:UpdateAuraIcon()
if not self.barFrame or not self.barFrame.icon then
return
end
local _, _, auraIcon = GetSpellInfo(self.moduleSettings.buffToTrack)
self.barFrame.icon:SetTexture(auraIcon)
end

View File

@ -17,15 +17,59 @@ local COOLDOWN_TYPE_ITEM = 2
local localizedInventorySlotNames = {} local localizedInventorySlotNames = {}
local IsSpellInRange = IsSpellInRange
if not IsSpellInRange and C_Spell then
IsSpellInRange = C_Spell.IsSpellInRange
end
local GetSpellName = GetSpellInfo
if C_Spell and C_Spell.GetSpellName then
GetSpellName = C_Spell.GetSpellName
end
local GetSpellInfo = GetSpellInfo
if not GetSpellInfo and C_Spell and C_Spell.GetSpellInfo then
GetSpellInfo = function(id)
if not id then
return nil
end
local info = C_Spell.GetSpellInfo(id)
if info then
return info.name, nil, info.iconID, info.spellID
end
end
end
local GetSpellCooldown = GetSpellCooldown
if not GetSpellCooldown and C_Spell then
GetSpellCooldown = function(spellID)
local spellCooldownInfo = C_Spell.GetSpellCooldown(spellID)
if spellCooldownInfo then
return spellCooldownInfo.startTime, spellCooldownInfo.duration, spellCooldownInfo.isEnabled, spellCooldownInfo.modRate
end
end
end
local GetItemInfo = GetItemInfo
if not GetItemInfo and C_Item then
GetItemInfo = C_Item.GetItemInfo
end
local IsUsableSpell = IsUsableSpell
if not IsUsableSpell and C_Spell then
IsUsableSpell = C_Spell.IsSpellUsable
end
local SpellHasRange = SpellHasRange
if not SpellHasRange and C_Spell then
SpellHasRange = C_Spell.SpellHasRange
end
IceCustomCDBar.prototype.cooldownDuration = 0 IceCustomCDBar.prototype.cooldownDuration = 0
IceCustomCDBar.prototype.cooldownEndTime = 0 IceCustomCDBar.prototype.cooldownEndTime = 0
IceCustomCDBar.prototype.coolingDown = false IceCustomCDBar.prototype.coolingDown = false
-- super temp...remove this when blizzard fixes these spells to work by name with GetSpellCooldown()
local brokenSpellsNameToId = {}
table.insert(brokenSpellsNameToId, {"Holy Word: Serenity",88684})
table.insert(brokenSpellsNameToId, {"Holy Word: Sanctuary",88685})
-- Constructor -- -- Constructor --
function IceCustomCDBar.prototype:init() function IceCustomCDBar.prototype:init()
IceCustomCDBar.super.prototype.init(self, "MyCustomCDBar") IceCustomCDBar.super.prototype.init(self, "MyCustomCDBar")
@ -136,9 +180,7 @@ function IceCustomCDBar.prototype:CreateBar()
IceCustomCDBar.super.prototype.CreateBar(self) IceCustomCDBar.super.prototype.CreateBar(self)
if not self.barFrame.icon then if not self.barFrame.icon then
self.barFrame.icon = self.masterFrame:CreateTexture(nil, "LOW") self.barFrame.icon = self.masterFrame:CreateTexture(nil, "BACKGROUND")
-- default texture so that 'config mode' can work without activating the bar first
self.barFrame.icon:SetTexture("Interface\\Icons\\Spell_Frost_Frost")
-- this cuts off the border around the buff icon -- this cuts off the border around the buff icon
self.barFrame.icon:SetTexCoord(0.1, 0.9, 0.1, 0.9) self.barFrame.icon:SetTexCoord(0.1, 0.9, 0.1, 0.9)
self.barFrame.icon:SetDrawLayer("OVERLAY") self.barFrame.icon:SetDrawLayer("OVERLAY")
@ -168,7 +210,7 @@ function IceCustomCDBar.prototype:GetDisplayText(fromValue)
if not self.moduleSettings.cooldownType or self.moduleSettings.cooldownType == COOLDOWN_TYPE_SPELL then if not self.moduleSettings.cooldownType or self.moduleSettings.cooldownType == COOLDOWN_TYPE_SPELL then
if tonumber(fromValue) ~= nil then if tonumber(fromValue) ~= nil then
local spellName = GetSpellInfo(tonumber(fromValue)) local spellName = GetSpellName(tonumber(fromValue))
if spellName then if spellName then
v = spellName v = spellName
end end
@ -285,7 +327,7 @@ function IceCustomCDBar.prototype:GetOptions()
set = function(info, v) set = function(info, v)
local orig = v local orig = v
if tonumber(v) ~= nil then if tonumber(v) ~= nil then
v = GetSpellInfo(tonumber(v)) v = GetSpellName(tonumber(v))
end end
if v == nil then if v == nil then
v = orig v = orig
@ -599,17 +641,27 @@ end
-- 'Protected' methods -------------------------------------------------------- -- 'Protected' methods --------------------------------------------------------
function IceCustomCDBar.prototype:GetCooldownDurationOverride(spellID)
if spellID and FindSpellOverrideByID then
local override = FindSpellOverrideByID(spellID)
if override and override ~= spellID then
return self:GetCooldownDuration(override)
end
end
end
function IceCustomCDBar.prototype:GetCooldownDuration(buffName) function IceCustomCDBar.prototype:GetCooldownDuration(buffName)
buffName = self:GetSpellNameOrId(buffName) local spellID
buffName, spellID = self:GetSpellNameOrId(buffName)
local now = GetTime() local now = GetTime()
local localRemaining = nil local localRemaining = nil
local localStart, localDuration, hasCooldown = GetSpellCooldown(buffName) local localStart, localDuration, hasCooldown = GetSpellCooldown(buffName)
if (hasCooldown == 1) then if hasCooldown then
-- the item has a potential cooldown -- the item has a potential cooldown
if (localDuration <= 1.5) then if localDuration <= 1.5 then
return nil, nil return self:GetCooldownDurationOverride(spellID)
end end
localRemaining = localDuration + (localStart - now) localRemaining = localDuration + (localStart - now)
@ -620,7 +672,7 @@ function IceCustomCDBar.prototype:GetCooldownDuration(buffName)
return localDuration, localRemaining return localDuration, localRemaining
else else
return nil, nil return self:GetCooldownDurationOverride(spellID)
end end
end end
@ -680,6 +732,9 @@ function IceCustomCDBar.prototype:UpdateIcon()
end end
if IceHUD.IceCore:IsInConfigMode() or self.moduleSettings.displayAuraIcon then if IceHUD.IceCore:IsInConfigMode() or self.moduleSettings.displayAuraIcon then
if not self.barFrame.icon:GetTexture() and IceHUD.IceCore:IsInConfigMode() then
self.barFrame.icon:SetTexture("Interface\\Icons\\Spell_Frost_Frost")
end
self.barFrame.icon:Show() self.barFrame.icon:Show()
else else
self.barFrame.icon:Hide() self.barFrame.icon:Hide()
@ -699,7 +754,10 @@ function IceCustomCDBar.prototype:UpdateItemUnitInventoryChanged(event, unit)
end end
end end
function IceCustomCDBar.prototype:UpdateCustomBarEvent() function IceCustomCDBar.prototype:UpdateCustomBarEvent(event, unit)
if unit and unit ~= self.unit then
return
end
if not self.moduleSettings.cooldownType or self.moduleSettings.cooldownType == COOLDOWN_TYPE_SPELL then if not self.moduleSettings.cooldownType or self.moduleSettings.cooldownType == COOLDOWN_TYPE_SPELL then
self:UpdateCustomBar() self:UpdateCustomBar()
end end
@ -727,6 +785,8 @@ function IceCustomCDBar.prototype:UpdateCustomBar(fromUpdate)
else else
self.cooldownEndTime = remaining + now self.cooldownEndTime = remaining + now
end end
self:UpdateIcon()
end end
if self.cooldownEndTime and self.cooldownEndTime >= now then if self.cooldownEndTime and self.cooldownEndTime >= now then
@ -801,7 +861,9 @@ function IceCustomCDBar.prototype:IsReady()
local checkSpell = self:GetSpellNameOrId(self.moduleSettings.cooldownToTrack) local checkSpell = self:GetSpellNameOrId(self.moduleSettings.cooldownToTrack)
if (IsUsableSpell(checkSpell)) then if (IsUsableSpell(checkSpell)) then
if (not self.moduleSettings.bIgnoreRange and SpellHasRange(checkSpell)) or (self.moduleSettings.bOnlyShowWithTarget) then if self.moduleSettings.bIgnoreRange and self.moduleSettings.bOnlyShowWithTarget then
is_ready = UnitExists("target") and 1 or nil
elseif (not self.moduleSettings.bIgnoreRange and SpellHasRange(checkSpell)) or (self.moduleSettings.bOnlyShowWithTarget) then
if (UnitExists("target") and (not SpellHasRange(checkSpell) or IsSpellInRange(checkSpell, "target") == 1)) if (UnitExists("target") and (not SpellHasRange(checkSpell) or IsSpellInRange(checkSpell, "target") == 1))
or (not UnitExists("target") and not self.moduleSettings.bOnlyShowWithTarget and IsSpellInRange(checkSpell, "player")) then or (not UnitExists("target") and not self.moduleSettings.bOnlyShowWithTarget and IsSpellInRange(checkSpell, "player")) then
is_ready = 1 is_ready = 1
@ -821,15 +883,8 @@ function IceCustomCDBar.prototype:IsReady()
end end
function IceCustomCDBar.prototype:GetSpellNameOrId(spellName) function IceCustomCDBar.prototype:GetSpellNameOrId(spellName)
-- super temp hax. certain spells (the new 'morphing' spells) do not work by name with GetSpellCooldown(), only id. local id = select(4, GetSpellInfo(spellName))
for i=1,#brokenSpellsNameToId do return spellName, id
if spellName == brokenSpellsNameToId[i][1] then
spellName = brokenSpellsNameToId[i][2]
break
end
end
return spellName
end end
function IceCustomCDBar.prototype:Show(bShouldShow, bForceHide) function IceCustomCDBar.prototype:Show(bShouldShow, bForceHide)

View File

@ -122,7 +122,7 @@ function IceCustomCount.prototype:GetOptions()
self.moduleSettings.vpos = v self.moduleSettings.vpos = v
self:Redraw() self:Redraw()
end, end,
min = -400, min = -700,
max = 700, max = 700,
step = 1, step = 1,
disabled = function() disabled = function()
@ -245,6 +245,23 @@ function IceCustomCount.prototype:GetOptions()
order = 34 order = 34
} }
opts["showWhenZero"] = {
type = 'toggle',
name = L["Show when zero"],
desc = L["Whether or not to show the counter when the value is zero. This will cause a 0 to be displayed at all times for Numeric mode and faded markers for graphical mode."],
get = function()
return self.moduleSettings.showWhenZero
end,
set = function(info, v)
self.moduleSettings.showWhenZero = v
self:Redraw()
end,
disabled = function()
return not self.moduleSettings.enabled
end,
order = 35,
}
return opts return opts
end end
@ -296,6 +313,11 @@ function IceCustomCount.prototype:Enable(core)
self:UpdateCustomCount() self:UpdateCustomCount()
end end
function IceCustomCount.prototype:TargetChanged()
IceCustomCount.super.prototype.TargetChanged(self)
self:UpdateCustomCount()
end
-- 'Protected' methods -------------------------------------------------------- -- 'Protected' methods --------------------------------------------------------
@ -304,7 +326,7 @@ end
function IceCustomCount.prototype:CreateFrame() function IceCustomCount.prototype:CreateFrame()
IceCustomCount.super.prototype.CreateFrame(self) IceCustomCount.super.prototype.CreateFrame(self)
self.frame:SetFrameStrata("BACKGROUND") self.frame:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
if self.moduleSettings.graphicalLayout == "Horizontal" then if self.moduleSettings.graphicalLayout == "Horizontal" then
self.frame:SetWidth((self.countSize + self.moduleSettings.countGap)*IceStackCounter_GetMaxCount(self)) self.frame:SetWidth((self.countSize + self.moduleSettings.countGap)*IceStackCounter_GetMaxCount(self))
self.frame:SetHeight(1) self.frame:SetHeight(1)
@ -324,7 +346,7 @@ end
function IceCustomCount.prototype:CreateCustomFrame(doTextureUpdate) function IceCustomCount.prototype:CreateCustomFrame(doTextureUpdate)
-- create numeric counts -- create numeric counts
self.frame.numeric = self:FontFactory(self.moduleSettings.countFontSize, nil, self.frame.numeric) self.frame.numeric = self:FontFactory(self.moduleSettings.countFontSize, self.frame, self.frame.numeric)
self.frame.numeric:SetWidth(50) self.frame.numeric:SetWidth(50)
self.frame.numeric:SetJustifyH("CENTER") self.frame.numeric:SetJustifyH("CENTER")
@ -360,7 +382,7 @@ function IceCustomCount.prototype:CreateCustomFrame(doTextureUpdate)
end end
end end
self.frame.graphicalBG[i]:SetFrameStrata("BACKGROUND") self.frame.graphicalBG[i]:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
self.frame.graphicalBG[i]:SetWidth(self.countSize) self.frame.graphicalBG[i]:SetWidth(self.countSize)
self.frame.graphicalBG[i]:SetHeight(self.countSize) self.frame.graphicalBG[i]:SetHeight(self.countSize)
if self.moduleSettings.graphicalLayout == "Horizontal" then if self.moduleSettings.graphicalLayout == "Horizontal" then
@ -394,7 +416,7 @@ function IceCustomCount.prototype:CreateCustomFrame(doTextureUpdate)
end end
end end
self.frame.graphical[i]:SetFrameStrata("BACKGROUND") self.frame.graphical[i]:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
self.frame.graphical[i]:SetAllPoints(self.frame.graphicalBG[i]) self.frame.graphical[i]:SetAllPoints(self.frame.graphicalBG[i])
self.frame.graphical[i]:Hide() self.frame.graphical[i]:Hide()
@ -421,6 +443,9 @@ function IceCustomCount.prototype:GetGradientColor(curr)
local r, g, b = self:GetCustomColor() local r, g, b = self:GetCustomColor()
local mr, mg, mb = self:GetCustomMinColor() local mr, mg, mb = self:GetCustomMinColor()
local scale = max > 1 and ((curr-1)/(max-1)) or 1 local scale = max > 1 and ((curr-1)/(max-1)) or 1
if self.moduleSettings.countMode == "Numeric" and self.moduleSettings.showWhenZero then
scale = max > 1 and (curr/max) or 1
end
r = r * scale + mr * (1-scale) r = r * scale + mr * (1-scale)
g = g * scale + mg * (1-scale) g = g * scale + mg * (1-scale)
@ -436,6 +461,15 @@ function IceCustomCount.prototype:UpdateCustomCount()
end end
local points = IceStackCounter_GetCount(self) local points = IceStackCounter_GetCount(self)
if not points and self.moduleSettings.showWhenZero then
points = 0
end
local max = IceStackCounter_GetMaxCount(self)
if max > #self.frame.graphical then
self:Redraw()
return
end
if (self.moduleSettings.countMode == "Numeric") then if (self.moduleSettings.countMode == "Numeric") then
local r, g, b = self:GetCustomColor() local r, g, b = self:GetCustomColor()

View File

@ -7,6 +7,20 @@ local AuraIconWidth = 20
local AuraIconHeight = 20 local AuraIconHeight = 20
local DefaultAuraIcon = "Interface\\Icons\\Spell_Frost_Frost" local DefaultAuraIcon = "Interface\\Icons\\Spell_Frost_Frost"
local GetSpellInfo = GetSpellInfo
if not GetSpellInfo and C_Spell and C_Spell.GetSpellInfo then
GetSpellInfo = function(id)
if not id then
return nil
end
local info = C_Spell.GetSpellInfo(id)
if info then
return info.name, nil, info.iconID
end
end
end
function IceCustomCounterBar.prototype:init() function IceCustomCounterBar.prototype:init()
IceCustomCounterBar.super.prototype.init(self, "CustomCounterBar") IceCustomCounterBar.super.prototype.init(self, "CustomCounterBar")
@ -250,6 +264,11 @@ function IceCustomCounterBar.prototype:Enable(core)
IceStackCounter_Enable(self) IceStackCounter_Enable(self)
end end
function IceCustomCounterBar.prototype:TargetChanged()
IceCustomCount.super.prototype.TargetChanged(self)
self:UpdateCustomCount()
end
function IceCustomCounterBar.prototype:Redraw() function IceCustomCounterBar.prototype:Redraw()
IceCustomCounterBar.super.prototype.Redraw(self) IceCustomCounterBar.super.prototype.Redraw(self)
@ -272,8 +291,7 @@ function IceCustomCounterBar.prototype:CreateFrame()
IceCustomCounterBar.super.prototype.CreateFrame(self) IceCustomCounterBar.super.prototype.CreateFrame(self)
if not self.barFrame.icon then if not self.barFrame.icon then
self.barFrame.icon = self.masterFrame:CreateTexture(nil, "LOW") self.barFrame.icon = self.masterFrame:CreateTexture(nil, "BACKGROUND")
self.barFrame.icon:SetTexture(DefaultAuraIcon)
self.barFrame.icon:SetTexCoord(0.1, 0.9, 0.1, 0.9) self.barFrame.icon:SetTexCoord(0.1, 0.9, 0.1, 0.9)
self.barFrame.icon:SetDrawLayer("OVERLAY") self.barFrame.icon:SetDrawLayer("OVERLAY")
self.barFrame.icon:Hide() self.barFrame.icon:Hide()
@ -301,10 +319,6 @@ function IceCustomCounterBar.prototype:UpdateAuraIcon()
local auraIcon, _ local auraIcon, _
_, _, auraIcon = GetSpellInfo(self.moduleSettings.auraName) _, _, auraIcon = GetSpellInfo(self.moduleSettings.auraName)
if auraIcon == nil then
auraIcon = "Interface\\Icons\\Spell_Frost_Frost"
end
self.barFrame.icon:SetTexture(auraIcon) self.barFrame.icon:SetTexture(auraIcon)
end end
@ -314,12 +328,16 @@ function IceCustomCounterBar.prototype:UpdateCustomCount()
local percent = IceHUD:Clamp(1.0 * points / (max > 0 and max or 1), 0, 1) local percent = IceHUD:Clamp(1.0 * points / (max > 0 and max or 1), 0, 1)
if IceHUD.IceCore:IsInConfigMode() then if IceHUD.IceCore:IsInConfigMode() then
if not self.barFrame.icon:GetTexture() then
self.barFrame.icon:SetTexture(DefaultAuraIcon)
end
points = IceStackCounter_GetMaxCount(self) points = IceStackCounter_GetMaxCount(self)
percent = 1 percent = 1
self.barFrame.icon:Show() self.barFrame.icon:Show()
end end
if points == nil or points == 0 then if (points == nil or points == 0) and self.moduleSettings.auraType ~= "charges" then
self:Show(false) self:Show(false)
self:UpdateBar(0, "undef") self:UpdateBar(0, "undef")
else else
@ -343,3 +361,7 @@ end
function IceCustomCounterBar.prototype:Update() function IceCustomCounterBar.prototype:Update()
self:UpdateCustomCount() self:UpdateCustomCount()
end end
function IceCustomCounterBar.prototype:UseTargetAlpha(scale)
return IceStackCounter_UseTargetAlpha(self)
end

View File

@ -144,6 +144,8 @@ function IceCustomHealth.prototype:Update(unit)
if (self.moduleSettings.scaleHealthColor) then if (self.moduleSettings.scaleHealthColor) then
self.color = "ScaledHealthColor" self.color = "ScaledHealthColor"
elseif self.moduleSettings.lowThresholdColor and self.healthPercentage and self.healthPercentage <= self.moduleSettings.lowThreshold then
self.color = "ScaledHealthColor"
end end
if (self.tapped) then if (self.tapped) then

View File

@ -0,0 +1,232 @@
local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false)
local DragonridingVigor = IceCore_CreateClass(IceClassPowerCounter)
local DragonridingBuffs = {
360954, -- Highland Drake
368896, -- Renewed Proto-Drake
368899, -- Windborn Velocidrake
368901, -- Cliffside Wylderdrake
368893, -- Winding Slitherdrake
412088, -- Grotto Netherwing Drake
}
local vigorWidgetSetID = 283
local vigorWidgetType = 24
local defaultVigorWidgetID = 4460
local vigorWidgetIDs = nil
local knowsAlternateMountEnum = Enum and Enum.PowerType and Enum.PowerType.AlternateMount
local unitPowerType = Enum and Enum.PowerType and Enum.PowerType.AlternateMount
unitPowerType = unitPowerType or ALTERNATE_POWER_INDEX
function DragonridingVigor.prototype:init()
DragonridingVigor.super.prototype.init(self, "Vigor")
self:SetDefaultColor("VigorNumeric", 150, 150, 255)
self.unit = "player"
self.numericColor = "VigorNumeric"
self.unitPower = unitPowerType
self.minLevel = 0
self.bTreatEmptyAsFull = false
self.runeWidth = self.runeHeight
self.shouldRegisterDisplayPower = false
end
function DragonridingVigor.prototype:Enable(core)
self.numRunes = UnitPowerMax(self.unit, unitPowerType)
self.runeCoords = { }
for i = 1, self.numRunes do
self:SetupNewRune(i)
end
DragonridingVigor.super.prototype.Enable(self, core)
self:Show(false)
self:RegisterEvent("UNIT_AURA", "CheckShouldShow")
self:RegisterEvent("UPDATE_UI_WIDGET", "UpdateVigorRecharge")
end
function DragonridingVigor.prototype:EnteringWorld()
DragonridingVigor.super.prototype.EnteringWorld(self)
self:CheckShouldShow("PLAYER_ENTERING_WORLD", "player")
end
function DragonridingVigor.prototype:CheckShouldShow(event, unit, info)
if not vigorWidgetIDs or #vigorWidgetIDs == 0 then
self:PopulateVigorWidgetIDs()
end
if unit ~= "player" or not vigorWidgetIDs then
return
end
local shown = false
for i=1,#vigorWidgetIDs do
local info = C_UIWidgetManager.GetFillUpFramesWidgetVisualizationInfo(vigorWidgetIDs[i])
if info and info.shownState ~= 0 then
shown = true
break
end
end
if not shown then
self:Show(false)
self.suppressHideBlizz = true
if self.moduleSettings.hideBlizz then
self:ShowBlizz()
end
return
end
self:Show(true)
-- if knowsAlternateMountEnum and UnitPowerMax(self.unit, unitPowerType) > 0 then
-- self:Show(true)
-- elseif not knowsAlternateMountEnum and IceHUD:HasAnyBuff("player", DragonridingBuffs) then
-- self:Show(true)
-- else
-- self:Show(false)
-- if self.moduleSettings.hideBlizz then
-- self:ShowBlizz()
-- end
-- end
end
function DragonridingVigor.prototype:UpdateRunePower(event, arg1, arg2)
self:UpdateVigorRecharge("internal")
DragonridingVigor.super.prototype.UpdateRunePower(self, event, arg1, arg2)
end
function DragonridingVigor.prototype:PopulateVigorWidgetIDs()
local widgets = C_UIWidgetManager.GetAllWidgetsBySetID(vigorWidgetSetID)
if not widgets then
return
end
for i=1,#widgets do
if widgets[i].widgetType == vigorWidgetType then
if not vigorWidgetIDs then
vigorWidgetIDs = {}
end
table.insert(vigorWidgetIDs, widgets[i].widgetID)
end
end
end
function DragonridingVigor.prototype:UpdateVigorRecharge(event, widget)
if not vigorWidgetIDs or #vigorWidgetIDs == 0 then
self:PopulateVigorWidgetIDs()
end
if not vigorWidgetIDs or #vigorWidgetIDs == 0 then
return
end
self.partialReady = nil
self.partialReadyPercent = nil
if event ~= "internal" and (not widget or widget.widgetSetID ~= vigorWidgetSetID) then
return
end
local widgetID = defaultVigorWidgetID
if widget then
widgetID = widget.widgetID
end
local info = C_UIWidgetManager.GetFillUpFramesWidgetVisualizationInfo(widgetID)
if not info then
return
end
self.suppressHideBlizz = not info or info.shownState == 0
if event ~= "internal" then
if self.moduleSettings.hideBlizz then
self:HideBlizz()
else
self:ShowBlizz()
end
end
if info.numFullFrames == info.numTotalFrames then
return
end
if info.fillMax == 0 then
return
end
self.partialReady = IceHUD:Clamp(info.numFullFrames + 1, 0, info.numTotalFrames)
self.partialReadyPercent = info.fillValue / info.fillMax
if event ~= "internal" then
self:UpdateRunePower()
end
end
function DragonridingVigor.prototype:SetupNewRune(rune)
self.runeCoords[rune] = {0, 1, 0, 1}
end
function DragonridingVigor.prototype:GetDefaultSettings()
local defaults = DragonridingVigor.super.prototype.GetDefaultSettings(self)
defaults.pulseWhenFull = false
defaults.runeGap = 4
defaults.inactiveDisplayMode = "Shown"
defaults.hideBlizz = true
defaults.vpos = -25
return defaults
end
function DragonridingVigor.prototype:GetOptions()
local opts = DragonridingVigor.super.prototype.GetOptions(self)
opts.inactiveDisplayMode.hidden = function() return true end
return opts
end
function DragonridingVigor.prototype:GetRuneAtlas(rune)
return "dragonriding_vigor_fillfull"
end
function DragonridingVigor.prototype:GetShineAtlas(rune)
return "Mage-ArcaneCharge-SmallSpark"
end
function DragonridingVigor.prototype:GetFrameAtlas(rune)
return "dragonriding_vigor_frame"
end
function DragonridingVigor.prototype:GetBackgroundAtlas(rune)
return "dragonriding_vigor_background"
end
function DragonridingVigor.prototype:GetPartialRuneAtlas(rune)
return "dragonriding_vigor_fill"
end
function DragonridingVigor.prototype:ShowBlizz()
local info = C_UIWidgetManager.GetFillUpFramesWidgetVisualizationInfo(defaultVigorWidgetID)
if not info or info.shownState == 0 then
return
end
UIWidgetPowerBarContainerFrame.widgetFrames[defaultVigorWidgetID]:Show()
end
function DragonridingVigor.prototype:HideBlizz()
if not UIWidgetPowerBarContainerFrame.widgetFrames or not UIWidgetPowerBarContainerFrame.widgetFrames[defaultVigorWidgetID] then
return
end
if not self.suppressHideBlizz then
UIWidgetPowerBarContainerFrame.widgetFrames[defaultVigorWidgetID]:Hide()
end
end
-- Load us up
if unitPowerType and C_UIWidgetManager and C_UIWidgetManager.GetFillUpFramesWidgetVisualizationInfo then
IceHUD.DragonridingVigor = DragonridingVigor:new()
end

123
modules/DruidEnergy.lua Normal file
View File

@ -0,0 +1,123 @@
local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false)
local DruidEnergy = IceCore_CreateClass(IceUnitBar)
DruidEnergy.prototype.DruidEnergy = nil
DruidEnergy.prototype.DruidEnergyMax = nil
local _, unitClass = UnitClass("player")
local FORM_NONE = 0
local FORM_BEAR = 1
local FORM_TRAVEL = 3
local SPELL_POWER_ENERGY = SPELL_POWER_ENERGY
if Enum and Enum.PowerType then
SPELL_POWER_ENERGY = Enum.PowerType.Energy
end
local shapeshiftFormValues = {NONE = L["No form"], BEAR = L["Bear"], TRAVEL = L["Travel"], OTHER = L["Other"]}
local shapeshiftFormIds = {NONE = FORM_NONE, BEAR = FORM_BEAR, TRAVEL = FORM_TRAVEL}
function DruidEnergy.prototype:init()
DruidEnergy.super.prototype.init(self, "DruidEnergy", "player")
self.side = IceCore.Side.Left
self.offset = 5
self:SetDefaultColor("DruidEnergy", 218, 231, 31)
end
function DruidEnergy.prototype:GetDefaultSettings()
local settings = DruidEnergy.super.prototype.GetDefaultSettings(self)
settings["side"] = IceCore.Side.Left
settings["offset"] = 5
settings["textVisible"] = {upper = true, lower = false}
settings["upperText"] = "[PercentMP(type='Energy'):Round]"
settings["lowerText"] = "[FractionalMP(type='Energy'):Color('dae71f'):Bracket]"
settings.enabled = false
settings.whileInForm = {["BEAR"] = true}
return settings
end
function DruidEnergy.prototype:GetOptions()
local opts = DruidEnergy.super.prototype.GetOptions(self)
opts["whileInForm"] = {
type = 'multiselect',
values = shapeshiftFormValues,
name = L["Show in form"],
desc = L["When the player is in one of the chosen shapeshift forms the bar will be shown, otherwise it will be hidden."],
get = function(info, v)
for key, value in pairs(self.moduleSettings.whileInForm) do
if key == v then
return value
end
end
return false
end,
set = function(info, v, state)
self.moduleSettings.whileInForm[v] = state
self:Update()
end,
disabled = function()
return not self.moduleSettings.enabled
end,
}
return opts
end
function DruidEnergy.prototype:Enable(core)
DruidEnergy.super.prototype.Enable(self, core)
self:RegisterEvent("UPDATE_SHAPESHIFT_FORM", "Update")
self:RegisterEvent("UNIT_POWER_FREQUENT", "Update")
self:RegisterEvent("UNIT_MAXPOWER", "Update")
end
function DruidEnergy.prototype:GetElementDescription()
return L["Always shows the Druid's Energy level while in non-energy-using forms."]
end
function DruidEnergy.prototype:ShouldShow(unit)
local currentForm = GetShapeshiftForm()
for k, v in pairs(self.moduleSettings.whileInForm) do
if currentForm > FORM_TRAVEL and k == "OTHER" then
return v
elseif currentForm == shapeshiftFormIds[k] then
return v
end
end
return false
end
function DruidEnergy.prototype:Update()
DruidEnergy.super.prototype.Update(self)
self.DruidEnergy = UnitPower(self.unit, SPELL_POWER_ENERGY)
self.DruidEnergyMax = UnitPowerMax(self.unit, SPELL_POWER_ENERGY)
self.DruidEnergyPercentage = self.DruidEnergyMax ~= 0 and (self.DruidEnergy/self.DruidEnergyMax) or 0
if (not self.alive or not self:ShouldShow(self.unit) or not self.DruidEnergy or not self.DruidEnergyMax or self.DruidEnergyMax == 0) then
self:Show(false)
return
else
self:Show(true)
end
if not IceHUD.IceCore:ShouldUseDogTags() and self.frame:IsVisible() then
self:SetBottomText1(math.floor(self.DruidEnergyPercentage * 100))
self:SetBottomText2(self:GetFormattedText(self:Round(self.DruidEnergy), self:Round(self.DruidEnergyMax)), "DruidEnergy")
end
self:UpdateBar(self.DruidEnergyMax ~= 0 and self.DruidEnergy / self.DruidEnergyMax or 0, "DruidEnergy")
end
if unitClass == "DRUID" then
IceHUD.DruidEnergy = DruidEnergy:new()
end

View File

@ -107,7 +107,7 @@ function EclipseBar.prototype:CreateFrame()
end end
function EclipseBar.prototype:CreateSolarBar() function EclipseBar.prototype:CreateSolarBar()
self.solarBar = self:BarFactory(self.solarBar,"BACKGROUND", "ARTWORK") self.solarBar = self:BarFactory(self.solarBar, "BACKGROUND", "ARTWORK", "Solar")
self:SetBarCoord(self.solarBar, 0.5, true) self:SetBarCoord(self.solarBar, 0.5, true)
self.solarBar.bar:SetVertexColor(self:GetColor("EclipseSolar", 1)) self.solarBar.bar:SetVertexColor(self:GetColor("EclipseSolar", 1))
@ -119,7 +119,7 @@ function EclipseBar.prototype:UpdateShown()
if form == MOONKIN_FORM or not form then if form == MOONKIN_FORM or not form then
local PrimaryTalentTree = 0 local PrimaryTalentTree = 0
if IceHUD.WowVer >= 50000 then if GetSpecialization then
PrimaryTalentTree = GetSpecialization() PrimaryTalentTree = GetSpecialization()
else else
PrimaryTalentTree = GetPrimaryTalentTree() PrimaryTalentTree = GetPrimaryTalentTree()
@ -190,6 +190,6 @@ function EclipseBar.prototype:MyOnUpdate()
end end
local _, unitClass = UnitClass("player") local _, unitClass = UnitClass("player")
if (unitClass == "DRUID" and IceHUD.WowVer >= 40000 and IceHUD.WowVer < 70000) then if (unitClass == "DRUID" and GetEclipseDirection) then
IceHUD.EclipseBar = EclipseBar:new() IceHUD.EclipseBar = EclipseBar:new()
end end

74
modules/EssencePower.lua Normal file
View File

@ -0,0 +1,74 @@
local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false)
local EssencePower = IceCore_CreateClass(IceClassPowerCounter)
local SPELL_POWER_ESSENCE = SPELL_POWER_ESSENCE
if Enum and Enum.PowerType then
SPELL_POWER_ESSENCE = Enum.PowerType.Essence
end
function EssencePower.prototype:init()
EssencePower.super.prototype.init(self, "EssencePower")
self:SetDefaultColor("EssencePowerNumeric", 150, 150, 255)
self.unit = "player"
self.numericColor = "EssencePowerNumeric"
self.unitPower = SPELL_POWER_ESSENCE
self.minLevel = 0
self.bTreatEmptyAsFull = false
self.runeWidth = self.runeHeight
end
function EssencePower.prototype:Enable(core)
self.numRunes = UnitPowerMax(self.unit, SPELL_POWER_ESSENCE)
self.runeCoords = { }
for i = 1, self.numRunes do
self:SetupNewRune(i)
end
EssencePower.super.prototype.Enable(self, core)
end
function EssencePower.prototype:SetupNewRune(rune)
self.runeCoords[rune] = {0, 1, 0, 1}
end
function EssencePower.prototype:GetPowerEvent()
return "UNIT_POWER_FREQUENT"
end
function EssencePower.prototype:GetDefaultSettings()
local defaults = EssencePower.super.prototype.GetDefaultSettings(self)
defaults["pulseWhenFull"] = false
return defaults
end
function EssencePower.prototype:GetOptions()
local opts = EssencePower.super.prototype.GetOptions(self)
opts.hideBlizz.hidden = function() return true end
return opts
end
function EssencePower.prototype:GetRuneAtlas(rune)
return "UF-Essence-Icon"
end
function EssencePower.prototype:GetShineAtlas(rune)
return "Mage-ArcaneCharge-SmallSpark"
end
function EssencePower.prototype:ShowBlizz()
end
function EssencePower.prototype:HideBlizz()
end
-- Load us up
local _, unitClass = UnitClass("player")
if unitClass == "EVOKER" then
IceHUD.EssencePower = EssencePower:new()
end

View File

@ -26,4 +26,6 @@ function FocusAbsorb.prototype:MyUnregisterCustomEvents()
end end
-- Load us up -- Load us up
IceHUD.FocusAbsorb = FocusAbsorb:new() if UnitGetTotalAbsorbs ~= nil then
IceHUD.FocusAbsorb = FocusAbsorb:new()
end

View File

@ -23,4 +23,6 @@ end
-- 'Protected' methods -------------------------------------------------------- -- 'Protected' methods --------------------------------------------------------
-- Load us up -- Load us up
IceHUD.FocusCC = FocusCC:new() if FocusUnit then
IceHUD.FocusCC = FocusCC:new()
end

View File

@ -112,4 +112,6 @@ end
-- Load us up -- Load us up
IceHUD.FocusCast = FocusCast:new() if FocusUnit then
IceHUD.FocusCast = FocusCast:new()
end

View File

@ -364,6 +364,8 @@ function FocusHealth.prototype:Update(unit)
if (self.moduleSettings.scaleHealthColor) then if (self.moduleSettings.scaleHealthColor) then
self.color = "ScaledHealthColor" self.color = "ScaledHealthColor"
elseif self.moduleSettings.lowThresholdColor and self.healthPercentage <= self.moduleSettings.lowThreshold then
self.color = "ScaledHealthColor"
end end
if (self.tapped) then if (self.tapped) then
@ -420,9 +422,9 @@ end
function FocusHealth.prototype:UpdateRaidFocusIcon() function FocusHealth.prototype:UpdateRaidFocusIcon()
if self.moduleSettings.raidIconOnTop then if self.moduleSettings.raidIconOnTop then
self.frame.raidIcon:SetFrameStrata("MEDIUM") self.frame.raidIcon:SetFrameStrata(IceHUD.IceCore:DetermineStrata("MEDIUM"))
else else
self.frame.raidIcon:SetFrameStrata("LOW") self.frame.raidIcon:SetFrameStrata(IceHUD.IceCore:DetermineStrata("LOW"))
end end
if not (UnitExists(self.unit)) or not self.moduleSettings.showRaidIcon then if not (UnitExists(self.unit)) or not self.moduleSettings.showRaidIcon then
@ -471,4 +473,6 @@ function FocusHealth.prototype:HideBlizz()
end end
-- Load us up -- Load us up
IceHUD.FocusHealth = FocusHealth:new() if FocusUnit then
IceHUD.FocusHealth = FocusHealth:new()
end

View File

@ -1,6 +1,14 @@
local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false) local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false)
local FocusMana = IceCore_CreateClass(IceUnitBar) local FocusMana = IceCore_CreateClass(IceUnitBar)
local SPELL_POWER_RAGE = SPELL_POWER_RAGE
local SPELL_POWER_FOCUS = SPELL_POWER_FOCUS
local SPELL_POWER_ENERGY = SPELL_POWER_ENERGY
if Enum and Enum.PowerType then
SPELL_POWER_RAGE = Enum.PowerType.Rage
SPELL_POWER_FOCUS = Enum.PowerType.Focus
SPELL_POWER_ENERGY = Enum.PowerType.Energy
end
-- Constructor -- -- Constructor --
function FocusMana.prototype:init() function FocusMana.prototype:init()
@ -31,9 +39,11 @@ end
function FocusMana.prototype:Enable(core) function FocusMana.prototype:Enable(core)
FocusMana.super.prototype.Enable(self, core) FocusMana.super.prototype.Enable(self, core)
if IceHUD.WowVer >= 40000 then if not IceHUD.PerPowerEventsExist then
self:RegisterEvent("UNIT_POWER", "UpdateEvent") self:RegisterEvent(IceHUD.UnitPowerEvent, "UpdateEvent")
self:RegisterEvent("UNIT_MAXPOWER", "UpdateEvent") if IceHUD.EventExistsUnitMaxPower then
self:RegisterEvent("UNIT_MAXPOWER", "UpdateEvent")
end
else else
self:RegisterEvent("UNIT_MANA", "UpdateEvent") self:RegisterEvent("UNIT_MANA", "UpdateEvent")
self:RegisterEvent("UNIT_MAXMANA", "UpdateEvent") self:RegisterEvent("UNIT_MAXMANA", "UpdateEvent")
@ -78,6 +88,8 @@ function FocusMana.prototype:Update(unit)
local color = "FocusMana" local color = "FocusMana"
if (self.moduleSettings.scaleManaColor) then if (self.moduleSettings.scaleManaColor) then
color = "ScaledManaColor" color = "ScaledManaColor"
elseif self.moduleSettings.lowThresholdColor and self.manaPercentage <= self.moduleSettings.lowThreshold then
color = "ScaledManaColor"
end end
if (manaType == SPELL_POWER_RAGE) then if (manaType == SPELL_POWER_RAGE) then
color = "FocusRage" color = "FocusRage"
@ -126,4 +138,6 @@ end
-- Load us up -- Load us up
IceHUD.FocusMana = FocusMana:new() if FocusUnit then
IceHUD.FocusMana = FocusMana:new()
end

View File

@ -16,4 +16,6 @@ function IceFocusThreat.prototype:GetDefaultSettings()
end end
-- Load us up -- Load us up
IceHUD.IceFocusThreat = IceFocusThreat:new() if FocusUnit then
IceHUD.IceFocusThreat = IceFocusThreat:new()
end

View File

@ -1,6 +1,35 @@
local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false) local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false)
local GlobalCoolDown = IceCore_CreateClass(IceBarElement) local GlobalCoolDown = IceCore_CreateClass(IceBarElement)
local GetSpellName = GetSpellInfo
if C_Spell and C_Spell.GetSpellName then
GetSpellName = C_Spell.GetSpellName
end
local GetSpellInfo = GetSpellInfo
if not GetSpellInfo and C_Spell and C_Spell.GetSpellInfo then
GetSpellInfo = function(id)
if not id then
return nil
end
local info = C_Spell.GetSpellInfo(id)
if info then
return info.name, nil, info.iconID, info.castTime
end
end
end
local GetSpellCooldown = GetSpellCooldown
if not GetSpellCooldown and C_Spell then
GetSpellCooldown = function(spellID)
local spellCooldownInfo = C_Spell.GetSpellCooldown(spellID)
if spellCooldownInfo then
return spellCooldownInfo.startTime, spellCooldownInfo.duration, spellCooldownInfo.isEnabled, spellCooldownInfo.modRate
end
end
end
-- Constructor -- -- Constructor --
function GlobalCoolDown.prototype:init() function GlobalCoolDown.prototype:init()
GlobalCoolDown.super.prototype.init(self, "GlobalCoolDown") GlobalCoolDown.super.prototype.init(self, "GlobalCoolDown")
@ -20,7 +49,7 @@ function GlobalCoolDown.prototype:Enable(core)
self.moduleSettings.inverse = "NORMAL" self.moduleSettings.inverse = "NORMAL"
end end
self:RegisterEvent("UNIT_SPELLCAST_SENT","SpellCastSent") self:RegisterEvent("CURRENT_SPELL_CAST_CHANGED", "SpellCastChanged")
--self:RegisterEvent("ACTIONBAR_UPDATE_COOLDOWN", "CooldownStateChanged") --self:RegisterEvent("ACTIONBAR_UPDATE_COOLDOWN", "CooldownStateChanged")
self:RegisterEvent("UNIT_SPELLCAST_START","CooldownStateChanged") self:RegisterEvent("UNIT_SPELLCAST_START","CooldownStateChanged")
@ -38,14 +67,17 @@ function GlobalCoolDown.prototype:Enable(core)
self:Show(false) self:Show(false)
self.frame:SetFrameStrata("LOW") self.frame:SetFrameStrata(IceHUD.IceCore:DetermineStrata("LOW"))
self.CDSpellId = self:GetSpellId() self.CDSpellId = self:GetSpellId()
end end
function GlobalCoolDown.prototype:CVarUpdate() function GlobalCoolDown.prototype:CVarUpdate()
self.useFixedLatency = self.moduleSettings.respectLagTolerance and GetCVar("reducedLagTolerance") == "1" self.useFixedLatency = self.moduleSettings.respectLagTolerance and GetCVar("reducedLagTolerance") == "1"
self.fixedLatency = tonumber(GetCVar("maxSpellStartRecoveryoffset")) / 1000.0 local recoveryOffset = GetCVar("maxSpellStartRecoveryoffset")
if recoveryOffset ~= nil then
self.fixedLatency = tonumber(recoveryOffset) / 1000.0
end
end end
-- OVERRIDE -- OVERRIDE
@ -140,20 +172,16 @@ function GlobalCoolDown.prototype:IsFull(scale)
return false return false
end end
function GlobalCoolDown.prototype:SpellCastSent(event, unit, spell) function GlobalCoolDown.prototype:SpellCastChanged(event, cancelled)
if unit ~= "player" or not spell then
return
end
self.spellCastSent = GetTime() self.spellCastSent = GetTime()
end end
function GlobalCoolDown.prototype:SpellCastStop(event, unit, spell, _, _, spellId) function GlobalCoolDown.prototype:SpellCastStop(event, unit, castGuid, spellId)
if unit ~= "player" or not spellId or not self.CurrSpellId or self.CurrSpellId ~= spellId then if unit ~= "player" or not spellId or not self.CurrSpellGuid or self.CurrSpellGuid ~= castGuid then
return return
end end
self.CurrSpellId = nil self.CurrSpellGuid = nil
if event == "UNIT_SPELLCAST_INTERRUPTED" or event == "UNIT_SPELLCAST_FAILED" then if event == "UNIT_SPELLCAST_INTERRUPTED" or event == "UNIT_SPELLCAST_FAILED" then
self.CurrLerpTime = self.moduleSettings.desiredLerpTime self.CurrLerpTime = self.moduleSettings.desiredLerpTime
@ -166,7 +194,7 @@ function GlobalCoolDown.prototype:GetSpellCastTime(spell)
end end
local spellname, castTime, _ local spellname, castTime, _
if IceHUD.WowVer < 60000 then if IceHUD.GetSpellInfoReturnsFunnel then
spellName, _, _, _, _, _, castTime = GetSpellInfo(spell) spellName, _, _, _, _, _, castTime = GetSpellInfo(spell)
else else
spellName, _, _, castTime = GetSpellInfo(spell) spellName, _, _, castTime = GetSpellInfo(spell)
@ -179,19 +207,19 @@ function GlobalCoolDown.prototype:GetSpellCastTime(spell)
end end
end end
function GlobalCoolDown.prototype:CooldownStateChanged(event, unit, spell, _, _, spellId) function GlobalCoolDown.prototype:CooldownStateChanged(event, unit, castGuid, spellId)
if unit ~= "player" or not spellId then if unit ~= "player" or not spellId then
return return
end end
-- Ignore all events unrelated to the spell currently being cast -- Ignore all events unrelated to the spell currently being cast
if self.CurrSpellId and self.CurrSpellId ~= spellId then if self.CurrSpellGuid and self.CurrSpellGuid ~= castGuid then
return return
end end
-- Update the current spell ID for all events indicating a spellcast is starting -- Update the current spell ID for all events indicating a spellcast is starting
if event ~= "UNIT_SPELLCAST_SUCCEEDED" then if event ~= "UNIT_SPELLCAST_SUCCEEDED" then
self.CurrSpellId = spellId self.CurrSpellGuid = castGuid
end end
local start, dur = GetSpellCooldown(self.CDSpellId) local start, dur = GetSpellCooldown(self.CDSpellId)
@ -256,7 +284,7 @@ function GlobalCoolDown.prototype:CreateFrame()
end end
function GlobalCoolDown.prototype:CreateLagBar() function GlobalCoolDown.prototype:CreateLagBar()
self.lagBar = self:BarFactory(self.lagBar, "LOW", "OVERLAY") self.lagBar = self:BarFactory(self.lagBar, "LOW", "OVERLAY", "Lag")
local r, g, b = self:GetColor("CastLag") local r, g, b = self:GetColor("CastLag")
if (self.settings.backgroundToggle) then if (self.settings.backgroundToggle) then
@ -268,28 +296,41 @@ function GlobalCoolDown.prototype:CreateLagBar()
end end
function GlobalCoolDown.prototype:GetSpellId() function GlobalCoolDown.prototype:GetSpellId()
return 61304 if GetSpellName(61304) then
--[[ return 61304
local defaultSpells else
local defaultSpells
defaultSpells = { defaultSpells = {
ROGUE=1752, -- sinister strike ROGUE=1752, -- sinister strike
PRIEST=585, -- smite PRIEST=585, -- smite
DRUID=5176, -- wrath DRUID=5176, -- wrath
WARRIOR=34428, -- victory rush (not available until 5, sadly) WARRIOR=34428, -- victory rush (not available until 5, sadly)
MAGE=44614, -- frostfire bolt MAGE=44614, -- frostfire bolt
WARLOCK=686, -- shadow bolt WARLOCK=686, -- shadow bolt
PALADIN=105361, -- seal of command (level 3) PALADIN=105361, -- seal of command (level 3)
SHAMAN=403, -- lightning bolt SHAMAN=403, -- lightning bolt
HUNTER=3044, -- arcane shot HUNTER=3044, -- arcane shot
DEATHKNIGHT=47541, -- death coil DEATHKNIGHT=47541, -- death coil
MONK=100780, -- jab MONK=100780, -- jab
} }
local _, unitClass = UnitClass("player") if not GetSpellName(defaultSpells["PALADIN"]) then
return defaultSpells[unitClass] defaultSpells["PALADIN"] = 635
]] end
if not GetSpellName(defaultSpells["MAGE"]) then
defaultSpells["MAGE"] = 133
end
if not GetSpellName(defaultSpells["WARRIOR"]) then
defaultSpells["WARRIOR"] = 6673
end
local _, unitClass = UnitClass("player")
return defaultSpells[unitClass]
end
end end
-- Load us up -- Load us up
IceHUD.GlobalCoolDown = GlobalCoolDown:new() if IceHUD.CanTrackGCD then
IceHUD.GlobalCoolDown = GlobalCoolDown:new()
end

View File

@ -1,10 +1,18 @@
local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false) local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false)
local HarmonyPower = IceCore_CreateClass(IceClassPowerCounter) local HarmonyPower = IceCore_CreateClass(IceClassPowerCounter)
function HarmonyPower.prototype:init() local SPELL_POWER_CHI = SPELL_POWER_CHI
HarmonyPower.super.prototype.init(self, "HarmonyPower") if not SPELL_POWER_CHI then
SPELL_POWER_CHI = SPELL_POWER_LIGHT_FORCE
end
if Enum and Enum.PowerType then
SPELL_POWER_CHI = Enum.PowerType.Chi
end
self:SetDefaultColor("HarmonyPowerNumeric", 218, 231, 31) function HarmonyPower.prototype:init()
HarmonyPower.super.prototype.init(self, "Chi")
self:SetDefaultColor("ChiNumeric", 218, 231, 31)
-- pulled from MonkHarmonyBar.xml in Blizzard's UI source -- pulled from MonkHarmonyBar.xml in Blizzard's UI source
self.runeCoords = self.runeCoords =
@ -17,12 +25,8 @@ function HarmonyPower.prototype:init()
{0.00390625, 0.08593750, 0.71093750, 0.87500000}, {0.00390625, 0.08593750, 0.71093750, 0.87500000},
} }
self.numRunes = 4 self.numRunes = 4
self.numericColor = "HarmonyPowerNumeric" self.numericColor = "ChiNumeric"
if IceHUD.WowVer >= 50100 then self.unitPower = SPELL_POWER_CHI
self.unitPower = SPELL_POWER_CHI
else
self.unitPower = SPELL_POWER_LIGHT_FORCE
end
if IceHUD.WowVer >= 70000 then if IceHUD.WowVer >= 70000 then
self.requiredSpec = SPEC_MONK_WINDWALKER self.requiredSpec = SPEC_MONK_WINDWALKER
end end
@ -36,6 +40,13 @@ function HarmonyPower.prototype:Enable(core)
HarmonyPower.super.prototype.Enable(self, core) HarmonyPower.super.prototype.Enable(self, core)
self:RegisterEvent("UNIT_POWER_FREQUENT", "UpdateRunePower") self:RegisterEvent("UNIT_POWER_FREQUENT", "UpdateRunePower")
if IceHUD.EventExistsUnitMaxPower then
self:RegisterEvent("UNIT_MAXPOWER", "PlayerChiUpdate")
end
end
function HarmonyPower.prototype:PlayerChiUpdate()
self:Redraw()
end end
function HarmonyPower.prototype:UpdateRunePower(event, arg1, arg2) function HarmonyPower.prototype:UpdateRunePower(event, arg1, arg2)
@ -112,6 +123,6 @@ end
-- Load us up -- Load us up
local _, unitClass = UnitClass("player") local _, unitClass = UnitClass("player")
if (unitClass == "MONK" and IceHUD.WowVer >= 50000) then if unitClass == "MONK" then
IceHUD.HarmonyPower = HarmonyPower:new() IceHUD.HarmonyPower = HarmonyPower:new()
end end

View File

@ -1,6 +1,11 @@
local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false) local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false)
local HolyPower = IceCore_CreateClass(IceClassPowerCounter) local HolyPower = IceCore_CreateClass(IceClassPowerCounter)
local SPELL_POWER_HOLY_POWER = SPELL_POWER_HOLY_POWER
if Enum and Enum.PowerType then
SPELL_POWER_HOLY_POWER = Enum.PowerType.HolyPower
end
function HolyPower.prototype:init() function HolyPower.prototype:init()
HolyPower.super.prototype.init(self, "HolyPower") HolyPower.super.prototype.init(self, "HolyPower")
@ -27,13 +32,13 @@ function HolyPower.prototype:init()
self.numericColor = "HolyPowerNumeric" self.numericColor = "HolyPowerNumeric"
self.unitPower = SPELL_POWER_HOLY_POWER self.unitPower = SPELL_POWER_HOLY_POWER
self.minLevel = PALADINPOWERBAR_SHOW_LEVEL self.minLevel = PALADINPOWERBAR_SHOW_LEVEL
if IceHUD.WowVer >= 70000 then if IceHUD.WowVer >= 70000 and IceHUD.WowVer < 90000 then
self.requiredSpec = SPEC_PALADIN_RETRIBUTION self.requiredSpec = SPEC_PALADIN_RETRIBUTION
end end
self.bTreatEmptyAsFull = true self.bTreatEmptyAsFull = true
self.unit = "player" self.unit = "player"
self.numRunes = 5 self.numRunes = 5
if IceHUD.WowVer >= 50000 then if HOLY_POWER_FULL then
self.numConsideredFull = HOLY_POWER_FULL self.numConsideredFull = HOLY_POWER_FULL
else else
self.numConsideredFull = 3 self.numConsideredFull = 3
@ -129,7 +134,7 @@ end
-- Load us up -- Load us up
local _, unitClass = UnitClass("player") local _, unitClass = UnitClass("player")
if (unitClass == "PALADIN" and IceHUD.WowVer >= 40000) then if (unitClass == "PALADIN" and (PaladinPowerBar or PaladinPowerBarFrame)) then
IceHUD.HolyPower = HolyPower:new() IceHUD.HolyPower = HolyPower:new()
end end

View File

@ -280,8 +280,8 @@ function MirrorBarHandler.prototype:GetOptions()
type='range', type='range',
name = L["Bar vertical offset"], name = L["Bar vertical offset"],
desc = L["Adjust the vertical placement of this bar"], desc = L["Adjust the vertical placement of this bar"],
min = -400, min = -600,
max = 400, max = 600,
step = 1, step = 1,
get = function() get = function()
return self.moduleSettings.barVerticalOffset return self.moduleSettings.barVerticalOffset

View File

@ -42,16 +42,23 @@ function PetHealth.prototype:Enable(core)
PetHealth.super.prototype.Enable(self, core) PetHealth.super.prototype.Enable(self, core)
self:RegisterEvent("PET_UI_UPDATE", "CheckPet"); self:RegisterEvent("PET_UI_UPDATE", "CheckPet");
self:RegisterEvent("PLAYER_PET_CHANGED", "CheckPet"); if IceHUD.EventExistsPlayerPetChanged then
self:RegisterEvent("PET_BAR_CHANGED", "CheckPet"); self:RegisterEvent("PLAYER_PET_CHANGED", "CheckPet");
end
self:RegisterEvent("PET_BAR_UPDATE_USABLE", "CheckPet");
self:RegisterEvent("UNIT_PET", "CheckPet"); self:RegisterEvent("UNIT_PET", "CheckPet");
self:RegisterEvent("UNIT_HEALTH", "UpdateEvent") self:RegisterEvent("UNIT_HEALTH", "UpdateEvent")
if IceHUD.EventExistsUnitHealthFrequent then
self:RegisterEvent("UNIT_HEALTH_FREQUENT", "UpdateEvent")
end
self:RegisterEvent("UNIT_MAXHEALTH", "UpdateEvent") self:RegisterEvent("UNIT_MAXHEALTH", "UpdateEvent")
self:RegisterEvent("UNIT_ENTERED_VEHICLE", "EnteringVehicle") if UnitHasVehicleUI then
self:RegisterEvent("UNIT_EXITED_VEHICLE", "ExitingVehicle") self:RegisterEvent("UNIT_ENTERED_VEHICLE", "EnteringVehicle")
self:RegisterEvent("PLAYER_ENTERING_WORLD", "CheckVehicle") self:RegisterEvent("UNIT_EXITED_VEHICLE", "ExitingVehicle")
end
self:RegisterEvent("PLAYER_ENTERING_WORLD", "EnteringWorld")
self.frame:SetAttribute("unit", self.unit) self.frame:SetAttribute("unit", self.unit)
RegisterUnitWatch(self.frame) RegisterUnitWatch(self.frame)
@ -86,6 +93,8 @@ function PetHealth.prototype:Update(unit)
if (self.moduleSettings.scaleHealthColor) then if (self.moduleSettings.scaleHealthColor) then
color = "ScaledHealthColor" color = "ScaledHealthColor"
elseif self.moduleSettings.lowThresholdColor and self.healthPercentage <= self.moduleSettings.lowThreshold then
color = "ScaledHealthColor"
end end
if not (self.alive) then if not (self.alive) then
@ -217,11 +226,16 @@ function PetHealth.prototype:ExitingVehicle(event, unit)
end end
end end
function PetHealth.prototype:CheckVehicle() function PetHealth.prototype:EnteringWorld()
if UnitHasVehicleUI("player") then self:TargetChanged()
self:EnteringVehicle(nil, "player", true) self:Update(self.unit)
else
self:ExitingVehicle(nil, "player") if UnitHasVehicleUI then
if UnitHasVehicleUI("player") then
self:EnteringVehicle(nil, "player", true)
else
self:ExitingVehicle(nil, "player")
end
end end
end end

View File

@ -1,6 +1,17 @@
local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false) local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false)
local PetMana = IceCore_CreateClass(IceUnitBar) local PetMana = IceCore_CreateClass(IceUnitBar)
local SPELL_POWER_RAGE = SPELL_POWER_RAGE
local SPELL_POWER_FOCUS = SPELL_POWER_FOCUS
local SPELL_POWER_ENERGY = SPELL_POWER_ENERGY
local SPELL_POWER_RUNIC_POWER = SPELL_POWER_RUNIC_POWER
if Enum and Enum.PowerType then
SPELL_POWER_RAGE = Enum.PowerType.Rage
SPELL_POWER_FOCUS = Enum.PowerType.Focus
SPELL_POWER_ENERGY = Enum.PowerType.Energy
SPELL_POWER_RUNIC_POWER = Enum.PowerType.RunicPower
end
-- Constructor -- -- Constructor --
function PetMana.prototype:init() function PetMana.prototype:init()
PetMana.super.prototype.init(self, "PetMana", "pet") PetMana.super.prototype.init(self, "PetMana", "pet")
@ -51,13 +62,17 @@ function PetMana.prototype:Enable(core)
PetMana.super.prototype.Enable(self, core) PetMana.super.prototype.Enable(self, core)
self:RegisterEvent("PET_UI_UPDATE", "CheckPet") self:RegisterEvent("PET_UI_UPDATE", "CheckPet")
self:RegisterEvent("PLAYER_PET_CHANGED", "CheckPet") if IceHUD.EventExistsPlayerPetChanged then
self:RegisterEvent("PET_BAR_CHANGED", "CheckPet") self:RegisterEvent("PLAYER_PET_CHANGED", "CheckPet")
end
self:RegisterEvent(IceHUD.EventExistsPetBarChanged and "PET_BAR_CHANGED" or "PET_BAR_UPDATE_USABLE", "CheckPet")
self:RegisterEvent("UNIT_PET", "CheckPet") self:RegisterEvent("UNIT_PET", "CheckPet")
if IceHUD.WowVer >= 40000 then if not IceHUD.PerPowerEventsExist then
self:RegisterEvent("UNIT_POWER", "UpdateEvent") self:RegisterEvent(IceHUD.UnitPowerEvent, "UpdateEvent")
self:RegisterEvent("UNIT_MAXPOWER", "UpdateEvent") if IceHUD.EventExistsUnitMaxPower then
self:RegisterEvent("UNIT_MAXPOWER", "UpdateEvent")
end
else else
self:RegisterEvent("UNIT_MANA", "UpdateEvent") self:RegisterEvent("UNIT_MANA", "UpdateEvent")
self:RegisterEvent("UNIT_MAXMANA", "UpdateEvent") self:RegisterEvent("UNIT_MAXMANA", "UpdateEvent")
@ -71,9 +86,11 @@ function PetMana.prototype:Enable(core)
self:RegisterEvent("UNIT_DISPLAYPOWER", "ManaType") self:RegisterEvent("UNIT_DISPLAYPOWER", "ManaType")
self:RegisterEvent("UNIT_ENTERED_VEHICLE", "EnteringVehicle") if UnitHasVehicleUI then
self:RegisterEvent("UNIT_EXITED_VEHICLE", "ExitingVehicle") self:RegisterEvent("UNIT_ENTERED_VEHICLE", "EnteringVehicle")
self:RegisterEvent("PLAYER_ENTERING_WORLD", "CheckVehicle") self:RegisterEvent("UNIT_EXITED_VEHICLE", "ExitingVehicle")
end
self:RegisterEvent("PLAYER_ENTERING_WORLD", "EnteringWorld")
self:CheckPet() self:CheckPet()
self:ManaType(nil, self.unit) self:ManaType(nil, self.unit)
@ -156,6 +173,8 @@ function PetMana.prototype:Update(unit)
local color = "PetMana" local color = "PetMana"
if (self.moduleSettings.scaleManaColor) then if (self.moduleSettings.scaleManaColor) then
color = "ScaledManaColor" color = "ScaledManaColor"
elseif self.moduleSettings.lowThresholdColor and self.manaPercentage <= self.moduleSettings.lowThreshold then
color = "ScaledManaColor"
end end
if not (self.alive) then if not (self.alive) then
color = "Dead" color = "Dead"
@ -224,11 +243,16 @@ function PetMana.prototype:ExitingVehicle(event, unit)
end end
end end
function PetMana.prototype:CheckVehicle() function PetMana.prototype:EnteringWorld()
if UnitHasVehicleUI("player") then self:TargetChanged()
self:EnteringVehicle(nil, "player", true) self:Update(self.unit)
else
self:ExitingVehicle(nil, "player") if UnitHasVehicleUI then
if UnitHasVehicleUI("player") then
self:EnteringVehicle(nil, "player", true)
else
self:ExitingVehicle(nil, "player")
end
end end
end end

View File

@ -19,4 +19,6 @@ function PlayerAbsorb.prototype:GetDefaultSettings()
end end
-- Load us up -- Load us up
IceHUD.PlayerAbsorb = PlayerAbsorb:new() if UnitGetTotalAbsorbs ~= nil then
IceHUD.PlayerAbsorb = PlayerAbsorb:new()
end

View File

@ -6,6 +6,13 @@ PlayerAltMana.prototype.PlayerAltManaMax = nil
local _, unitClass = UnitClass("player") local _, unitClass = UnitClass("player")
local SPELL_POWER_MANA = SPELL_POWER_MANA
local SPELL_POWER_INSANITY = SPELL_POWER_INSANITY
if Enum and Enum.PowerType then
SPELL_POWER_MANA = Enum.PowerType.Mana
SPELL_POWER_INSANITY = Enum.PowerType.Insanity
end
-- Constructor -- -- Constructor --
function PlayerAltMana.prototype:init() function PlayerAltMana.prototype:init()
PlayerAltMana.super.prototype.init(self, "PlayerAltMana", "player") PlayerAltMana.super.prototype.init(self, "PlayerAltMana", "player")
@ -76,6 +83,7 @@ function PlayerAltMana.prototype:Update()
self.PlayerAltMana = UnitPower(self.unit, SPELL_POWER_MANA) self.PlayerAltMana = UnitPower(self.unit, SPELL_POWER_MANA)
self.PlayerAltManaMax = UnitPowerMax(self.unit, SPELL_POWER_MANA) self.PlayerAltManaMax = UnitPowerMax(self.unit, SPELL_POWER_MANA)
self.PlayerAltManaPercentage = self.PlayerAltManaMax ~= 0 and (self.PlayerAltMana/self.PlayerAltManaMax) or 0
if (not self.alive or not ShouldShow(self.unit) or not self.PlayerAltMana or not self.PlayerAltManaMax or self.PlayerAltManaMax == 0) then if (not self.alive or not ShouldShow(self.unit) or not self.PlayerAltMana or not self.PlayerAltManaMax or self.PlayerAltManaMax == 0) then
self:Show(false) self:Show(false)
@ -84,6 +92,16 @@ function PlayerAltMana.prototype:Update()
self:Show(true) self:Show(true)
end end
if not IceHUD.IceCore:ShouldUseDogTags() and self.frame:IsVisible() then
self:SetBottomText1(math.floor(self.PlayerAltManaPercentage * 100))
if (self.PlayerAltManaMax ~= 100) then
self:SetBottomText2(self:GetFormattedText(self:Round(self.PlayerAltMana), self:Round(self.PlayerAltManaMax)), "PlayerMana")
else
self:SetBottomText2()
end
end
self:UpdateBar(self.PlayerAltManaMax ~= 0 and self.PlayerAltMana / self.PlayerAltManaMax or 0, "PlayerAltMana") self:UpdateBar(self.PlayerAltManaMax ~= 0 and self.PlayerAltMana / self.PlayerAltManaMax or 0, "PlayerAltMana")
end end

View File

@ -1,9 +1,9 @@
local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false) local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false)
IceHUDPlayerAlternatePower = IceCore_CreateClass(IceUnitBar) local PlayerAlternatePower = IceCore_CreateClass(IceUnitBar)
-- Constructor -- -- Constructor --
function IceHUDPlayerAlternatePower.prototype:init(moduleName, unit) function PlayerAlternatePower.prototype:init(moduleName, unit)
IceHUDPlayerAlternatePower.super.prototype.init(self, moduleName or "PlayerAlternatePower", "player") PlayerAlternatePower.super.prototype.init(self, moduleName or "PlayerAlternatePower", "player")
self.bTreatEmptyAsFull = true self.bTreatEmptyAsFull = true
self.power = 0 self.power = 0
@ -13,8 +13,8 @@ function IceHUDPlayerAlternatePower.prototype:init(moduleName, unit)
self.powerName = "MANA" self.powerName = "MANA"
end end
function IceHUDPlayerAlternatePower.prototype:GetDefaultSettings() function PlayerAlternatePower.prototype:GetDefaultSettings()
local settings = IceHUDPlayerAlternatePower.super.prototype.GetDefaultSettings(self) local settings = PlayerAlternatePower.super.prototype.GetDefaultSettings(self)
settings["side"] = IceCore.Side.Left settings["side"] = IceCore.Side.Left
settings["offset"] = -1 settings["offset"] = -1
@ -25,11 +25,13 @@ function IceHUDPlayerAlternatePower.prototype:GetDefaultSettings()
return settings return settings
end end
function IceHUDPlayerAlternatePower.prototype:Enable(core) function PlayerAlternatePower.prototype:Enable(core)
IceHUDPlayerAlternatePower.super.prototype.Enable(self, core) PlayerAlternatePower.super.prototype.Enable(self, core)
self:RegisterEvent("UNIT_POWER", "UpdateEvent") self:RegisterEvent(IceHUD.UnitPowerEvent, "UpdateEvent")
self:RegisterEvent("UNIT_MAXPOWER", "UpdateEvent") if IceHUD.EventExistsUnitMaxPower then
self:RegisterEvent("UNIT_MAXPOWER", "UpdateEvent")
end
self:RegisterEvent("UNIT_POWER_BAR_SHOW", "PowerBarShow") self:RegisterEvent("UNIT_POWER_BAR_SHOW", "PowerBarShow")
self:RegisterEvent("UNIT_POWER_BAR_HIDE", "PowerBarHide") self:RegisterEvent("UNIT_POWER_BAR_HIDE", "PowerBarHide")
@ -37,40 +39,50 @@ function IceHUDPlayerAlternatePower.prototype:Enable(core)
if self.maxPower == 0 then if self.maxPower == 0 then
self:Show(false) self:Show(false)
else
self.wantToShow = true
end end
if self.moduleSettings.hideBlizz then if self.moduleSettings.hideBlizz then
self:HideBlizz() self:HideBlizz()
end end
end end
function IceHUDPlayerAlternatePower.prototype:PowerBarShow(event, unit) function PlayerAlternatePower.prototype:PowerBarShow(event, unit)
if unit ~= self.unit then if unit ~= self.unit then
return return
end end
self.wantToShow = true
self:Show(true) self:Show(true)
self:Update(self.unit) self:Update(self.unit)
end end
function IceHUDPlayerAlternatePower.prototype:PowerBarHide(event, unit) function PlayerAlternatePower.prototype:PowerBarHide(event, unit)
if unit ~= self.unit then if unit ~= self.unit then
return return
end end
self.wantToShow = false
self:Show(false) self:Show(false)
self:Update(self.unit) self:Update(self.unit)
end end
function IceHUDPlayerAlternatePower.prototype:UpdateEvent(event, unit) function PlayerAlternatePower.prototype:UpdateEvent(event, unit)
self:Update(unit) self:Update(unit)
end end
function IceHUDPlayerAlternatePower.prototype:Update(unit) function PlayerAlternatePower.prototype:Update(unit)
IceHUDPlayerAlternatePower.super.prototype.Update(self) PlayerAlternatePower.super.prototype.Update(self)
if (unit and (unit ~= self.unit)) then if (unit and (unit ~= self.unit)) then
return return
end end
if IceHUD.DragonridingVigor and IceHUD.DragonridingVigor.bIsVisible then
self:Show(false)
elseif self.wantToShow then
self:Show(true)
end
self.maxPower = UnitPowerMax(self.unit, self.powerIndex) self.maxPower = UnitPowerMax(self.unit, self.powerIndex)
self.power = UnitPower(self.unit, self.powerIndex) self.power = UnitPower(self.unit, self.powerIndex)
if self.maxPower > 0 then if self.maxPower > 0 then
@ -90,8 +102,8 @@ function IceHUDPlayerAlternatePower.prototype:Update(unit)
end end
end end
function IceHUDPlayerAlternatePower.prototype:GetOptions() function PlayerAlternatePower.prototype:GetOptions()
local opts = IceHUDPlayerAlternatePower.super.prototype.GetOptions(self) local opts = PlayerAlternatePower.super.prototype.GetOptions(self)
opts["lowThresholdColor"] = nil opts["lowThresholdColor"] = nil
@ -119,15 +131,17 @@ function IceHUDPlayerAlternatePower.prototype:GetOptions()
return opts return opts
end end
function IceHUDPlayerAlternatePower.prototype:ShowBlizz() function PlayerAlternatePower.prototype:ShowBlizz()
PlayerPowerBarAlt:GetScript("OnLoad")(PlayerPowerBarAlt) PlayerPowerBarAlt:GetScript("OnLoad")(PlayerPowerBarAlt)
end end
function IceHUDPlayerAlternatePower.prototype:HideBlizz() function PlayerAlternatePower.prototype:HideBlizz()
PlayerPowerBarAlt:Hide() PlayerPowerBarAlt:Hide()
PlayerPowerBarAlt:UnregisterAllEvents() PlayerPowerBarAlt:UnregisterAllEvents()
end end
-- Load us up -- Load us up
IceHUD.PlayerAlternatePower = IceHUDPlayerAlternatePower:new() if ALTERNATE_POWER_INDEX then
IceHUD.PlayerAlternatePower = PlayerAlternatePower:new()
end

View File

@ -10,6 +10,7 @@ PlayerHealth.prototype.absorbAmount = 0
local configMode = false local configMode = false
local HealComm local HealComm
local incomingHealAmt = 0 local incomingHealAmt = 0
local groupEvent = IceHUD.EventExistsGroupRosterUpdate and "GROUP_ROSTER_UPDATE" or "PARTY_MEMBERS_CHANGED"
-- Constructor -- -- Constructor --
function PlayerHealth.prototype:init() function PlayerHealth.prototype:init()
@ -29,7 +30,7 @@ function PlayerHealth.prototype:GetDefaultSettings()
settings["hideBlizz"] = false settings["hideBlizz"] = false
settings["hideBlizzParty"] = false settings["hideBlizzParty"] = false
settings["upperText"] = "[PercentHP:Round]" settings["upperText"] = "[PercentHP:Round]"
settings["lowerText"] = "[FractionalHP:HPColor:Bracket]" settings["lowerText"] = "[FractionalHP:Short:HPColor:Bracket]"
settings["allowMouseInteraction"] = false settings["allowMouseInteraction"] = false
settings["allowMouseInteractionCombat"] = false settings["allowMouseInteractionCombat"] = false
settings["healAlpha"] = 0.6 settings["healAlpha"] = 0.6
@ -68,6 +69,9 @@ function PlayerHealth.prototype:Enable(core)
PlayerHealth.super.prototype.Enable(self, core) PlayerHealth.super.prototype.Enable(self, core)
self:RegisterEvent("UNIT_HEALTH", "UpdateEvent") self:RegisterEvent("UNIT_HEALTH", "UpdateEvent")
if IceHUD.EventExistsUnitHealthFrequent then
self:RegisterEvent("UNIT_HEALTH_FREQUENT", "UpdateEvent")
end
self:RegisterEvent("UNIT_MAXHEALTH", "UpdateEvent") self:RegisterEvent("UNIT_MAXHEALTH", "UpdateEvent")
self:RegisterEvent("PLAYER_ENTERING_WORLD", "EnteringWorld") self:RegisterEvent("PLAYER_ENTERING_WORLD", "EnteringWorld")
@ -78,14 +82,12 @@ function PlayerHealth.prototype:Enable(core)
self:RegisterEvent("PLAYER_REGEN_DISABLED", "CheckCombat") self:RegisterEvent("PLAYER_REGEN_DISABLED", "CheckCombat")
self:RegisterEvent("PARTY_LEADER_CHANGED", "CheckLeader") self:RegisterEvent("PARTY_LEADER_CHANGED", "CheckLeader")
if IceHUD.WowVer >= 50000 then self:RegisterEvent(groupEvent, "CheckLeader")
self:RegisterEvent("GROUP_ROSTER_UPDATE", "CheckLeader") if GetLFGProposal then
else self:RegisterEvent("LFG_PROPOSAL_UPDATE", "CheckPartyRole")
self:RegisterEvent("PARTY_MEMBERS_CHANGED", "CheckLeader") self:RegisterEvent("LFG_PROPOSAL_FAILED", "CheckPartyRole")
self:RegisterEvent("LFG_ROLE_UPDATE", "CheckPartyRole")
end end
self:RegisterEvent("LFG_PROPOSAL_UPDATE", "CheckPartyRole")
self:RegisterEvent("LFG_PROPOSAL_FAILED", "CheckPartyRole")
self:RegisterEvent("LFG_ROLE_UPDATE", "CheckPartyRole")
--self:RegisterEvent("PARTY_MEMBERS_CHANGED", "CheckPartyFrameStatus") --self:RegisterEvent("PARTY_MEMBERS_CHANGED", "CheckPartyFrameStatus")
@ -95,10 +97,12 @@ function PlayerHealth.prototype:Enable(core)
self:RegisterEvent("PLAYER_FLAGS_CHANGED", "CheckPvP") self:RegisterEvent("PLAYER_FLAGS_CHANGED", "CheckPvP")
self:RegisterEvent("UNIT_FACTION", "CheckPvP") self:RegisterEvent("UNIT_FACTION", "CheckPvP")
self:RegisterEvent("UNIT_ENTERED_VEHICLE", "EnteringVehicle") if UnitHasVehicleUI then
self:RegisterEvent("UNIT_EXITED_VEHICLE", "ExitingVehicle") self:RegisterEvent("UNIT_ENTERED_VEHICLE", "EnteringVehicle")
self:RegisterEvent("UNIT_EXITED_VEHICLE", "ExitingVehicle")
end
if IceHUD.WowVer < 40000 then if not IceHUD.SupportsHealPrediction then
HealComm = LibStub("LibHealComm-4.0", true) HealComm = LibStub("LibHealComm-4.0", true)
if HealComm then if HealComm then
HealComm.RegisterCallback(self, "HealComm_HealStarted", function(event, casterGUID, spellID, spellType, endTime, ...) self:HealComm_HealEvent(event, casterGUID, spellID, spellType, endTime, ...) end) HealComm.RegisterCallback(self, "HealComm_HealStarted", function(event, casterGUID, spellID, spellType, endTime, ...) self:HealComm_HealEvent(event, casterGUID, spellID, spellType, endTime, ...) end)
@ -111,7 +115,9 @@ function PlayerHealth.prototype:Enable(core)
self:RegisterEvent("UNIT_HEAL_PREDICTION", "IncomingHealPrediction") self:RegisterEvent("UNIT_HEAL_PREDICTION", "IncomingHealPrediction")
end end
self:RegisterEvent("UNIT_ABSORB_AMOUNT_CHANGED", "UpdateAbsorbAmount") if UnitGetTotalAbsorbs then
self:RegisterEvent("UNIT_ABSORB_AMOUNT_CHANGED", "UpdateAbsorbAmount")
end
if (self.moduleSettings.hideBlizz) then if (self.moduleSettings.hideBlizz) then
self:HideBlizz() self:HideBlizz()
@ -160,7 +166,7 @@ function PlayerHealth.prototype:HealComm_ModifierChanged(event, guid)
end end
function PlayerHealth.prototype:IncomingHealPrediction(event, unit) function PlayerHealth.prototype:IncomingHealPrediction(event, unit)
if IceHUD.WowVer >= 40000 then if IceHUD.SupportsHealPrediction then
if unit and unit ~= self.unit then if unit and unit ~= self.unit then
return return
end end
@ -312,7 +318,7 @@ function PlayerHealth.prototype:GetOptions()
self:Update() self:Update()
end, end,
disabled = function() disabled = function()
return not (self.moduleSettings.enabled and (IceHUD.WowVer >= 40000 or HealComm)) return not (self.moduleSettings.enabled and (IceHUD.SupportsHealPrediction or HealComm))
end, end,
order = 43.6 order = 43.6
} }
@ -358,7 +364,7 @@ function PlayerHealth.prototype:GetOptions()
self:Update() self:Update()
end, end,
disabled = function() disabled = function()
return not (self.moduleSettings.enabled and IceHUD.WowVer >= 70000) return not (self.moduleSettings.enabled and UnitGetTotalAbsorbs)
end, end,
order = 43.8 order = 43.8
} }
@ -916,36 +922,29 @@ function PlayerHealth.prototype:CreateBackground(redraw)
end end
end end
if not self.frame.button.menu then
self.frame.button.menu = function(this, unit)
IceHUD.DropdownUnit = unit
ToggleDropDownMenu(1, nil, IceHUD_UnitFrame_DropDown, "cursor")
end
end
self:EnableClickTargeting(self.moduleSettings.allowMouseInteraction) self:EnableClickTargeting(self.moduleSettings.allowMouseInteraction)
end end
function PlayerHealth.prototype:CreateHealBar() function PlayerHealth.prototype:CreateHealBar()
self.healFrame = self:BarFactory(self.healFrame, "LOW","BACKGROUND") self.healFrame = self:BarFactory(self.healFrame, "LOW","BACKGROUND", "Heal")
self.healFrame.bar:SetVertexColor(self:GetColor("PlayerHealthHealAmount", self.alpha * self.moduleSettings.healAlpha)) self.healFrame.bar:SetVertexColor(self:GetColor("PlayerHealthHealAmount", self.alpha * self.moduleSettings.healAlpha))
self:UpdateBar(1, "undef") self:UpdateBar(1, "undef")
if not self.moduleSettings.showIncomingHeals or (IceHUD.WowVer < 40000 and not HealComm) then if not self.moduleSettings.showIncomingHeals or (not IceHUD.SupportsHealPrediction and not HealComm) then
self.healFrame.bar:Hide() self.healFrame.bar:Hide()
end end
end end
function PlayerHealth.prototype:CreateAbsorbBar() function PlayerHealth.prototype:CreateAbsorbBar()
self.absorbFrame = self:BarFactory(self.absorbFrame, "LOW","BACKGROUND") self.absorbFrame = self:BarFactory(self.absorbFrame, "LOW","BACKGROUND", "Absorb")
self.absorbFrame.bar:SetVertexColor(self:GetColor("PlayerHealthAbsorbAmount", self.alpha * self.moduleSettings.absorbAlpha)) self.absorbFrame.bar:SetVertexColor(self:GetColor("PlayerHealthAbsorbAmount", self.alpha * self.moduleSettings.absorbAlpha))
self:UpdateBar(1, "undef") self:UpdateBar(1, "undef")
if not self.moduleSettings.showAbsorbs or UnitGetTotalAbsorbs == nil then if not self.moduleSettings.showAbsorbs or not UnitGetTotalAbsorbs then
self.absorbFrame.bar:Hide() self.absorbFrame.bar:Hide()
end end
end end
@ -956,7 +955,7 @@ function PlayerHealth.prototype:EnableClickTargeting(bEnable)
self.frame.button:EnableMouse(true) self.frame.button:EnableMouse(true)
self.frame.button:RegisterForClicks("AnyUp") self.frame.button:RegisterForClicks("AnyUp")
self.frame.button:SetAttribute("type1", "target") self.frame.button:SetAttribute("type1", "target")
self.frame.button:SetAttribute("type2", "menu") self.frame.button:SetAttribute("type2", "togglemenu")
self.frame.button:SetAttribute("unit", self.unit) self.frame.button:SetAttribute("unit", self.unit)
-- set up click casting -- set up click casting
@ -994,10 +993,12 @@ function PlayerHealth.prototype:EnteringWorld()
end end
function PlayerHealth.prototype:CheckVehicle() function PlayerHealth.prototype:CheckVehicle()
if UnitHasVehicleUI("player") then if UnitHasVehicleUI then
self:EnteringVehicle(nil, "player", true) if UnitHasVehicleUI("player") then
else self:EnteringVehicle(nil, "player", true)
self:ExitingVehicle(nil, "player") else
self:ExitingVehicle(nil, "player")
end
end end
end end
@ -1078,12 +1079,12 @@ function PlayerHealth.prototype:CheckPartyRole()
if configMode or IceHUD:GetIsInLFGGroup() then if configMode or IceHUD:GetIsInLFGGroup() then
if (configMode or self.moduleSettings.showPartyRoleIcon) and not self.frame.PartyRoleIcon then if (configMode or self.moduleSettings.showPartyRoleIcon) and not self.frame.PartyRoleIcon then
local isTank, isHeal, isDPS local isTank, isHeal, isDPS
local proposalExists, typeID, id, name local proposalExists, typeID, id, subtypeID, name
local texture, role, hasResponded, totalEncounters, completedEncounters, numMembers, isleader local texture, role, hasResponded, totalEncounters, completedEncounters, numMembers, isleader
proposalExists, typeID, id, name, texture, role, hasResponded, totalEncounters, completedEncounters, numMembers, isleader = GetLFGProposal() proposalExists, id, typeID, subtypeID, name, texture, role, hasResponded, totalEncounters, completedEncounters, numMembers, isleader = GetLFGProposal()
local p = self.unit local p = self.unit
if IceHUD.WowVer < 40000 then if not IceHUD.UnitGroupRolesReturnsRoleString then
isTank, isHeal, isDPS = UnitGroupRolesAssigned(p) isTank, isHeal, isDPS = UnitGroupRolesAssigned(p)
else else
local grpRole = UnitGroupRolesAssigned(p) local grpRole = UnitGroupRolesAssigned(p)
@ -1096,7 +1097,7 @@ function PlayerHealth.prototype:CheckPartyRole()
IceHUD:Debug( tostring(proposalExists) .."**".. tostring(typeID) .."**".. tostring(id) .."**".. tostring(name) .."**".. tostring(texture) .."**".. tostring(role) .."**".. tostring(hasResponded) .."**".. tostring(totalEncounters) .."**".. tostring(completedEncounters) .."**".. tostring(numMembers) .."**".. tostring(isleader) ) IceHUD:Debug( tostring(proposalExists) .."**".. tostring(typeID) .."**".. tostring(id) .."**".. tostring(name) .."**".. tostring(texture) .."**".. tostring(role) .."**".. tostring(hasResponded) .."**".. tostring(totalEncounters) .."**".. tostring(completedEncounters) .."**".. tostring(numMembers) .."**".. tostring(isleader) )
if proposalExists == true then if proposalExists == true then
IceHUD:Debug(tostring(typeID).." "..role) IceHUD:Debug(tostring(typeID).." "..(role or ""))
isTank = (role == "TANK") isTank = (role == "TANK")
isHeal = (role == "HEALER") isHeal = (role == "HEALER")
isDPS = (role == "DAMAGER") isDPS = (role == "DAMAGER")
@ -1160,7 +1161,7 @@ end
function PlayerHealth.prototype:CheckLeader() function PlayerHealth.prototype:CheckLeader()
local isLeader local isLeader
if IceHUD.WowVer >= 50000 then if UnitIsGroupLeader then
isLeader = UnitIsGroupLeader("player") isLeader = UnitIsGroupLeader("player")
else else
isLeader = IsPartyLeader() isLeader = IsPartyLeader()
@ -1268,6 +1269,8 @@ function PlayerHealth.prototype:Update(unit)
if (self.moduleSettings.scaleHealthColor) then if (self.moduleSettings.scaleHealthColor) then
color = "ScaledHealthColor" color = "ScaledHealthColor"
elseif self.moduleSettings.lowThresholdColor and self.healthPercentage <= self.moduleSettings.lowThreshold then
color = "ScaledHealthColor"
end end
if not (self.alive) then if not (self.alive) then
@ -1396,15 +1399,56 @@ end
function PlayerHealth.prototype:ShowBlizz() function PlayerHealth.prototype:ShowBlizz()
PlayerFrame:Show() PlayerFrame:SetParent(self.OriginalPlayerFrameParent or UIParent)
PlayerFrame:GetScript("OnLoad")(PlayerFrame)
end end
function PlayerHealth.prototype:HideBlizz() function PlayerHealth.prototype:HideBlizz()
PlayerFrame:Hide() if not self.PlayerFrameParent then
self.PlayerFrameParent = CreateFrame("Frame")
self.PlayerFrameParent:Hide()
end
PlayerFrame:UnregisterAllEvents() self.OriginalPlayerFrameParent = PlayerFrame:GetParent()
PlayerFrame:SetParent(self.PlayerFrameParent)
end
local parents = {}
local hide_frame = IceHUD:OutOfCombatWrapper(function(self) self:Hide() end)
local function hook_frames(...)
for i = 1, select("#", ...) do
local frame = select(i, ...)
frame:UnregisterAllEvents()
if not IceHUD:IsHooked(frame, "OnShow") then
IceHUD:SecureHookScript(frame, "OnShow", hide_frame)
end
frame:Hide()
end
end
local function unhook_frame(frame)
if IceHUD:IsHooked(frame, "OnShow") then
IceHUD:Unhook(frame, "OnShow")
local parent = parents[frame]
if parent then
frame:SetParent(parent)
end
elseif IceHUD:IsHooked(frame, "Show") then
IceHUD:Unhook(frame, "Show")
IceHUD:Unhook(frame, "SetPoint")
end
end
local function unhook_frames(...)
for i = 1, select("#", ...) do
local frame = select(i, ...)
unhook_frame(frame)
local handler = frame:GetScript("OnLoad")
if handler then
handler(frame)
end
end
end end
function PlayerHealth.prototype:HideBlizzardParty() function PlayerHealth.prototype:HideBlizzardParty()
@ -1413,37 +1457,34 @@ function PlayerHealth.prototype:HideBlizzardParty()
return return
end end
-- Both Pitbull 4 and Xperl use these exact code, so we use it too. if PartyFrame then
for i = 1, MAX_PARTY_MEMBERS do PartyFrame:Hide()
local party = _G['PartyMemberFrame'..i] PartyFrame:UnregisterEvent(groupEvent)
party:UnregisterAllEvents() else
party:Hide() for i = 1, MAX_PARTY_MEMBERS do
party.Show = function() end local frame = _G["PartyMemberFrame" .. i]
frame:SetAttribute("statehidden", true)
hook_frames(frame)
end
UIParent:UnregisterEvent(groupEvent)
end end
UIParent:UnregisterEvent('RAID_ROSTER_UPDATE')
end end
function PlayerHealth.prototype:ShowBlizzardParty() function PlayerHealth.prototype:ShowBlizzardParty()
-- Both Pitbull 4 and Xperl use these exact code, so we use it too. if PartyFrame then
for i = 1, MAX_PARTY_MEMBERS do PartyFrame:Show()
local frame = _G["PartyMemberFrame"..i] PartyFrame:Layout()
if frame then PartyFrame:RegisterEvent(groupEvent)
frame.Show = nil else
frame:GetScript("OnLoad")(frame) for i = 1, MAX_PARTY_MEMBERS do
if IceHUD.WowVer >= 50000 then local frame = _G["PartyMemberFrame" .. i]
frame:GetScript("OnEvent")(frame, "GROUP_ROSTER_UPDATE") frame:SetAttribute("statehidden", nil)
else unhook_frames(frame)
frame:GetScript("OnEvent")(frame, "PARTY_MEMBERS_CHANGED") frame:GetScript("OnEvent")(frame, groupEvent)
end
PartyMemberFrame_UpdateMember(frame)
end end
UIParent:RegisterEvent(groupEvent)
end end
UIParent:RegisterEvent("RAID_ROSTER_UPDATE")
end end
--function PlayerHealth.prototype:ShowBlizzParty() --function PlayerHealth.prototype:ShowBlizzParty()

View File

@ -115,15 +115,33 @@ end
function PlayerInfo.prototype:ShowBlizz() function PlayerInfo.prototype:ShowBlizz()
BuffFrame:Show() BuffFrame:Show()
TemporaryEnchantFrame:Show() if DebuffFrame then
DebuffFrame:Show()
DebuffFrame:GetScript("OnLoad")(DebuffFrame)
if DebuffFrame.Update then
DebuffFrame:Update()
end
end
if TemporaryEnchantFrame then
TemporaryEnchantFrame:Show()
end
BuffFrame:GetScript("OnLoad")(BuffFrame) BuffFrame:GetScript("OnLoad")(BuffFrame)
if BuffFrame.Update then
BuffFrame:Update()
end
end end
function PlayerInfo.prototype:HideBlizz() function PlayerInfo.prototype:HideBlizz()
BuffFrame:Hide() BuffFrame:Hide()
TemporaryEnchantFrame:Hide() if DebuffFrame then
DebuffFrame:Hide()
DebuffFrame:UnregisterAllEvents()
end
if TemporaryEnchantFrame then
TemporaryEnchantFrame:Hide()
end
BuffFrame:UnregisterAllEvents() BuffFrame:UnregisterAllEvents()
end end

View File

@ -3,6 +3,29 @@ local PlayerMana = IceCore_CreateClass(IceUnitBar)
local IceHUD = _G.IceHUD local IceHUD = _G.IceHUD
local SPELL_POWER_MANA = SPELL_POWER_MANA
local SPELL_POWER_RAGE = SPELL_POWER_RAGE
local SPELL_POWER_FOCUS = SPELL_POWER_FOCUS
local SPELL_POWER_ENERGY = SPELL_POWER_ENERGY
local SPELL_POWER_RUNIC_POWER = SPELL_POWER_RUNIC_POWER
local SPELL_POWER_INSANITY = SPELL_POWER_INSANITY
local SPELL_POWER_FURY = SPELL_POWER_FURY
local SPELL_POWER_MAELSTROM = SPELL_POWER_MAELSTROM
local SPELL_POWER_PAIN = SPELL_POWER_PAIN
local SPELL_POWER_LUNAR_POWER = SPELL_POWER_LUNAR_POWER
if Enum and Enum.PowerType then
SPELL_POWER_MANA = Enum.PowerType.Mana
SPELL_POWER_RAGE = Enum.PowerType.Rage
SPELL_POWER_FOCUS = Enum.PowerType.Focus
SPELL_POWER_ENERGY = Enum.PowerType.Energy
SPELL_POWER_RUNIC_POWER = Enum.PowerType.RunicPower
SPELL_POWER_INSANITY = Enum.PowerType.Insanity
SPELL_POWER_FURY = Enum.PowerType.Fury
SPELL_POWER_MAELSTROM = Enum.PowerType.Maelstrom
SPELL_POWER_PAIN = Enum.PowerType.Pain
SPELL_POWER_LUNAR_POWER = Enum.PowerType.LunarPower
end
PlayerMana.prototype.manaType = nil PlayerMana.prototype.manaType = nil
PlayerMana.prototype.tickStart = nil PlayerMana.prototype.tickStart = nil
PlayerMana.prototype.previousEnergy = nil PlayerMana.prototype.previousEnergy = nil
@ -18,9 +41,9 @@ function PlayerMana.prototype:init()
self:SetDefaultColor("PlayerRunicPower", 62, 54, 152) self:SetDefaultColor("PlayerRunicPower", 62, 54, 152)
if IceHUD.WowVer >= 70000 then if IceHUD.WowVer >= 70000 then
self:SetDefaultColor("PlayerInsanity", 150, 50, 255) self:SetDefaultColor("PlayerInsanity", 150, 50, 255)
self:SetDefaultColor("PlayerFury", 255, 50, 255) self:SetDefaultColor("PlayerFury", 201, 66, 253)
self:SetDefaultColor("PlayerMaelstrom", 62, 54, 152) self:SetDefaultColor("PlayerMaelstrom", 62, 54, 152)
self:SetDefaultColor("PlayerPain", 255, 50, 255) self:SetDefaultColor("PlayerPain", 255, 156, 0)
end end
end end
@ -34,7 +57,7 @@ function PlayerMana.prototype:GetDefaultSettings()
settings["tickerEnabled"] = true settings["tickerEnabled"] = true
settings["tickerAlpha"] = 0.5 settings["tickerAlpha"] = 0.5
settings["upperText"] = "[PercentMP:Round]" settings["upperText"] = "[PercentMP:Round]"
settings["lowerText"] = "[FractionalMP:PowerColor]" settings["lowerText"] = "[FractionalMP:Short:PowerColor]"
return settings return settings
end end
@ -130,9 +153,11 @@ function PlayerMana.prototype:Enable(core)
self:CreateTickerFrame() self:CreateTickerFrame()
if IceHUD.WowVer >= 40000 then if not IceHUD.PerPowerEventsExist then
self:RegisterEvent("UNIT_POWER", "UpdateEvent") self:RegisterEvent(IceHUD.UnitPowerEvent, "UpdateEvent")
self:RegisterEvent("UNIT_MAXPOWER", "UpdateEvent") if IceHUD.EventExistsUnitMaxPower then
self:RegisterEvent("UNIT_MAXPOWER", "UpdateEvent")
end
else else
self:RegisterEvent("UNIT_MAXMANA", "UpdateEvent") self:RegisterEvent("UNIT_MAXMANA", "UpdateEvent")
self:RegisterEvent("UNIT_MAXRAGE", "UpdateEvent") self:RegisterEvent("UNIT_MAXRAGE", "UpdateEvent")
@ -145,8 +170,10 @@ function PlayerMana.prototype:Enable(core)
self:RegisterEvent("UNIT_RUNIC_POWER", "UpdateEvent") self:RegisterEvent("UNIT_RUNIC_POWER", "UpdateEvent")
end end
self:RegisterEvent("UNIT_ENTERED_VEHICLE", "EnteringVehicle") if UnitHasVehicleUI then
self:RegisterEvent("UNIT_EXITED_VEHICLE", "ExitingVehicle") self:RegisterEvent("UNIT_ENTERED_VEHICLE", "EnteringVehicle")
self:RegisterEvent("UNIT_EXITED_VEHICLE", "ExitingVehicle")
end
self:RegisterEvent("PLAYER_ENTERING_WORLD", "EnteringWorld") self:RegisterEvent("PLAYER_ENTERING_WORLD", "EnteringWorld")
if not self.CustomOnUpdate then if not self.CustomOnUpdate then
@ -166,15 +193,17 @@ function PlayerMana.prototype:EnteringWorld()
end end
function PlayerMana.prototype:CheckVehicle() function PlayerMana.prototype:CheckVehicle()
if UnitHasVehicleUI("player") then if UnitHasVehicleUI then
self:EnteringVehicle(nil, "player", true) if UnitHasVehicleUI("player") then
else self:EnteringVehicle(nil, "player", true)
self:ExitingVehicle(nil, "player") else
self:ExitingVehicle(nil, "player")
end
end end
end end
function PlayerMana.prototype:ShouldUseTicker() function PlayerMana.prototype:ShouldUseTicker()
return IceHUD.WowVer < 30000 or (IceHUD.WowVer < 70100 and not GetCVarBool("predictedPower")) return IceHUD.WowVer < 30000 or (IceHUD.WowVer < 70100 and not GetCVarBool("predictedPower") and not IceHUD.WowClassicWrath)
end end
function PlayerMana.prototype:SetupOnUpdate(enable) function PlayerMana.prototype:SetupOnUpdate(enable)
@ -251,7 +280,7 @@ function PlayerMana.prototype:ManaType(event, unit)
if self:ShouldUseTicker() then if self:ShouldUseTicker() then
-- register ticker for rogue energy -- register ticker for rogue energy
if (self.moduleSettings.tickerEnabled and (self.manaType == SPELL_POWER_ENERGY) and self.alive) then if self.moduleSettings.tickerEnabled and self.manaType == SPELL_POWER_ENERGY then
self.tickerFrame:Show() self.tickerFrame:Show()
self.tickerFrame:SetScript("OnUpdate", function() self:EnergyTick() end) self.tickerFrame:SetScript("OnUpdate", function() self:EnergyTick() end)
else else
@ -271,6 +300,14 @@ function PlayerMana.prototype:TreatEmptyAsFull()
or self.manaType == SPELL_POWER_FURY or self.manaType == SPELL_POWER_PAIN or self.manaType == SPELL_POWER_MAELSTROM)) or self.manaType == SPELL_POWER_FURY or self.manaType == SPELL_POWER_PAIN or self.manaType == SPELL_POWER_MAELSTROM))
end end
function PlayerMana.prototype:IsFull(scale)
if IceHUD.WowVer >= 80000 and self.manaType == SPELL_POWER_LUNAR_POWER and IsPlayerSpell(202430) then
return scale - 0.5 >= 0
end
return PlayerMana.super.prototype.IsFull(self, scale)
end
function PlayerMana.prototype:UpdateEvent(event, unit, powertype) function PlayerMana.prototype:UpdateEvent(event, unit, powertype)
self:Update(unit, powertype) self:Update(unit, powertype)
end end
@ -307,6 +344,8 @@ function PlayerMana.prototype:Update(unit, powertype)
color = "Dead" color = "Dead"
elseif (self.moduleSettings.scaleManaColor and (UnitPowerType(self.unit) == SPELL_POWER_MANA or self.moduleSettings.scaleManaColorForAll)) then elseif (self.moduleSettings.scaleManaColor and (UnitPowerType(self.unit) == SPELL_POWER_MANA or self.moduleSettings.scaleManaColorForAll)) then
color = "ScaledManaColor" color = "ScaledManaColor"
elseif self.moduleSettings.lowThresholdColor and self.manaPercentage <= self.moduleSettings.lowThreshold then
color = "ScaledManaColor"
else else
if (self.manaType == SPELL_POWER_RAGE) then if (self.manaType == SPELL_POWER_RAGE) then
color = "PlayerRage" color = "PlayerRage"
@ -316,13 +355,13 @@ function PlayerMana.prototype:Update(unit, powertype)
color = "PlayerRunicPower" color = "PlayerRunicPower"
elseif (self.manaType == SPELL_POWER_FOCUS) then elseif (self.manaType == SPELL_POWER_FOCUS) then
color = "PlayerFocus" color = "PlayerFocus"
elseif (IceHUD.WowVer >= 70000 and self.manaType == SPELL_POWER_INSANITY) then elseif (self.manaType == SPELL_POWER_INSANITY) then
color = "PlayerInsanity" color = "PlayerInsanity"
elseif (IceHUD.WowVer >= 70000 and self.manaType == SPELL_POWER_FURY) then elseif (self.manaType == SPELL_POWER_FURY) then
color = "PlayerFury" color = "PlayerFury"
elseif (IceHUD.WowVer >= 70000 and self.manaType == SPELL_POWER_MAELSTROM) then elseif (self.manaType == SPELL_POWER_MAELSTROM) then
color = "PlayerMaelstrom" color = "PlayerMaelstrom"
elseif (IceHUD.WowVer >= 70000 and self.manaType == SPELL_POWER_PAIN) then elseif (self.manaType == SPELL_POWER_PAIN) then
color = "PlayerPain" color = "PlayerPain"
end end
end end
@ -350,7 +389,7 @@ function PlayerMana.prototype:Update(unit, powertype)
if not IceHUD.IceCore:ShouldUseDogTags() then if not IceHUD.IceCore:ShouldUseDogTags() then
-- extra hack for whiny rogues (are there other kind?) -- extra hack for whiny rogues (are there other kind?)
local displayPercentage = self.manaPercentage local displayPercentage = self.manaPercentage
if (self.manaType == SPELL_POWER_ENERGY) then if self.manaType == SPELL_POWER_ENERGY or self.manaType == SPELL_POWER_FOCUS or self.manaType == SPELL_POWER_FURY then
displayPercentage = self.mana displayPercentage = self.mana
else else
displayPercentage = math.floor(displayPercentage * 100) displayPercentage = math.floor(displayPercentage * 100)
@ -382,17 +421,17 @@ function PlayerMana.prototype:UpdateEnergy(event, unit)
return return
end end
self.previousEnergy = UnitPower(self.unit, UnitPowerType(self.unit))
if IceHUD.WowVer < 40000 then
self:Update(unit)
end
if self:ShouldUseTicker() and if self:ShouldUseTicker() and
((not (self.previousEnergy) or (self.previousEnergy <= UnitPower(self.unit, UnitPowerType(self.unit)))) and ((not (self.previousEnergy) or (self.previousEnergy < UnitPower(self.unit, UnitPowerType(self.unit)))) and
(self.moduleSettings.tickerEnabled) and self.manaType == SPELL_POWER_ENERGY) then (self.moduleSettings.tickerEnabled) and self.manaType == SPELL_POWER_ENERGY) then
self.tickStart = GetTime() self.tickStart = GetTime()
self.tickerFrame:Show() self.tickerFrame:Show()
end end
self.previousEnergy = UnitPower(self.unit, UnitPowerType(self.unit))
if IceHUD.WowVer < 40000 then
self:Update(unit)
end
end end
@ -401,7 +440,7 @@ function PlayerMana.prototype:EnergyTick()
return return
end end
if not (self.tickStart) then if not self.tickStart or not self.alive then
self.tickerFrame:Hide() self.tickerFrame:Hide()
return return
end end
@ -436,7 +475,7 @@ function PlayerMana.prototype:CreateTickerFrame()
self.tickerFrame = CreateFrame("Frame", nil, self.barFrame) self.tickerFrame = CreateFrame("Frame", nil, self.barFrame)
end end
self.tickerFrame:SetFrameStrata("BACKGROUND") self.tickerFrame:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
self.tickerFrame:SetWidth(self.settings.barWidth) self.tickerFrame:SetWidth(self.settings.barWidth)
self.tickerFrame:SetHeight(self.settings.barHeight) self.tickerFrame:SetHeight(self.settings.barHeight)

View File

@ -11,7 +11,7 @@ function RangeCheck.prototype:init()
self.scalingEnabled = true self.scalingEnabled = true
LibRange = LibStub("LibRangeCheck-2.0", true) LibRange = LibStub("LibRangeCheck-3.0", true)
end end
function RangeCheck.prototype:Enable(core) function RangeCheck.prototype:Enable(core)
@ -126,7 +126,7 @@ function RangeCheck.prototype:CreateFrame(redraw)
end end
self.frame:SetScale(self.moduleSettings.scale) self.frame:SetScale(self.moduleSettings.scale)
self.frame:SetFrameStrata("BACKGROUND") self.frame:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
self.frame:SetWidth(200) self.frame:SetWidth(200)
self.frame:SetHeight(32) self.frame:SetHeight(32)
self.frame:ClearAllPoints() self.frame:ClearAllPoints()

View File

@ -4,6 +4,25 @@ local Resolve = IceCore_CreateClass(IceUnitBar)
local RESOLVE_SPELL_ID = 158300 local RESOLVE_SPELL_ID = 158300
local RESOLVE_MAX = 240 local RESOLVE_MAX = 240
local GetSpellInfo = GetSpellInfo
if not GetSpellInfo and C_Spell and C_Spell.GetSpellInfo then
GetSpellInfo = function(spellID)
if not spellID then
return nil
end
local spellInfo = C_Spell.GetSpellInfo(spellID)
if spellInfo then
return spellInfo.name, nil, spellInfo.iconID, spellInfo.castTime, spellInfo.minRange, spellInfo.maxRange, spellInfo.spellID, spellInfo.originalIconID
end
end
end
local GetSpellName = GetSpellInfo
if C_Spell and C_Spell.GetSpellName then
GetSpellName = C_Spell.GetSpellName
end
Resolve.prototype.current = nil Resolve.prototype.current = nil
Resolve.prototype.max = RESOLVE_MAX Resolve.prototype.max = RESOLVE_MAX
@ -49,14 +68,19 @@ end
-- scan the tooltip and extract the Resolve value -- scan the tooltip and extract the Resolve value
do do
local spellName = GetSpellInfo(RESOLVE_SPELL_ID) local spellName = GetSpellName(RESOLVE_SPELL_ID)
function Resolve.prototype:UpdateCurrent(event, unit) function Resolve.prototype:UpdateCurrent(event, unit)
if (unit and (unit ~= self.unit)) then if (unit and (unit ~= self.unit)) then
return return
end end
self.current = select(15, UnitAura(self.unit, spellName)) or 0 if UnitAura then
self.current = select(IceHUD.SpellFunctionsReturnRank and 15 or 14, UnitAura(self.unit, spellName)) or 0
else
local auraInfo = C_UnitAuras.GetAuraDataBySpellName(self.unit, spellName)
self.current = auraInfo and auraInfo.timeMod or 0
end
self:Update() self:Update()
end end
@ -79,7 +103,7 @@ end
-- Load for tanks only -- Load for tanks only
local _, unitClass = UnitClass("player") local _, unitClass = UnitClass("player")
if ((unitClass == "DEATHKNIGHT" or unitClass == "DRUID" or unitClass == "PALADIN" or unitClass == "WARRIOR" or unitClass == "MONK") if (unitClass == "DEATHKNIGHT" or unitClass == "DRUID" or unitClass == "PALADIN" or unitClass == "WARRIOR" or unitClass == "MONK")
and IceHUD.WowVer >= 60000 and IceHUD.WowVer < 70000) then and GetSpellName(RESOLVE_SPELL_ID) then
IceHUD.Resolve = Resolve:new() IceHUD.Resolve = Resolve:new()
end end

View File

@ -9,6 +9,8 @@ local maxComboPoints = 5
local rtbEndTime = 0 local rtbEndTime = 0
local rtbDuration = 0 local rtbDuration = 0
local rtbCount = 0 local rtbCount = 0
local sixComboPointsTalentID = 19240
local behaviorDependsOnComboPoints = IceHUD.WowVer < 90000
local CurrMaxRtBDuration = 0 local CurrMaxRtBDuration = 0
local PotentialRtBDuration = 0 local PotentialRtBDuration = 0
@ -19,6 +21,42 @@ for _, v in ipairs(RtBBuffs) do
RtBSet[v] = true RtBSet[v] = true
end end
local SPELL_POWER_COMBO_POINTS = SPELL_POWER_COMBO_POINTS
if Enum and Enum.PowerType then
SPELL_POWER_COMBO_POINTS = Enum.PowerType.ComboPoints
end
local GetSpellInfo = GetSpellInfo
if not GetSpellInfo and C_Spell and C_Spell.GetSpellInfo then
GetSpellInfo = function(spellID)
if not spellID then
return nil
end
local spellInfo = C_Spell.GetSpellInfo(spellID)
if spellInfo then
return spellInfo.name, nil, spellInfo.iconID, spellInfo.castTime, spellInfo.minRange, spellInfo.maxRange, spellInfo.spellID, spellInfo.originalIconID
end
end
end
local GetSpellName = GetSpellInfo
if C_Spell and C_Spell.GetSpellName then
GetSpellName = C_Spell.GetSpellName
end
local UnitBuff = UnitBuff
if not UnitBuff and C_UnitAuras and AuraUtil then
UnitBuff = function(unitToken, index, filter)
local auraData = C_UnitAuras.GetBuffDataByIndex(unitToken, index, filter)
if not auraData then
return nil
end
return AuraUtil.UnpackAuraData(auraData)
end
end
-- Constructor -- -- Constructor --
function RollTheBones.prototype:init() function RollTheBones.prototype:init()
RollTheBones.super.prototype.init(self, "RollTheBones", "player") RollTheBones.super.prototype.init(self, "RollTheBones", "player")
@ -28,10 +66,14 @@ function RollTheBones.prototype:init()
self.moduleSettings.shouldAnimate = false self.moduleSettings.shouldAnimate = false
self:SetDefaultColor("RollTheBones", 1, 0.6, 0.2) self:SetDefaultColor("RollTheBones", 1, 0.6, 0.2)
self:SetDefaultColor("RollTheBones2", 0.75, 1, 0.2) if behaviorDependsOnComboPoints then
self:SetDefaultColor("RollTheBones3", 0.4, 1, 0.2) self:SetDefaultColor("RollTheBones2", 0.75, 1, 0.2)
self:SetDefaultColor("RollTheBones6", 0.1, 1, 0.7) self:SetDefaultColor("RollTheBones3", 0.4, 1, 0.2)
self:SetDefaultColor("RollTheBonesPotential", 1, 1, 1) self:SetDefaultColor("RollTheBones4", 0.4, 1, 0.2)
self:SetDefaultColor("RollTheBones5", 0.1, 1, 0.7)
self:SetDefaultColor("RollTheBones6", 0.1, 1, 0.7)
self:SetDefaultColor("RollTheBonesPotential", 1, 1, 1)
end
self.bTreatEmptyAsFull = true self.bTreatEmptyAsFull = true
end end
@ -43,7 +85,10 @@ function RollTheBones.prototype:Enable(core)
RollTheBones.super.prototype.Enable(self, core) RollTheBones.super.prototype.Enable(self, core)
self:RegisterEvent("UNIT_AURA", "UpdateRollTheBones") self:RegisterEvent("UNIT_AURA", "UpdateRollTheBones")
self:RegisterEvent("UNIT_POWER", "ComboPointsChanged")
if behaviorDependsOnComboPoints then
self:RegisterEvent(IceHUD.UnitPowerEvent, "ComboPointsChanged")
end
if not self.moduleSettings.alwaysFullAlpha then if not self.moduleSettings.alwaysFullAlpha then
self:Show(false) self:Show(false)
@ -59,7 +104,7 @@ function RollTheBones.prototype:Disable(core)
end end
function RollTheBones.prototype:ComboPointsChanged(...) function RollTheBones.prototype:ComboPointsChanged(...)
if select('#', ...) >= 3 and select(1, ...) == "UNIT_POWER" and select(3, ...) ~= "COMBO_POINTS" then if select('#', ...) >= 3 and select(1, ...) == IceHUD.UnitPowerEvent and select(3, ...) ~= "COMBO_POINTS" then
return return
end end
@ -99,41 +144,60 @@ function RollTheBones.prototype:GetOptions()
opts["textSettings"].args["upperTextString"]["desc"] = "The text to display under this bar. # will be replaced with the number of Roll the Bones seconds remaining." opts["textSettings"].args["upperTextString"]["desc"] = "The text to display under this bar. # will be replaced with the number of Roll the Bones seconds remaining."
opts["textSettings"].args["upperTextString"].hidden = false opts["textSettings"].args["upperTextString"].hidden = false
opts["showAsPercentOfMax"] = if behaviorDependsOnComboPoints then
{ opts["showAsPercentOfMax"] =
type = 'toggle', {
name = L["Show bar as % of maximum"], type = 'toggle',
desc = L["If this is checked, then the RtB buff time shows as a percent of the maximum attainable (taking set bonuses and talents into account). Otherwise, the bar always goes from full to empty when applying RtB no matter the duration."], name = L["Show bar as % of maximum"],
get = function() desc = L["If this is checked, then the RtB buff time shows as a percent of the maximum attainable (taking set bonuses and talents into account). Otherwise, the bar always goes from full to empty when applying RtB no matter the duration."],
return self.moduleSettings.showAsPercentOfMax get = function()
end, return self.moduleSettings.showAsPercentOfMax
set = function(info, v) end,
self.moduleSettings.showAsPercentOfMax = v set = function(info, v)
end, self.moduleSettings.showAsPercentOfMax = v
disabled = function() end,
return not self.moduleSettings.enabled disabled = function()
end return not self.moduleSettings.enabled
} end
}
opts["durationAlpha"] = opts["durationAlpha"] =
{ {
type = "range", type = "range",
name = L["Potential RtB time bar alpha"], name = L["Potential RtB time bar alpha"],
desc = L["What alpha value to use for the bar that displays how long your RtB will last if you activate it. (This gets multiplied by the bar's current alpha to stay in line with the bar on top of it)"], desc = L["What alpha value to use for the bar that displays how long your RtB will last if you activate it. (This gets multiplied by the bar's current alpha to stay in line with the bar on top of it)"],
min = 0, min = 0,
max = 100, max = 100,
step = 5, step = 5,
get = function() get = function()
return self.moduleSettings.durationAlpha * 100 return self.moduleSettings.durationAlpha * 100
end, end,
set = function(info, v) set = function(info, v)
self.moduleSettings.durationAlpha = v / 100.0 self.moduleSettings.durationAlpha = v / 100.0
self:Redraw() self:Redraw()
end, end,
disabled = function() disabled = function()
return not self.moduleSettings.enabled return not self.moduleSettings.enabled
end end
} }
opts["bUseMultipleBuffColors"] =
{
type = 'toggle',
name = L["Use multiple buff colors"],
desc = L["If this is checked, then the bar uses different colors depending on how many RtB buffs you have"],
get = function()
return self.moduleSettings.bUseMultipleBuffColors
end,
set = function(info, v)
self.moduleSettings.bUseMultipleBuffColors = v
self:Redraw()
end,
disabled = function()
return not self.moduleSettings.enabled
end,
}
end
opts["bShowWithNoTarget"] = opts["bShowWithNoTarget"] =
{ {
@ -152,23 +216,6 @@ function RollTheBones.prototype:GetOptions()
end, end,
} }
opts["bUseMultipleBuffColors"] =
{
type = 'toggle',
name = L["Use multiple buff colors"],
desc = L["If this is checked, then the bar uses different colors depending on how many RtB buffs you have"],
get = function()
return self.moduleSettings.bUseMultipleBuffColors
end,
set = function(info, v)
self.moduleSettings.bUseMultipleBuffColors = v
self:Redraw()
end,
disabled = function()
return not self.moduleSettings.enabled
end,
}
return opts return opts
end end
@ -179,7 +226,11 @@ function RollTheBones.prototype:CreateFrame()
end end
function RollTheBones.prototype:CreateDurationBar() function RollTheBones.prototype:CreateDurationBar()
self.durationFrame = self:BarFactory(self.durationFrame, "BACKGROUND","ARTWORK") if not behaviorDependsOnComboPoints then
return
end
self.durationFrame = self:BarFactory(self.durationFrame, "BACKGROUND","ARTWORK", "Duration")
-- Rokiyo: Do we need to call this here? -- Rokiyo: Do we need to call this here?
self.CurrScale = 0 self.CurrScale = 0
@ -197,7 +248,9 @@ end
function RollTheBones.prototype:RotateHorizontal() function RollTheBones.prototype:RotateHorizontal()
RollTheBones.super.prototype.RotateHorizontal(self) RollTheBones.super.prototype.RotateHorizontal(self)
self:RotateFrame(self.durationFrame) if self.durationFrame then
self:RotateFrame(self.durationFrame)
end
end end
function RollTheBones.prototype:ResetRotation() function RollTheBones.prototype:ResetRotation()
@ -212,8 +265,12 @@ end
function RollTheBones.prototype:GetBuffDuration(unitName, ids) function RollTheBones.prototype:GetBuffDuration(unitName, ids)
local i = 1 local i = 1
local buff, rank, texture, type, duration, endTime, remaining, spellId local buff, _, type, duration, endTime, spellId
buff, _, _, _, type, duration, endTime, _, _, _, spellId = UnitBuff(unitName, i) if IceHUD.SpellFunctionsReturnRank then
buff, _, _, _, type, duration, endTime, _, _, _, spellId = UnitBuff(unitName, i)
else
buff, _, _, type, duration, endTime, _, _, _, spellId = UnitBuff(unitName, i)
end
local realDuration, remaining, count local realDuration, remaining, count
local now = GetTime() local now = GetTime()
@ -230,7 +287,11 @@ function RollTheBones.prototype:GetBuffDuration(unitName, ids)
i = i + 1; i = i + 1;
buff, _, _, _, type, duration, endTime, _, _, _, spellId = UnitBuff(unitName, i) if IceHUD.SpellFunctionsReturnRank then
buff, _, _, _, type, duration, endTime, _, _, _, spellId = UnitBuff(unitName, i)
else
buff, _, _, type, duration, endTime, _, _, _, spellId = UnitBuff(unitName, i)
end
end end
@ -244,7 +305,7 @@ end
function RollTheBones.prototype:MyOnUpdate() function RollTheBones.prototype:MyOnUpdate()
RollTheBones.super.prototype.MyOnUpdate(self) RollTheBones.super.prototype.MyOnUpdate(self)
if self.bUpdateRtb then if self.bUpdateRtb then
self:UpdateRollTheBones(nil, self.unit, true) self:UpdateRollTheBones("internal", self.unit)
end end
if self.target or self.moduleSettings.bShowWithNoTarget then if self.target or self.moduleSettings.bShowWithNoTarget then
self:UpdateDurationBar() self:UpdateDurationBar()
@ -258,21 +319,22 @@ end
-- use this to figure out if Roll the Bones is available or not. neither IsSpellKnown nor IsPlayerSpell are correct for it -- use this to figure out if Roll the Bones is available or not. neither IsSpellKnown nor IsPlayerSpell are correct for it
-- when SnD is known, but this is. -- when SnD is known, but this is.
local function HasSpell(id) local function HasSpell(id)
local spell = GetSpellInfo(id) local spell = GetSpellName(id)
return spell == GetSpellInfo(spell) return spell == GetSpellName(spell)
end end
local function ShouldHide() local function ShouldHide()
return not HasSpell(193316) return not HasSpell(193316)
end end
function RollTheBones.prototype:UpdateRollTheBones(event, unit, fromUpdate) function RollTheBones.prototype:UpdateRollTheBones(event, unit)
if unit and unit ~= self.unit then if unit and unit ~= self.unit then
return return
end end
local now = GetTime() local now = GetTime()
local remaining = nil local remaining = nil
local fromUpdate = event == "internal"
if not fromUpdate then if not fromUpdate then
rtbDuration, remaining, rtbCount = self:GetBuffDuration(self.unit, RtBSet) rtbDuration, remaining, rtbCount = self:GetBuffDuration(self.unit, RtBSet)
@ -293,7 +355,7 @@ function RollTheBones.prototype:UpdateRollTheBones(event, unit, fromUpdate)
if not remaining then if not remaining then
remaining = rtbEndTime - now remaining = rtbEndTime - now
end end
local denominator = (self.moduleSettings.showAsPercentOfMax and CurrMaxRtBDuration or rtbDuration) local denominator = ((self.moduleSettings.showAsPercentOfMax and behaviorDependsOnComboPoints) and CurrMaxRtBDuration or rtbDuration)
self:UpdateBar(denominator ~= 0 and remaining / denominator or 0, self:GetColorName(rtbCount)) self:UpdateBar(denominator ~= 0 and remaining / denominator or 0, self:GetColorName(rtbCount))
else else
self:UpdateBar(0, "RollTheBones") self:UpdateBar(0, "RollTheBones")
@ -311,13 +373,13 @@ function RollTheBones.prototype:UpdateRollTheBones(event, unit, fromUpdate)
-- somewhat redundant, but we also need to check potential remaining time -- somewhat redundant, but we also need to check potential remaining time
if (remaining ~= nil) or PotentialRtBDuration > 0 then if (remaining ~= nil) or PotentialRtBDuration > 0 then
local potText = " (" .. PotentialRtBDuration .. ")" local potText = behaviorDependsOnComboPoints and " (" .. PotentialRtBDuration .. ")" or ""
self:SetBottomText1(self.moduleSettings.upperText .. tostring(floor(remaining or 0)) .. (self.moduleSettings.durationAlpha ~= 0 and potText or "")) self:SetBottomText1(self.moduleSettings.upperText .. tostring(floor(remaining or 0)) .. (self.moduleSettings.durationAlpha ~= 0 and potText or ""))
end end
end end
function RollTheBones.prototype:GetColorName(count) function RollTheBones.prototype:GetColorName(count)
if self.moduleSettings.bUseMultipleBuffColors and count >= 2 then if behaviorDependsOnComboPoints and self.moduleSettings.bUseMultipleBuffColors and count >= 2 then
return "RollTheBones"..count return "RollTheBones"..count
else else
return "RollTheBones" return "RollTheBones"
@ -337,19 +399,27 @@ function RollTheBones.prototype:TargetChanged()
end end
function RollTheBones.prototype:UpdateDurationBar(event, unit) function RollTheBones.prototype:UpdateDurationBar(event, unit)
if not self.durationFrame then
return
end
if unit and unit ~= self.unit then if unit and unit ~= self.unit then
return return
end end
local points = RTBGetComboPoints(self.unit) local points = RTBGetComboPoints(self.unit)
-- check for Deeper Stratagem if UnitPowerMax then
local _, _, _, DeeperStratagem = GetTalentInfo(3, 1, 1) CurrMaxRtBDuration = self:GetMaxBuffTime(UnitPowerMax(self.unit, SPELL_POWER_COMBO_POINTS))
if DeeperStratagem then
-- first, set the cached upper limit of RtB duration
CurrMaxRtBDuration = self:GetMaxBuffTime(maxComboPoints + 1)
else else
CurrMaxRtBDuration = self:GetMaxBuffTime(maxComboPoints) -- check for Deeper Stratagem
local _, _, _, DeeperStratagem = GetTalentInfoByID(sixComboPointsTalentID, GetActiveSpecGroup())
if DeeperStratagem then
-- first, set the cached upper limit of RtB duration
CurrMaxRtBDuration = self:GetMaxBuffTime(maxComboPoints + 1)
else
CurrMaxRtBDuration = self:GetMaxBuffTime(maxComboPoints)
end
end end
if event then if event then

View File

@ -3,22 +3,24 @@ local Runes = IceCore_CreateClass(IceElement)
local IceHUD = _G.IceHUD local IceHUD = _G.IceHUD
local RunesReturnedByMaxPower = IceHUD.WowVer >= 70000
local CooldownFrame_SetTimer = CooldownFrame_SetTimer local CooldownFrame_SetTimer = CooldownFrame_SetTimer
if IceHUD.WowVer >= 70000 then if CooldownFrame_Set then
CooldownFrame_SetTimer = CooldownFrame_Set CooldownFrame_SetTimer = CooldownFrame_Set
end end
-- blizzard cracks me up. the below block is copied verbatim from RuneFrame.lua ;)
--Readability == win
local RUNETYPE_BLOOD = 1; local RUNETYPE_BLOOD = 1;
local RUNETYPE_DEATH = 2; local RUNETYPE_DEATH = IceHUD.DeathKnightUnholyFrostRunesSwapped and 2 or 3;
local RUNETYPE_FROST = 3; local RUNETYPE_FROST = IceHUD.DeathKnightUnholyFrostRunesSwapped and 3 or 2;
local RUNETYPE_CHROMATIC = 4; local RUNETYPE_CHROMATIC = 4;
local RUNETYPE_LEGION = 5; -- not real, but makes for an easy update local RUNETYPE_LEGION = 5; -- not real, but makes for an easy update
local GetRuneType = GetRuneType local GetRuneType = GetRuneType
if IceHUD.WowVer >= 70000 then if IceHUD.WowVer >= 70000 and IceHUD.WowVer < 70300 then
GetRuneType = function() return RUNETYPE_LEGION end GetRuneType = function() return RUNETYPE_LEGION end
elseif IceHUD.WowVer >= 70300 and GetSpecialization then
GetRuneType = function() return GetSpecialization() end
end end
local RUNEMODE_DEFAULT = "Blizzard" local RUNEMODE_DEFAULT = "Blizzard"
@ -43,15 +45,22 @@ Runes.prototype.numRunes = 6
Runes.prototype.lastRuneState = {} Runes.prototype.lastRuneState = {}
local SPELL_POWER_RUNES = SPELL_POWER_RUNES
if Enum and Enum.PowerType then
SPELL_POWER_RUNES = Enum.PowerType.Runes
end
-- Constructor -- -- Constructor --
function Runes.prototype:init() function Runes.prototype:init()
Runes.super.prototype.init(self, "Runes") Runes.super.prototype.init(self, "Runes")
if IceHUD.WowVer < 70000 then if IceHUD.WowVer < 70000 or IceHUD.WowVer >= 70300 then
self:SetDefaultColor("Runes"..self.runeNames[RUNETYPE_BLOOD], 255, 0, 0) self:SetDefaultColor("Runes"..self.runeNames[RUNETYPE_BLOOD], 255, 0, 0)
self:SetDefaultColor("Runes"..self.runeNames[RUNETYPE_DEATH], 0, 207, 0) self:SetDefaultColor("Runes"..self.runeNames[RUNETYPE_DEATH], 0, 207, 0)
self:SetDefaultColor("Runes"..self.runeNames[RUNETYPE_FROST], 0, 255, 255) self:SetDefaultColor("Runes"..self.runeNames[RUNETYPE_FROST], 0, 255, 255)
self:SetDefaultColor("Runes"..self.runeNames[RUNETYPE_CHROMATIC], 204, 26, 255) if IceHUD.WowVer < 70300 then
self:SetDefaultColor("Runes"..self.runeNames[RUNETYPE_CHROMATIC], 204, 26, 255)
end
else else
self:SetDefaultColor("Runes"..self.runeNames[RUNETYPE_LEGION], 204, 204, 255) self:SetDefaultColor("Runes"..self.runeNames[RUNETYPE_LEGION], 204, 204, 255)
end end
@ -125,6 +134,9 @@ function Runes.prototype:GetOptions()
disabled = function() disabled = function()
return not self.moduleSettings.enabled return not self.moduleSettings.enabled
end, end,
hidden = function()
return not PlayerFrame_HideVehicleTexture
end,
order = 32 order = 32
} }
@ -258,7 +270,7 @@ end
-- OVERRIDE -- OVERRIDE
function Runes.prototype:Enable(core) function Runes.prototype:Enable(core)
if IceHUD.WowVer >= 70000 then if RunesReturnedByMaxPower then
self.numRunes = UnitPowerMax("player", SPELL_POWER_RUNES) self.numRunes = UnitPowerMax("player", SPELL_POWER_RUNES)
end end
@ -268,16 +280,28 @@ function Runes.prototype:Enable(core)
Runes.super.prototype.Enable(self, core) Runes.super.prototype.Enable(self, core)
self:RegisterEvent("RUNE_POWER_UPDATE", "UpdateRunePower") self:RegisterEvent("RUNE_POWER_UPDATE", "ResetRuneAvailability")
self:RegisterEvent("RUNE_TYPE_UPDATE", "UpdateRuneType") if IceHUD.WowVer < 80000 then
self:RegisterEvent("PLAYER_ENTERING_WORLD", "ResetRuneAvailability") self:RegisterEvent("RUNE_TYPE_UPDATE", "UpdateRuneType")
self:RegisterEvent("UNIT_MAXPOWER", "CheckMaxNumRunes") end
if IceHUD.WowVer >= 70300 then
self:RegisterEvent("PLAYER_SPECIALIZATION_CHANGED", "UpdateRuneColors")
end
self:RegisterEvent("PLAYER_ENTERING_WORLD", "EnteringWorld")
if RunesReturnedByMaxPower then
self:RegisterEvent("UNIT_MAXPOWER", "CheckMaxNumRunes")
end
if (self.moduleSettings.hideBlizz) then if (self.moduleSettings.hideBlizz) then
self:HideBlizz() self:HideBlizz()
end end
end end
function Runes.prototype:EnteringWorld()
self:TargetChanged()
self:ResetRuneAvailability()
end
function Runes.prototype:Disable(core) function Runes.prototype:Disable(core)
Runes.super.prototype.Disable(self, core) Runes.super.prototype.Disable(self, core)
@ -300,16 +324,17 @@ function Runes.prototype:CheckMaxNumRunes(event, unit, powerType)
end end
end end
function Runes.prototype:ResetRuneAvailability() function Runes.prototype:ResetRuneAvailability(event)
for i=1, self.numRunes do for i=1, self.numRunes do
self:UpdateRunePower(nil, i, true) self:UpdateRunePower(event, i, not event)
end end
self:Redraw() self:Redraw()
end end
-- simply shows/hides the foreground rune when it becomes usable/unusable. this allows the background transparent rune to show only -- simply shows/hides the foreground rune when it becomes usable/unusable. this allows the background transparent rune to show only
function Runes.prototype:UpdateRunePower(event, rune, dontFlash) function Runes.prototype:UpdateRunePower(event, rune, dontFlash)
if not rune or not self.frame.graphical or #self.frame.graphical < rune then if rune and (not self.frame.graphical or #self.frame.graphical < rune) then
return return
end end
@ -323,27 +348,9 @@ function Runes.prototype:UpdateRunePower(event, rune, dontFlash)
local lastState = self.lastRuneState[rune] local lastState = self.lastRuneState[rune]
self.lastRuneState[rune] = usable self.lastRuneState[rune] = usable
if self.moduleSettings.runeMode ~= RUNEMODE_DEFAULT then -- if lastState == usable then
if lastState == usable then -- return
return -- end
end
if usable then
for i=1,self.numRunes do
if self.frame.graphical[i]:GetAlpha() == 0 then
rune = i
break
end
end
else
for i=1,self.numRunes do
if self.frame.graphical[i]:GetAlpha() == 0 then
break
end
rune = i
end
end
end
-- print("Runes.prototype:UpdateRunePower: rune="..rune.." usable="..(usable and "yes" or "no").." GetRuneType(rune)="..GetRuneType(rune)); -- print("Runes.prototype:UpdateRunePower: rune="..rune.." usable="..(usable and "yes" or "no").." GetRuneType(rune)="..GetRuneType(rune));
@ -357,12 +364,13 @@ function Runes.prototype:UpdateRunePower(event, rune, dontFlash)
self.frame.graphical[rune]:SetAlpha(1) self.frame.graphical[rune]:SetAlpha(1)
end end
if not dontFlash then if not dontFlash and lastState ~= usable then
local fadeInfo={ local fadeInfo={
mode = "IN", mode = "IN",
timeToFade = 0.5, timeToFade = 0.25,
finishedFunc = function(rune) self:ShineFinished(rune) end, finishedFunc = Runes.prototype.ShineFinished,
finishedArg1 = rune finishedArg1 = self,
finishedArg2 = rune
} }
UIFrameFade(self.frame.graphical[rune].shine, fadeInfo); UIFrameFade(self.frame.graphical[rune].shine, fadeInfo);
end end
@ -380,8 +388,6 @@ function Runes.prototype:UpdateRunePower(event, rune, dontFlash)
self.frame.graphical[rune]:SetAlpha(0.2) self.frame.graphical[rune]:SetAlpha(0.2)
end end
end end
self:Redraw()
end end
function Runes.prototype:GetNumRunesAvailable() function Runes.prototype:GetNumRunesAvailable()
@ -418,7 +424,17 @@ function Runes.prototype:UpdateRuneType(event, rune)
self.frame.graphical[rune].rune:SetVertexColor(self:GetColor("Runes"..thisRuneName)) self.frame.graphical[rune].rune:SetVertexColor(self:GetColor("Runes"..thisRuneName))
end end
function Runes.prototype:UpdateRuneColors()
for i=1,self.numRunes do
self:UpdateRuneType(nil, i)
end
end
function Runes.prototype:GetRuneTexture(runeName) function Runes.prototype:GetRuneTexture(runeName)
if IceHUD.WowVer >= 70300 then
runeName = self.runeNames[RUNETYPE_LEGION]
end
if self.moduleSettings.runeMode == RUNEMODE_DEFAULT and runeName then if self.moduleSettings.runeMode == RUNEMODE_DEFAULT and runeName then
return "Interface\\PlayerFrame\\UI-PlayerFrame-DeathKnight-"..runeName return "Interface\\PlayerFrame\\UI-PlayerFrame-DeathKnight-"..runeName
elseif self.moduleSettings.runeMode == RUNEMODE_BAR then elseif self.moduleSettings.runeMode == RUNEMODE_BAR then
@ -440,7 +456,7 @@ end
function Runes.prototype:CreateFrame() function Runes.prototype:CreateFrame()
Runes.super.prototype.CreateFrame(self) Runes.super.prototype.CreateFrame(self)
self.frame:SetFrameStrata("BACKGROUND") self.frame:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
self.frame:SetWidth(self.runeSize*self.numRunes) self.frame:SetWidth(self.runeSize*self.numRunes)
self.frame:SetHeight(1) self.frame:SetHeight(1)
self.frame:ClearAllPoints() self.frame:ClearAllPoints()
@ -494,13 +510,13 @@ function Runes.prototype:CreateRune(i, type, name)
-- create runes -- create runes
if (not self.frame.graphical[i]) then if (not self.frame.graphical[i]) then
self.frame.graphical[i] = CreateFrame("Frame", nil, self.frame) self.frame.graphical[i] = CreateFrame("Frame", nil, self.frame)
self.frame.graphical[i].rune = self.frame.graphical[i]:CreateTexture(nil, "LOW") self.frame.graphical[i].rune = self.frame.graphical[i]:CreateTexture(nil, "BACKGROUND")
self.frame.graphical[i].rune:SetAllPoints(self.frame.graphical[i]) self.frame.graphical[i].rune:SetAllPoints(self.frame.graphical[i])
self.frame.graphical[i].cd = CreateFrame("Cooldown", nil, self.frame.graphical[i], "CooldownFrameTemplate") self.frame.graphical[i].cd = CreateFrame("Cooldown", nil, self.frame.graphical[i], "CooldownFrameTemplate")
self.frame.graphical[i].shine = self.frame.graphical[i]:CreateTexture(nil, "OVERLAY") self.frame.graphical[i].shine = self.frame.graphical[i]:CreateTexture(nil, "OVERLAY")
end end
self.frame.graphical[i]:SetFrameStrata("BACKGROUND") self.frame.graphical[i]:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
self.frame.graphical[i]:SetWidth(self.runeSize) self.frame.graphical[i]:SetWidth(self.runeSize)
self.frame.graphical[i]:SetHeight(self.runeSize) self.frame.graphical[i]:SetHeight(self.runeSize)
@ -530,7 +546,7 @@ function Runes.prototype:CreateRune(i, type, name)
self.frame.graphical[i]:Hide() self.frame.graphical[i]:Hide()
end end
self.frame.graphical[i].cd:SetFrameStrata("BACKGROUND") self.frame.graphical[i].cd:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
self.frame.graphical[i].cd:SetFrameLevel(self.frame.graphical[i]:GetFrameLevel()+1) self.frame.graphical[i].cd:SetFrameLevel(self.frame.graphical[i]:GetFrameLevel()+1)
self.frame.graphical[i].cd:ClearAllPoints() self.frame.graphical[i].cd:ClearAllPoints()
self.frame.graphical[i].cd:SetAllPoints(self.frame.graphical[i]) self.frame.graphical[i].cd:SetAllPoints(self.frame.graphical[i])
@ -555,13 +571,7 @@ function Runes.prototype:ShowBlizz()
RuneFrame:Show() RuneFrame:Show()
RuneFrame:GetScript("OnLoad")(RuneFrame) RuneFrame:GetScript("OnLoad")(RuneFrame)
RuneFrame:GetScript("OnEvent")(frame, "PLAYER_ENTERING_WORLD") RuneFrame:GetScript("OnEvent")(RuneFrame, "PLAYER_ENTERING_WORLD")
for i=1, self.numRunes do
local frame = _G["RuneButtonIndividual"..i]
if frame then
frame:GetScript("OnLoad")(frame)
end
end
end end
local function hook_playerframe() local function hook_playerframe()
@ -574,6 +584,10 @@ local function hook_playerframe()
end end
function Runes.prototype:HideBlizz() function Runes.prototype:HideBlizz()
if not PlayerFrame_HideVehicleTexture then
return
end
RuneFrame:Hide() RuneFrame:Hide()
RuneFrame:UnregisterAllEvents() RuneFrame:UnregisterAllEvents()

View File

@ -3,14 +3,26 @@ local ShardCounter = IceCore_CreateClass(IceClassPowerCounter)
local CurrentSpec = nil local CurrentSpec = nil
local AfflictionCoords = local AfflictionCoords
{ if IceHUD.WowVer < 70200 then
{0.01562500, 0.28125000, 0.00781250, 0.13281250}, AfflictionCoords =
{0.01562500, 0.28125000, 0.00781250, 0.13281250}, {
{0.01562500, 0.28125000, 0.00781250, 0.13281250}, {0.01562500, 0.28125000, 0.00781250, 0.13281250},
{0.01562500, 0.28125000, 0.00781250, 0.13281250}, {0.01562500, 0.28125000, 0.00781250, 0.13281250},
{0.01562500, 0.28125000, 0.00781250, 0.13281250}, {0.01562500, 0.28125000, 0.00781250, 0.13281250},
} {0.01562500, 0.28125000, 0.00781250, 0.13281250},
{0.01562500, 0.28125000, 0.00781250, 0.13281250},
}
else
AfflictionCoords =
{
{0, 1, 0, 1},
{0, 1, 0, 1},
{0, 1, 0, 1},
{0, 1, 0, 1},
{0, 1, 0, 1},
}
end
local DestructionCoords = local DestructionCoords =
{ {
@ -25,6 +37,11 @@ local DemonologyCoords =
{0.03906250, 0.55468750, 0.10546875, 0.19921875}, {0.03906250, 0.55468750, 0.10546875, 0.19921875},
} }
local SPELL_POWER_SOUL_SHARDS = SPELL_POWER_SOUL_SHARDS
if Enum and Enum.PowerType then
SPELL_POWER_SOUL_SHARDS = Enum.PowerType.SoulShards
end
function ShardCounter.prototype:init() function ShardCounter.prototype:init()
ShardCounter.super.prototype.init(self, "Warlock Power") ShardCounter.super.prototype.init(self, "Warlock Power")
@ -36,6 +53,10 @@ function ShardCounter.prototype:init()
if IceHUD.WowVer >= 70000 then if IceHUD.WowVer >= 70000 then
self.runeHeight = 23 self.runeHeight = 23
self.runeWidth = 26 self.runeWidth = 26
if IceHUD.WowVer >= 70200 then
self.runeHeight = 27
self.runeWidth = 22
end
self.runeCoords = AfflictionCoords self.runeCoords = AfflictionCoords
self.unitPower = SPELL_POWER_SOUL_SHARDS self.unitPower = SPELL_POWER_SOUL_SHARDS
self.unit = "player" self.unit = "player"
@ -45,6 +66,16 @@ end
function ShardCounter.prototype:Enable(core) function ShardCounter.prototype:Enable(core)
if IceHUD.WowVer >= 70000 then if IceHUD.WowVer >= 70000 then
self.numRunes = UnitPowerMax(self.unit, self.unitPower) self.numRunes = UnitPowerMax(self.unit, self.unitPower)
if IceHUD.WowVer >= 80000 or GetSpecialization() == SPEC_WARLOCK_DESTRUCTION then
self.shouldShowUnmodified = true
self.numericFormat = "%.1f"
self.round = floor
else
self.shouldShowUnmodified = nil
self.numericFormat = nil
self.round = nil
end
end end
ShardCounter.super.prototype.Enable(self, core) ShardCounter.super.prototype.Enable(self, core)
@ -76,6 +107,7 @@ function ShardCounter.prototype:UpdateRunePower(event, arg1, arg2)
end end
if event == "PLAYER_ENTERING_WORLD" and IceHUD.WowVer < 70000 then if event == "PLAYER_ENTERING_WORLD" and IceHUD.WowVer < 70000 then
self:TargetChanged()
self:UpdatePowerType(event) self:UpdatePowerType(event)
end end
@ -90,16 +122,16 @@ function ShardCounter.prototype:CheckGreenFire()
end end
function ShardCounter.prototype:UpdatePowerType(event) function ShardCounter.prototype:UpdatePowerType(event)
if IceHUD.WowVer >= 50000 then if IceHUD.WowVer >= 50000 and IceHUD.WowVer < 80000 then
CurrentSpec = GetSpecialization() CurrentSpec = GetSpecialization()
else else
-- all warlocks use shards in pre-5.0, so just act like our spec is affliction -- all warlocks use shards in pre-5.0/post-8.0, so just act like our spec is affliction
CurrentSpec = SPEC_WARLOCK_AFFLICTION CurrentSpec = SPEC_WARLOCK_AFFLICTION
end end
self.shouldShowUnmodified = false self.shouldShowUnmodified = false
self.requiredSpec = CurrentSpec self.requiredSpec = CurrentSpec
self.currentGrowMode = nil self.currentGrowMode = self.growModes["height"]
if CurrentSpec == SPEC_WARLOCK_AFFLICTION then if CurrentSpec == SPEC_WARLOCK_AFFLICTION then
self.runeCoords = AfflictionCoords self.runeCoords = AfflictionCoords
@ -205,6 +237,10 @@ function ShardCounter.prototype:GetDefaultSettings()
end end
function ShardCounter.prototype:GetRuneTexture(rune) function ShardCounter.prototype:GetRuneTexture(rune)
if IceHUD.WowVer >= 70200 then
return nil
end
if not rune or rune ~= tonumber(rune) then if not rune or rune ~= tonumber(rune) then
return return
end end
@ -222,6 +258,10 @@ function ShardCounter.prototype:GetRuneTexture(rune)
return "Interface\\PlayerFrame\\UI-WarlockShard" return "Interface\\PlayerFrame\\UI-WarlockShard"
end end
function ShardCounter.prototype:GetRuneAtlas(rune)
return "Warlock-ReadyShard"
end
function ShardCounter.prototype:ShowBlizz() function ShardCounter.prototype:ShowBlizz()
WarlockPowerFrame:Show() WarlockPowerFrame:Show()
@ -236,6 +276,6 @@ end
-- Load us up -- Load us up
local _, unitClass = UnitClass("player") local _, unitClass = UnitClass("player")
if (unitClass == "WARLOCK" and IceHUD.WowVer >= 40000) then if (unitClass == "WARLOCK" and WarlockPowerFrame) then
IceHUD.ShardCounter = ShardCounter:new() IceHUD.ShardCounter = ShardCounter:new()
end end

View File

@ -20,14 +20,50 @@ local impSndBonusPerRank = 0.25
local maxComboPoints = 5 local maxComboPoints = 5
local sndEndTime = 0 local sndEndTime = 0
local sndDuration = 0 local sndDuration = 0
local sixComboPointsTalentID = 19240
local CurrMaxSnDDuration = 0 local CurrMaxSnDDuration = 0
local PotentialSnDDuration = 0 local PotentialSnDDuration = 0
local sndBuffName = 132306
if IceHUD.WowMain and IceHUD.WowVer < 80000 then
sndBuffName = "Ability_Rogue_SliceDice"
end
if IceHUD.WowVer >= 50000 then if IceHUD.WowVer >= 50000 then
baseTime = 12 baseTime = 12
gapPerComboPoint = 6 gapPerComboPoint = 6
end end
if IceHUD.WowClassic then
impSndBonusPerRank = 0.15
impSndTalentPage = 1
impSndTalentIdx = 6
elseif IceHUD.WowClassicBC then
impSndBonusPerRank = 0.15
impSndTalentPage = 2
impSndTalentIdx = 4
elseif IceHUD.WowClassicWrath then
impSndBonusPerRank = 0.25
impSndTalentPage = 2
impSndTalentIdx = 23
end
local SPELL_POWER_COMBO_POINTS = SPELL_POWER_COMBO_POINTS
if Enum and Enum.PowerType then
SPELL_POWER_COMBO_POINTS = Enum.PowerType.ComboPoints
end
local UnitBuff = UnitBuff
if not UnitBuff and C_UnitAuras and AuraUtil then
UnitBuff = function(unitToken, index, filter)
local auraData = C_UnitAuras.GetBuffDataByIndex(unitToken, index, filter)
if not auraData then
return nil
end
return AuraUtil.UnpackAuraData(auraData)
end
end
-- Constructor -- -- Constructor --
function SliceAndDice.prototype:init() function SliceAndDice.prototype:init()
@ -50,10 +86,19 @@ function SliceAndDice.prototype:Enable(core)
SliceAndDice.super.prototype.Enable(self, core) SliceAndDice.super.prototype.Enable(self, core)
self:RegisterEvent("UNIT_AURA", "UpdateSliceAndDice") self:RegisterEvent("UNIT_AURA", "UpdateSliceAndDice")
if IceHUD.WowVer < 70000 then if IceHUD.EventExistsUnitComboPoints then
self:RegisterEvent("UNIT_COMBO_POINTS", "ComboPointsChanged") self:RegisterEvent("UNIT_COMBO_POINTS", "ComboPointsChanged")
else else
self:RegisterEvent("UNIT_POWER", "ComboPointsChanged") self:RegisterEvent(IceHUD.UnitPowerEvent, "ComboPointsChanged")
end
if IceHUD.WowVer >= 70000 then
self:RegisterEvent("PLAYER_TALENT_UPDATE", "CheckMaxComboPoints")
self:CheckMaxComboPoints()
end
if IceHUD.EventExistsUnitMaxPower then
self:RegisterEvent("UNIT_MAXPOWER", "CheckMaxComboPoints")
end end
if not self.moduleSettings.alwaysFullAlpha then if not self.moduleSettings.alwaysFullAlpha then
@ -65,12 +110,21 @@ function SliceAndDice.prototype:Enable(core)
self:SetBottomText1("") self:SetBottomText1("")
end end
function SliceAndDice.prototype:CheckMaxComboPoints()
if UnitPowerMax then
maxComboPoints = UnitPowerMax(self.unit, SPELL_POWER_COMBO_POINTS)
else
local talentID, name, texture, selected, available, spellID, unknown, row, column, known, grantedByAura = GetTalentInfoByID(sixComboPointsTalentID, GetActiveSpecGroup())
maxComboPoints = selected and 6 or 5
end
end
function SliceAndDice.prototype:Disable(core) function SliceAndDice.prototype:Disable(core)
SliceAndDice.super.prototype.Disable(self, core) SliceAndDice.super.prototype.Disable(self, core)
end end
function SliceAndDice.prototype:ComboPointsChanged(...) function SliceAndDice.prototype:ComboPointsChanged(...)
if select('#', ...) >= 3 and select(1, ...) == "UNIT_POWER" and select(3, ...) ~= "COMBO_POINTS" then if select('#', ...) >= 3 and select(1, ...) == IceHUD.UnitPowerEvent and select(3, ...) ~= "COMBO_POINTS" then
return return
end end
@ -172,7 +226,7 @@ function SliceAndDice.prototype:CreateFrame()
end end
function SliceAndDice.prototype:CreateDurationBar() function SliceAndDice.prototype:CreateDurationBar()
self.durationFrame = self:BarFactory(self.durationFrame, "BACKGROUND","ARTWORK") self.durationFrame = self:BarFactory(self.durationFrame, "BACKGROUND", "ARTWORK", "Duration")
-- Rokiyo: Do we need to call this here? -- Rokiyo: Do we need to call this here?
self.CurrScale = 0 self.CurrScale = 0
@ -205,15 +259,15 @@ end
function SliceAndDice.prototype:GetBuffDuration(unitName, buffName) function SliceAndDice.prototype:GetBuffDuration(unitName, buffName)
local i = 1 local i = 1
local buff, rank, texture, count, type, duration, endTime, remaining local buff, _, texture, duration, endTime, remaining
if IceHUD.WowVer >= 30000 then if IceHUD.SpellFunctionsReturnRank then
buff, rank, texture, count, type, duration, endTime = UnitBuff(unitName, i) buff, _, texture, _, _, duration, endTime = UnitBuff(unitName, i)
else else
buff, rank, texture, count, duration, remaining = UnitBuff(unitName, i) buff, texture, _, _, duration, endTime = UnitBuff(unitName, i)
end end
while buff do while buff do
if (texture and string.match(texture, buffName)) then if (texture and (type(buffName) == 'string' and string.match(texture, buffName) or texture == buffName)) then
if endTime and not remaining then if endTime and not remaining then
remaining = endTime - GetTime() remaining = endTime - GetTime()
end end
@ -222,10 +276,10 @@ function SliceAndDice.prototype:GetBuffDuration(unitName, buffName)
i = i + 1; i = i + 1;
if IceHUD.WowVer >= 30000 then if IceHUD.SpellFunctionsReturnRank then
buff, rank, texture, count, type, duration, endTime = UnitBuff(unitName, i) buff, _, texture, _, _, duration, endTime = UnitBuff(unitName, i)
else else
buff, rank, texture, count, duration, remaining = UnitBuff(unitName, i) buff, texture, _, _, duration, endTime = UnitBuff(unitName, i)
end end
end end
@ -235,7 +289,7 @@ end
function SliceAndDice.prototype:MyOnUpdate() function SliceAndDice.prototype:MyOnUpdate()
SliceAndDice.super.prototype.MyOnUpdate(self) SliceAndDice.super.prototype.MyOnUpdate(self)
if self.bUpdateSnd then if self.bUpdateSnd then
self:UpdateSliceAndDice(nil, self.unit, true) self:UpdateSliceAndDice("internal", self.unit)
end end
if self.target or self.moduleSettings.bShowWithNoTarget then if self.target or self.moduleSettings.bShowWithNoTarget then
self:UpdateDurationBar() self:UpdateDurationBar()
@ -243,39 +297,37 @@ function SliceAndDice.prototype:MyOnUpdate()
end end
local function SNDGetComboPoints(unit) local function SNDGetComboPoints(unit)
if IceHUD.WowVer >= 60000 then if IceHUD.PerTargetComboPoints then
return UnitPower(unit, SPELL_POWER_COMBO_POINTS)
elseif IceHUD.WowVer >= 30000 then
return GetComboPoints(unit, "target") return GetComboPoints(unit, "target")
elseif IceHUD.WowVer >= 60000 then
return UnitPower(unit, SPELL_POWER_COMBO_POINTS)
else else
return GetComboPoints() return GetComboPoints()
end end
end end
-- use this to figure out if Roll the Bones is available or not. neither IsSpellKnown nor IsPlayerSpell are correct for it
-- when SnD is known, but this is.
local function HasSpell(id)
local spell = GetSpellInfo(id)
return spell == GetSpellInfo(spell)
end
local function ShouldHide() local function ShouldHide()
if IceHUD.WowVer >= 90000 or IceHUD.WowClassicBC or IceHUD.WowClassicWrath then
return false
end
return --[[(IceHUD.WowVer < 70000 or not IsSpellKnown(193316)) and]] not IsPlayerSpell(5171) -- IsSpellKnown returns incorrect info for SnD in 7.0 return --[[(IceHUD.WowVer < 70000 or not IsSpellKnown(193316)) and]] not IsPlayerSpell(5171) -- IsSpellKnown returns incorrect info for SnD in 7.0
-- commented code is here in case we decide we'd like to use this module for Roll the Bones. -- commented code is here in case we decide we'd like to use this module for Roll the Bones.
-- if we do, though, the "active" check gets way more complicated since it can activate any number of 6 different abilities -- if we do, though, the "active" check gets way more complicated since it can activate any number of 6 different abilities
-- with different durations -- with different durations
end end
function SliceAndDice.prototype:UpdateSliceAndDice(event, unit, fromUpdate) function SliceAndDice.prototype:UpdateSliceAndDice(event, unit)
if unit and unit ~= self.unit then if unit and unit ~= self.unit then
return return
end end
local now = GetTime() local now = GetTime()
local remaining = nil local remaining = nil
local fromUpdate = event == "internal"
if not fromUpdate or IceHUD.WowVer < 30000 then if not fromUpdate or IceHUD.WowVer < 30000 then
sndDuration, remaining = self:GetBuffDuration(self.unit, "Ability_Rogue_SliceDice") sndDuration, remaining = self:GetBuffDuration(self.unit, sndBuffName)
if not remaining then if not remaining then
sndEndTime = 0 sndEndTime = 0
@ -377,13 +429,11 @@ function SliceAndDice.prototype:UpdateDurationBar(event, unit)
end end
function SliceAndDice.prototype:GetMaxBuffTime(numComboPoints) function SliceAndDice.prototype:GetMaxBuffTime(numComboPoints)
local maxduration
if numComboPoints == 0 then if numComboPoints == 0 then
return 0 return 0
end end
maxduration = baseTime + ((numComboPoints - 1) * gapPerComboPoint) local maxduration = baseTime + ((numComboPoints - 1) * gapPerComboPoint)
if self:HasNetherbladeBonus() then if self:HasNetherbladeBonus() then
maxduration = maxduration + netherbladeBonus maxduration = maxduration + netherbladeBonus
@ -399,8 +449,10 @@ function SliceAndDice.prototype:GetMaxBuffTime(numComboPoints)
end end
local rank = 0 local rank = 0
local _ if GetTalentInfo then
_, _, _, _, rank = GetTalentInfo(impSndTalentPage, impSndTalentIdx) local _
_, _, _, _, rank = GetTalentInfo(impSndTalentPage, impSndTalentIdx)
end
maxduration = maxduration * (1 + (rank * impSndBonusPerRank)) maxduration = maxduration * (1 + (rank * impSndBonusPerRank))
end end
@ -461,6 +513,9 @@ function SliceAndDice.prototype:HasNineTailedBonus()
end end
function SliceAndDice.prototype:HasGlyphBonus() function SliceAndDice.prototype:HasGlyphBonus()
if not GetNumGlyphSockets then
return false
end
for i=1,GetNumGlyphSockets() do for i=1,GetNumGlyphSockets() do
local enabled, _, _, spell = GetGlyphSocketInfo(i) local enabled, _, _, spell = GetGlyphSocketInfo(i)

View File

@ -13,9 +13,47 @@ local ModerateID = 124274
local HeavyID = 124273 local HeavyID = 124273
local StaggerID = 124255 local StaggerID = 124255
local staggerNames = {"", "", ""} local staggerNames = {"", "", ""}
local staggerIds = {LightID, ModerateID, HeavyID}
local MinLevel = 10 local MinLevel = 10
local STAGGER_YELLOW_TRANSITION, STAGGER_RED_TRANSITION = STAGGER_YELLOW_TRANSITION, STAGGER_RED_TRANSITION
if STAGGER_STATES then
STAGGER_YELLOW_TRANSITION = STAGGER_STATES.YELLOW.threshold
STAGGER_RED_TRANSITION = STAGGER_STATES.RED.threshold
end
local GetSpellInfo = GetSpellInfo
if not GetSpellInfo and C_Spell and C_Spell.GetSpellInfo then
GetSpellInfo = function(spellID)
if not spellID then
return nil
end
local spellInfo = C_Spell.GetSpellInfo(spellID)
if spellInfo then
return spellInfo.name, nil, spellInfo.iconID, spellInfo.castTime, spellInfo.minRange, spellInfo.maxRange, spellInfo.spellID, spellInfo.originalIconID
end
end
end
local GetSpellName = GetSpellInfo
if C_Spell and C_Spell.GetSpellName then
GetSpellName = C_Spell.GetSpellName
end
local UnitDebuff = UnitDebuff
if not UnitDebuff and C_UnitAuras and AuraUtil then
UnitDebuff = function(unitToken, index, filter)
local auraData = C_UnitAuras.GetDebuffDataByIndex(unitToken, index, filter)
if not auraData then
return nil
end
return AuraUtil.UnpackAuraData(auraData)
end
end
StaggerBar.prototype.StaggerDuration = 0 StaggerBar.prototype.StaggerDuration = 0
StaggerBar.prototype.StaggerEndTime = 0 StaggerBar.prototype.StaggerEndTime = 0
@ -71,7 +109,7 @@ function StaggerBar.prototype:GetOptions()
name = "Max Percent", name = "Max Percent",
desc = "Maximum percentage of your maximum health for the Stagger bar to represent. I.e, if set to 20%, the bar will be full when the Stagger damage over time effect is dealing 20% of your maximum health per second.", desc = "Maximum percentage of your maximum health for the Stagger bar to represent. I.e, if set to 20%, the bar will be full when the Stagger damage over time effect is dealing 20% of your maximum health per second.",
min = 0, min = 0,
max = 50, max = 100,
step = 1, step = 1,
get = function() get = function()
return self.moduleSettings.maxPercent return self.moduleSettings.maxPercent
@ -112,9 +150,9 @@ function StaggerBar.prototype:Enable(core)
StaggerBar.super.prototype.Enable(self, core) StaggerBar.super.prototype.Enable(self, core)
playerName = UnitName(self.unit) playerName = UnitName(self.unit)
staggerNames[1] = GetSpellInfo(LightID) staggerNames[1] = GetSpellName(LightID)
staggerNames[2] = GetSpellInfo(ModerateID) staggerNames[2] = GetSpellName(ModerateID)
staggerNames[3] = GetSpellInfo(HeavyID) staggerNames[3] = GetSpellName(HeavyID)
self:RegisterEvent("COMBAT_LOG_EVENT_UNFILTERED") self:RegisterEvent("COMBAT_LOG_EVENT_UNFILTERED")
self:RegisterEvent("PLAYER_ENTERING_WORLD") self:RegisterEvent("PLAYER_ENTERING_WORLD")
@ -136,7 +174,7 @@ function StaggerBar.prototype:CreateFrame()
end end
function StaggerBar.prototype:CreateTimerBar() function StaggerBar.prototype:CreateTimerBar()
self.timerFrame = self:BarFactory(self.timerFrame, "MEDIUM","ARTWORK") self.timerFrame = self:BarFactory(self.timerFrame, "MEDIUM", "ARTWORK", "Timer")
self.CurrScale = 0 self.CurrScale = 0
@ -156,6 +194,7 @@ function StaggerBar.prototype:UpdateShown()
end end
function StaggerBar.prototype:PLAYER_ENTERING_WORLD() function StaggerBar.prototype:PLAYER_ENTERING_WORLD()
self:TargetChanged()
self:UpdateStaggerBar() self:UpdateStaggerBar()
end end
@ -165,7 +204,7 @@ end
function StaggerBar.prototype:GetDebuffInfo() function StaggerBar.prototype:GetDebuffInfo()
if IceHUD.WowVer >= 70000 then if IceHUD.WowVer >= 70000 then
self.amount = UnitStagger(self.unit) self.amount = UnitStagger(self.unit) or 0
self.staggerLevel = 1 self.staggerLevel = 1
local healthMax = UnitHealthMax(self.unit) local healthMax = UnitHealthMax(self.unit)
@ -183,13 +222,13 @@ function StaggerBar.prototype:GetDebuffInfo()
local staggerLevel = 1 local staggerLevel = 1
for i = 1, IceCore.BuffLimit do for i = 1, IceCore.BuffLimit do
local debuffID = select(11, UnitDebuff(self.unit, i)) local debuffID = select(IceHUD.SpellFunctionsReturnRank and 11 or 10, UnitDebuff(self.unit, i))
if debuffID == LightID or debuffID == ModerateID or debuffID == HeavyID then if debuffID == LightID or debuffID == ModerateID or debuffID == HeavyID then
local spellName = select(1, UnitDebuff(self.unit, i)) local spellName = UnitDebuff(self.unit, i)
duration = select(6, UnitAura(self.unit, spellName, "", "HARMFUL")) duration = select(IceHUD.SpellFunctionsReturnRank and 6 or 5, IceHUD.UnitAura(self.unit, spellName, "", "HARMFUL"))
amount = select(15, UnitAura(self.unit, spellName, "", "HARMFUL")) amount = select(IceHUD.SpellFunctionsReturnRank and 15 or 14, IceHUD.UnitAura(self.unit, spellName, "", "HARMFUL"))
staggerLevel = (debuffID == LightID) and 1 or (debuffID == ModerateID) and 2 or 3 staggerLevel = (debuffID == LightID) and 1 or (debuffID == ModerateID) and 2 or 3
break break
@ -201,9 +240,14 @@ function StaggerBar.prototype:GetDebuffInfo()
self.staggerLevel = staggerLevel or 1 self.staggerLevel = staggerLevel or 1
end end
function StaggerBar.prototype:COMBAT_LOG_EVENT_UNFILTERED(_, timestamp, event, hideCaster, sourceGUID, sourceName, sourceFlags, sourceFlags2, destGUID, destName, destFlags, destFlags2, spellID) function StaggerBar.prototype:COMBAT_LOG_EVENT_UNFILTERED(...)
if destName == playerName then local eventArgs = {...}
if spellID == StaggerID or event == "SWING_DAMAGE" or event == "SPELL_AURA_APPLIED" or event == "SPELL_AURA_REMOVED" then if (CombatLogGetCurrentEventInfo) then
eventArgs = {CombatLogGetCurrentEventInfo()}
end
if eventArgs[9] == playerName then
if eventArgs[12] == StaggerID or eventArgs[2] == "SWING_DAMAGE" or eventArgs[2] == "SPELL_AURA_APPLIED" or eventArgs[2] == "SPELL_AURA_REMOVED" then
self:UpdateStaggerBar() self:UpdateStaggerBar()
end end
end end
@ -216,7 +260,7 @@ function StaggerBar.prototype:UpdateStaggerBar()
local maxHealth = UnitHealthMax(self.unit) local maxHealth = UnitHealthMax(self.unit)
local scale = IceHUD:Clamp((self.amount / maxHealth) * (100 / self.moduleSettings.maxPercent), 0, 1) local scale = IceHUD:Clamp((self.amount / maxHealth) * (100 / self.moduleSettings.maxPercent), 0, 1)
if self.amount > 0 and (IceHUD.WowVer >= 7000 or self.duration <= 10) then if self.amount > 0 and (IceHUD.WowVer >= 70000 or self.duration <= 10) then
-- self.timerFrame.bar:SetVertexColor(self:GetColor("StaggerTime", self.moduleSettings.timerAlpha)) -- self.timerFrame.bar:SetVertexColor(self:GetColor("StaggerTime", self.moduleSettings.timerAlpha))
self:UpdateBar(scale or 0, "Stagger"..self.staggerLevel) self:UpdateBar(scale or 0, "Stagger"..self.staggerLevel)
self:UpdateShown() self:UpdateShown()
@ -227,8 +271,20 @@ function StaggerBar.prototype:UpdateStaggerBar()
end end
end end
function StaggerBar.prototype:GetDebuffDuration(unitName, buffName) function StaggerBar.prototype:GetDebuffDuration(unitName, buffId)
local name, _, _, _, _, duration, endTime = UnitDebuff(unitName, buffName) local name, _, duration, endTime
if IceHUD.SpellFunctionsReturnRank then
name, _, _, _, _, duration, endTime = UnitDebuff(unitName, buffName)
else
for i = 1, IceCore.BuffLimit do
local id
name, _, _, _, duration, endTime, _, _, _, id = UnitDebuff(unitName, i)
if id == buffId then
break
end
end
end
if name then if name then
return duration, endTime - GetTime() return duration, endTime - GetTime()
@ -255,7 +311,7 @@ function StaggerBar.prototype:UpdateTimerFrame(event, unit, fromUpdate)
if not fromUpdate then if not fromUpdate then
for i = 1, 3 do for i = 1, 3 do
self.StaggerDuration, remaining = self:GetDebuffDuration(self.unit, staggerNames[i]) self.StaggerDuration, remaining = self:GetDebuffDuration(self.unit, staggerIds[i])
if remaining then if remaining then
break break

View File

@ -1,3 +1,4 @@
local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false)
IceTargetAbsorb = IceCore_CreateClass(IceUnitBar) IceTargetAbsorb = IceCore_CreateClass(IceUnitBar)
IceTargetAbsorb.prototype.highestAbsorbSinceLastZero = 0 IceTargetAbsorb.prototype.highestAbsorbSinceLastZero = 0
@ -29,6 +30,28 @@ function IceTargetAbsorb.prototype:GetDefaultSettings()
return settings return settings
end end
function IceTargetAbsorb.prototype:GetOptions()
local opts = IceTargetAbsorb.super.prototype.GetOptions(self)
opts["scaleToUnitHealth"] = {
type = 'toggle',
name = L["Scale to health"],
desc = L["Whether the bar's maximum value should be set to the unit's maximum health or not. If set, any absorb above that amount will not be shown."],
get = function()
return self.moduleSettings.scaleToUnitHealth
end,
set = function(info, v)
self.moduleSettings.scaleToUnitHealth = v
self:Update()
end,
disabled = function()
return not self.moduleSettings.enabled
end
}
return opts
end
function IceTargetAbsorb.prototype:Enable(core) function IceTargetAbsorb.prototype:Enable(core)
IceTargetAbsorb.super.prototype.Enable(self, core) IceTargetAbsorb.super.prototype.Enable(self, core)
@ -47,6 +70,7 @@ function IceTargetAbsorb.prototype:MyUnregisterCustomEvents()
end end
function IceTargetAbsorb.prototype:Update() function IceTargetAbsorb.prototype:Update()
IceTargetAbsorb.super.prototype.Update(self)
self:UpdateAbsorbAmount() self:UpdateAbsorbAmount()
end end
@ -63,11 +87,25 @@ function IceTargetAbsorb.prototype:UpdateAbsorbAmount(event, unit)
self.highestAbsorbSinceLastZero = absorbAmount self.highestAbsorbSinceLastZero = absorbAmount
end end
if absorbAmount <= 0 or self.highestAbsorbSinceLastZero <= 0 then local maxAbsorb = self.highestAbsorbSinceLastZero
if self.moduleSettings.scaleToUnitHealth then
maxAbsorb = self.maxHealth
end
self.absorbPercent = maxAbsorb ~= 0 and IceHUD:Clamp(absorbAmount / maxAbsorb, 0, 1) or 0
if absorbAmount <= 0 or maxAbsorb <= 0 then
self:Show(false) self:Show(false)
else else
self:Show(true) self:Show(true)
self:UpdateBar(absorbAmount / self.highestAbsorbSinceLastZero, self.ColorName) self:UpdateBar(self.absorbPercent, self.ColorName)
end
if not IceHUD.IceCore:ShouldUseDogTags() and self.frame:IsVisible() then
if (self.PlayerAltManaMax ~= 100) then
self:SetBottomText1(self:GetFormattedText(self:Round(absorbAmount)), self.ColorName)
else
self:SetBottomText1()
end
end end
end end

View File

@ -7,11 +7,30 @@ TargetCC.prototype.debuffRemaining = 0
TargetCC.prototype.debuffDuration = 0 TargetCC.prototype.debuffDuration = 0
local GetNumPartyMembers, GetNumRaidMembers = GetNumPartyMembers, GetNumRaidMembers local GetNumPartyMembers, GetNumRaidMembers = GetNumPartyMembers, GetNumRaidMembers
if IceHUD.WowVer >= 50000 then if GetNumGroupMembers then
GetNumPartyMembers = GetNumGroupMembers GetNumPartyMembers = GetNumGroupMembers
GetNumRaidMembers = GetNumGroupMembers GetNumRaidMembers = GetNumGroupMembers
end end
local GetSpellInfo = GetSpellInfo
if not GetSpellInfo and C_Spell and C_Spell.GetSpellInfo then
GetSpellInfo = function(spellID)
if not spellID then
return nil
end
local spellInfo = C_Spell.GetSpellInfo(spellID)
if spellInfo then
return spellInfo.name, nil, spellInfo.iconID, spellInfo.castTime, spellInfo.minRange, spellInfo.maxRange, spellInfo.spellID, spellInfo.originalIconID
end
end
end
local GetSpellName = GetSpellInfo
if C_Spell and C_Spell.GetSpellName then
GetSpellName = C_Spell.GetSpellName
end
-- list of spell ID's for each CC type so we can avoid localization issues -- list of spell ID's for each CC type so we can avoid localization issues
local StunCCList = { local StunCCList = {
-- kidney shot -- kidney shot
@ -35,9 +54,9 @@ local StunCCList = {
-- bash -- bash
5211, 5211,
-- Maim -- Maim
22570, 203123,
-- pounce -- Rake
9005, 163505,
-- war stomp -- war stomp
20549, 20549,
-- deep freeze -- deep freeze
@ -53,6 +72,8 @@ local StunCCList = {
105593, 105593,
-- Remorseless Winter -- Remorseless Winter
115001, 115001,
-- Between the Eyes
199804,
} }
local IncapacitateCCList = { local IncapacitateCCList = {
@ -70,14 +91,32 @@ local IncapacitateCCList = {
19503, 19503,
-- Sleep -- Sleep
700, 700,
-- Polymorph -- Polymorph (rank 1)
118, 118,
-- Also Polymorph
65801,
-- Polymorph rank 2
12824,
-- Polymorph rank 3
12825,
-- Polymorph rank 4
12826,
-- Polymorph: Pig -- Polymorph: Pig
28272, 28272,
-- Also Polymorph: Pig
28285,
-- Polymorph: Turtle -- Polymorph: Turtle
28271, 28271,
-- Polymorph: Penguin -- Polymorph: Penguin
59634, 59634,
-- Polymorph: Monkey
161354,
-- Polymorph: Polar Bear Cub
120137,
-- Polymorph: Porcupine
120140,
-- Polymorph: Direhorn
162625,
-- Hibernate -- Hibernate
2637, 2637,
-- Freezing Trap Effect -- Freezing Trap Effect
@ -103,6 +142,8 @@ local IncapacitateCCList = {
local FearCCList = { local FearCCList = {
-- Psychic Scream -- Psychic Scream
8122, 8122,
-- Fear (Retail)
118699,
-- Fear -- Fear
5782, 5782,
-- Howl of Terror -- Howl of Terror
@ -113,6 +154,16 @@ local FearCCList = {
5246, 5246,
-- Hex -- Hex
51514, 51514,
-- Hex: Compy
210873,
-- Hex: Wicker Mongrel
277784,
-- Hex: Zandalari Tendonripper
277778,
-- Hex: Spider
211004,
-- Hex: Skeletal Hatchling
269352,
-- Scare Beast -- Scare Beast
1513, 1513,
} }
@ -227,7 +278,7 @@ function TargetCC.prototype:PopulateSpellList(debuffListVar, ccList, ccName)
local spellName local spellName
for i=1,#ccList do for i=1,#ccList do
spellName = GetSpellInfo(ccList[i]) spellName = GetSpellName(ccList[i])
if spellName and spellName ~= "" then if spellName and spellName ~= "" then
debuffListVar[spellName] = ccName debuffListVar[spellName] = ccName
@ -315,7 +366,12 @@ end
function TargetCC.prototype:GetMaxDebuffDuration(unitName, debuffNames) function TargetCC.prototype:GetMaxDebuffDuration(unitName, debuffNames)
local i = 1 local i = 1
local debuff, rank, texture, count, debuffType, duration, endTime, unitCaster, _, _, spellId = UnitAura(unitName, i, "HARMFUL") local debuff, rank, texture, count, debuffType, duration, endTime, unitCaster, _, _, spellId
if IceHUD.SpellFunctionsReturnRank then
debuff, rank, texture, count, debuffType, duration, endTime, unitCaster, _, _, spellId = IceHUD.UnitAura(unitName, i, "HARMFUL")
else
debuff, texture, count, debuffType, duration, endTime, unitCaster, _, _, spellId = IceHUD.UnitAura(unitName, i, "HARMFUL")
end
local isMine = unitCaster == "player" local isMine = unitCaster == "player"
local result = {nil, nil, nil} local result = {nil, nil, nil}
local remaining local remaining
@ -323,7 +379,7 @@ function TargetCC.prototype:GetMaxDebuffDuration(unitName, debuffNames)
while debuff do while debuff do
remaining = endTime - GetTime() remaining = endTime - GetTime()
if debuffNames[spellId] and (not self.moduleSettings.onlyShowForMyDebuffs or isMine) then if (debuffNames[spellId] or debuffNames[debuff]) and (not self.moduleSettings.onlyShowForMyDebuffs or isMine) then
if result[0] then if result[0] then
if result[2] < remaining then if result[2] < remaining then
result = {debuff, duration, remaining} result = {debuff, duration, remaining}
@ -335,7 +391,11 @@ function TargetCC.prototype:GetMaxDebuffDuration(unitName, debuffNames)
i = i + 1; i = i + 1;
debuff, rank, texture, count, debuffType, duration, endTime, unitCaster, _, _, spellId = UnitAura(unitName, i, "HARMFUL") if IceHUD.SpellFunctionsReturnRank then
debuff, rank, texture, count, debuffType, duration, endTime, unitCaster, _, _, spellId = IceHUD.UnitAura(unitName, i, "HARMFUL")
else
debuff, texture, count, debuffType, duration, endTime, unitCaster, _, _, spellId = IceHUD.UnitAura(unitName, i, "HARMFUL")
end
isMine = unitCaster == "player" isMine = unitCaster == "player"
end end
@ -344,11 +404,12 @@ end
function TargetCC.prototype:MyOnUpdate() function TargetCC.prototype:MyOnUpdate()
TargetCC.super.prototype.MyOnUpdate(self) TargetCC.super.prototype.MyOnUpdate(self)
self:UpdateTargetDebuffs(nil, self.unit, true) self:UpdateTargetDebuffs("internal", self.unit)
end end
function TargetCC.prototype:UpdateTargetDebuffs(event, unit, isUpdate) function TargetCC.prototype:UpdateTargetDebuffs(event, unit)
local name, duration, remaining local name, duration, remaining
local isUpdate = event == "internal"
if not isUpdate or not self.lastUpdateTime then if not isUpdate or not self.lastUpdateTime then
self.debuffName, self.debuffDuration, self.debuffRemaining = self:GetMaxDebuffDuration(self.unit, self.debuffList) self.debuffName, self.debuffDuration, self.debuffRemaining = self:GetMaxDebuffDuration(self.unit, self.debuffList)

View File

@ -15,8 +15,10 @@ end
function TargetCast.prototype:Enable(core) function TargetCast.prototype:Enable(core)
TargetCast.super.prototype.Enable(self, core) TargetCast.super.prototype.Enable(self, core)
self:RegisterEvent("UNIT_SPELLCAST_INTERRUPTIBLE", "SpellCastInterruptible") if IceHUD.EventExistsSpellcastInterruptible then
self:RegisterEvent("UNIT_SPELLCAST_NOT_INTERRUPTIBLE", "SpellCastNotInterruptible") self:RegisterEvent("UNIT_SPELLCAST_INTERRUPTIBLE", "SpellCastInterruptible")
self:RegisterEvent("UNIT_SPELLCAST_NOT_INTERRUPTIBLE", "SpellCastNotInterruptible")
end
end end
@ -63,7 +65,12 @@ function TargetCast.prototype:GetDefaultSettings()
settings["side"] = IceCore.Side.Right settings["side"] = IceCore.Side.Right
settings["offset"] = 3 settings["offset"] = 3
settings["flashInstants"] = "Never" settings["flashInstants"] = "Never"
settings["flashFailures"] = "Never" -- Fulzamoth 2019-09-27 : let the flash handler work if in Classic and LibClassicCasterino exists
if LibClassicCasterino then
settings["flashFailures"] = ""
else
settings["flashFailures"] = "Never"
end
settings["shouldAnimate"] = false settings["shouldAnimate"] = false
settings["hideAnimationSettings"] = true settings["hideAnimationSettings"] = true
settings["usesDogTagStrings"] = false settings["usesDogTagStrings"] = false
@ -82,18 +89,24 @@ function TargetCast.prototype:TargetChanged(unit)
return return
end end
local spell, _, _, _, _, _, _, _, notInterruptibleCast = UnitCastingInfo(self.unit) if UnitCastingInfo then
if (spell) then local spell = UnitCastingInfo(self.unit)
self.notInterruptible = notInterruptibleCast local notInterruptible = select(IceHUD.SpellFunctionsReturnRank and 9 or 8, UnitCastingInfo(self.unit))
self:StartBar(IceCastBar.Actions.Cast) if spell then
return self.notInterruptible = notInterruptibleCast
self:StartBar(IceCastBar.Actions.Cast)
return
end
end end
local channel, _, _, _, _, _, _, notInterruptibleChannel = UnitChannelInfo(self.unit) if UnitChannelInfo then
if (channel) then local channel = UnitChannelInfo(self.unit)
self.notInterruptible = notInterruptibleChannel notInterruptible = select(IceHUD.SpellFunctionsReturnRank and 8 or 7, UnitChannelInfo(self.unit))
self:StartBar(IceCastBar.Actions.Channel) if channel then
return self.notInterruptible = notInterruptibleChannel
self:StartBar(IceCastBar.Actions.Channel)
return
end
end end
self:StopBar() self:StopBar()
@ -167,13 +180,18 @@ function TargetCast.prototype:GetOptions()
end end
function TargetCast.prototype:StartBar(action, message) function TargetCast.prototype:StartBar(action, message)
local spell, rank, displayName, icon, startTime, endTime, isTradeSkill, castId, notInterruptible = UnitCastingInfo(self.unit) local spell, notInterruptible
if not (spell) then if UnitCastingInfo then
spell, rank, displayName, icon, startTime, endTime, isTradeSkill, notInterruptible = UnitChannelInfo(self.unit) spell = UnitCastingInfo(self.unit)
notInterruptible = select(IceHUD.SpellFunctionsReturnRank and 9 or 8, UnitCastingInfo(self.unit))
end end
if UnitChannelInfo and not spell then
spell = UnitChannelInfo(self.unit)
notInterruptible = select(IceHUD.SpellFunctionsReturnRank and 8 or 7, UnitChannelInfo(self.unit))
if not spell then if not spell then
return return
end
end end
self.notInterruptible = notInterruptible self.notInterruptible = notInterruptible
@ -184,5 +202,8 @@ end
------------------------------------------------------------------------------- -------------------------------------------------------------------------------
-- Fulzamoth 2019-09-27 : load in Classic if LibClassicCasterino exists
-- Load us up -- Load us up
IceHUD.TargetCast = TargetCast:new() if IceHUD.CanShowTargetCasting then
IceHUD.TargetCast = TargetCast:new()
end

View File

@ -3,6 +3,11 @@ IceTargetHealth = IceCore_CreateClass(IceUnitBar)
local IceHUD = _G.IceHUD local IceHUD = _G.IceHUD
local IsAddOnLoaded = IsAddOnLoaded
if not IsAddOnLoaded and C_AddOns then
IsAddOnLoaded = C_AddOns.IsAddOnLoaded
end
IceTargetHealth.prototype.color = nil IceTargetHealth.prototype.color = nil
IceTargetHealth.prototype.determineColor = true IceTargetHealth.prototype.determineColor = true
IceTargetHealth.prototype.registerEvents = true IceTargetHealth.prototype.registerEvents = true
@ -43,7 +48,7 @@ function IceTargetHealth.prototype:GetDefaultSettings()
settings["classColor"] = false settings["classColor"] = false
settings["hideBlizz"] = false settings["hideBlizz"] = false
settings["upperText"] = "[PercentHP:Round]" settings["upperText"] = "[PercentHP:Round]"
settings["lowerText"] = "[(HP:Round \"/\" MaxHP:Round):HPColor:Bracket]" settings["lowerText"] = "[FractionalHP:Short:HPColor:Bracket]"
settings["raidIconOnTop"] = true settings["raidIconOnTop"] = true
settings["showRaidIcon"] = true settings["showRaidIcon"] = true
settings["raidIconXOffset"] = 12 settings["raidIconXOffset"] = 12
@ -637,9 +642,15 @@ function IceTargetHealth.prototype:Enable(core)
self:RegisterEvent("UPDATE_FACTION", "CheckPvP") self:RegisterEvent("UPDATE_FACTION", "CheckPvP")
self:RegisterEvent("PLAYER_FLAGS_CHANGED", "CheckPvP") self:RegisterEvent("PLAYER_FLAGS_CHANGED", "CheckPvP")
self:RegisterEvent("UNIT_FACTION", "CheckPvP") self:RegisterEvent("UNIT_FACTION", "CheckPvP")
self:RegisterEvent("LFG_PROPOSAL_UPDATE", "CheckPartyRole") if GetLFGRoles then
self:RegisterEvent("LFG_PROPOSAL_FAILED", "CheckPartyRole") self:RegisterEvent("LFG_PROPOSAL_UPDATE", "CheckPartyRole")
self:RegisterEvent("LFG_ROLE_UPDATE", "CheckPartyRole") self:RegisterEvent("LFG_PROPOSAL_FAILED", "CheckPartyRole")
self:RegisterEvent("LFG_ROLE_UPDATE", "CheckPartyRole")
end
if IceHUD.ShouldUpdateTargetHealthEveryTick and self.unit == "target" then
self.frame:SetScript("OnUpdate", function() self:Update(self.unit) end)
end
end end
if (self.moduleSettings.hideBlizz) then if (self.moduleSettings.hideBlizz) then
@ -657,6 +668,10 @@ function IceTargetHealth.prototype:Disable(core)
UnregisterUnitWatch(self.frame) UnregisterUnitWatch(self.frame)
if self.registerEvents and IceHUD.ShouldUpdateTargetHealthEveryTick and self.unit == "target" then
self.frame:SetScript("OnUpdate", nil)
end
if self.moduleSettings.hideBlizz then if self.moduleSettings.hideBlizz then
self:ShowBlizz() self:ShowBlizz()
end end
@ -698,13 +713,6 @@ function IceTargetHealth.prototype:CreateBackground(redraw)
self.frame.button:SetPoint("BOTTOMRIGHT", self.frame, "BOTTOMRIGHT", -1 * self.frame:GetWidth() / 1.5, 0) self.frame.button:SetPoint("BOTTOMRIGHT", self.frame, "BOTTOMRIGHT", -1 * self.frame:GetWidth() / 1.5, 0)
end end
end end
if not self.frame.button.menu then
self.frame.button.menu = function(this, unit)
IceHUD.DropdownUnit = unit
ToggleDropDownMenu(1, nil, IceHUD_UnitFrame_DropDown, "cursor")
end
end
end end
end end
@ -718,7 +726,7 @@ function IceTargetHealth.prototype:EnableClickTargeting(bEnable)
self.frame.button:EnableMouse(true) self.frame.button:EnableMouse(true)
self.frame.button:RegisterForClicks("AnyUp") self.frame.button:RegisterForClicks("AnyUp")
self.frame.button:SetAttribute("type1", "target") self.frame.button:SetAttribute("type1", "target")
self.frame.button:SetAttribute("type2", "menu") self.frame.button:SetAttribute("type2", "togglemenu")
self.frame.button:SetAttribute("unit", self.unit) self.frame.button:SetAttribute("unit", self.unit)
-- set up click casting -- set up click casting
@ -831,6 +839,8 @@ function IceTargetHealth.prototype:Update(unit)
if (self.moduleSettings.scaleHealthColor) then if (self.moduleSettings.scaleHealthColor) then
self.color = "ScaledHealthColor" self.color = "ScaledHealthColor"
elseif self.moduleSettings.lowThresholdColor and self.healthPercentage <= self.moduleSettings.lowThreshold then
self.color = "ScaledHealthColor"
end end
if (self.tapped) then if (self.tapped) then
@ -840,21 +850,46 @@ function IceTargetHealth.prototype:Update(unit)
self:UpdateBar(self.healthPercentage, self.color) self:UpdateBar(self.healthPercentage, self.color)
if not IceHUD.IceCore:ShouldUseDogTags() and self.frame:IsVisible() then if IsAddOnLoaded("RealMobHealth") then
self:SetBottomText1(math.floor(self.healthPercentage * 100)) if not IceHUD.IceCore:ShouldUseDogTags() and self.frame:IsVisible() then
self:SetBottomText1(math.floor(self.healthPercentage * 100))
if self.moduleSettings.abbreviateHealth then if self.moduleSettings.abbreviateHealth then
self.health = self:Round(self.health) if RealMobHealth.UnitHasHealthData(unit) then
self.maxHealth = self:Round(self.maxHealth) self.health, self.maxHealth = RealMobHealth.GetUnitHealth(unit)
end end
self.health = self:Round(self.health)
self.maxHealth = self:Round(self.maxHealth)
end
if (self.maxHealth ~= 100) then if RealMobHealth.UnitHasHealthData(unit) or (self.maxHealth ~= 100) then
self:SetBottomText2(self:GetFormattedText(self.health, self.maxHealth), self.color) if RealMobHealth.UnitHasHealthData(unit) then
else self.health, self.maxHealth = RealMobHealth.GetUnitHealth(unit)
self:SetBottomText2() self:SetBottomText2(self:GetFormattedText(self.health, self.maxHealth), self.color)
else
self:SetBottomText2(self:GetFormattedText(self.health, self.maxHealth), self.color)
end
else
self:SetBottomText2()
end
end end
else
if not IceHUD.IceCore:ShouldUseDogTags() and self.frame:IsVisible() then
self:SetBottomText1(math.floor(self.healthPercentage * 100))
if self.moduleSettings.abbreviateHealth then
self.health = self:Round(self.health)
self.maxHealth = self:Round(self.maxHealth)
end
if (self.maxHealth ~= 100) then
self:SetBottomText2(self:GetFormattedText(self.health, self.maxHealth), self.color)
else
self:SetBottomText2()
end
end
end end
self:CheckPvP() self:CheckPvP()
self:CheckPartyRole() self:CheckPartyRole()
self:SetIconAlpha() self:SetIconAlpha()
@ -947,9 +982,9 @@ end
function IceTargetHealth.prototype:UpdateRaidTargetIcon() function IceTargetHealth.prototype:UpdateRaidTargetIcon()
if self.moduleSettings.raidIconOnTop then if self.moduleSettings.raidIconOnTop then
self.frame.raidIcon:SetFrameStrata("MEDIUM") self.frame.raidIcon:SetFrameStrata(IceHUD.IceCore:DetermineStrata("MEDIUM"))
else else
self.frame.raidIcon:SetFrameStrata("LOW") self.frame.raidIcon:SetFrameStrata(IceHUD.IceCore:DetermineStrata("LOW"))
end end
if not self.moduleSettings.showRaidIcon or (not UnitExists(self.unit) and (not self.configMode and not IceHUD.IceCore:IsInConfigMode())) then if not self.moduleSettings.showRaidIcon or (not UnitExists(self.unit) and (not self.configMode and not IceHUD.IceCore:IsInConfigMode())) then
@ -972,17 +1007,6 @@ function IceTargetHealth.prototype:UpdateRaidTargetIcon()
end end
function IceTargetHealth.prototype:Round(health)
if (health > 1000000) then
return IceHUD:MathRound(health/1000000, 1) .. "M"
end
if (health > 1000) then
return IceHUD:MathRound(health/1000, 1) .. "k"
end
return health
end
function IceTargetHealth.prototype:CheckPvP() function IceTargetHealth.prototype:CheckPvP()
local pvpMode = nil local pvpMode = nil
local minx, maxx, miny, maxy local minx, maxx, miny, maxy
@ -1041,20 +1065,25 @@ end
function IceTargetHealth.prototype:ShowBlizz() function IceTargetHealth.prototype:ShowBlizz()
TargetFrame:Show() TargetFrame:SetParent(self.OriginalTargetFrameParent or UIParent)
TargetFrame:GetScript("OnLoad")(TargetFrame) ComboFrame:SetParent(self.OriginalComboFrameParent or UIParent)
ComboFrame:Show()
ComboFrame:GetScript("OnLoad")(ComboFrame)
end end
function IceTargetHealth.prototype:HideBlizz() function IceTargetHealth.prototype:HideBlizz()
TargetFrame:Hide() if not self.TargetFrameParent then
TargetFrame:UnregisterAllEvents() self.TargetFrameParent = CreateFrame("Frame")
self.TargetFrameParent:Hide()
end
if not self.ComboFrameParent then
self.ComboFrameParent = CreateFrame("Frame")
self.ComboFrameParent:Hide()
end
ComboFrame:Hide() self.OriginalTargetFrameParent = TargetFrame:GetParent()
ComboFrame:UnregisterAllEvents() TargetFrame:SetParent(self.TargetFrameParent)
self.OriginalComboFrameParent = ComboFrame:GetParent()
ComboFrame:SetParent(self.ComboFrameParent)
end end
function IceTargetHealth.prototype:UpdateBar(scale, color, alpha) function IceTargetHealth.prototype:UpdateBar(scale, color, alpha)
@ -1074,12 +1103,12 @@ function IceTargetHealth.prototype:CheckPartyRole()
if self.configMode or IceHUD:GetIsInLFGGroup() then if self.configMode or IceHUD:GetIsInLFGGroup() then
if self.configMode or self.moduleSettings.showPartyRoleIcon then if self.configMode or self.moduleSettings.showPartyRoleIcon then
local isTank, isHeal, isDPS local isTank, isHeal, isDPS
local proposalExists, typeID, id, name local proposalExists, typeID, id, subtypeID, name
local texture, role, hasResponded, totalEncounters, completedEncounters, numMembers, isleader local texture, role, hasResponded, totalEncounters, completedEncounters, numMembers, isleader
proposalExists, typeID, id, name, texture, role, hasResponded, totalEncounters, completedEncounters, numMembers, isleader = GetLFGProposal() proposalExists, id, typeID, subtypeID, name, texture, role, hasResponded, totalEncounters, completedEncounters, numMembers, isleader = GetLFGProposal()
local p = self.unit local p = self.unit
if IceHUD.WowVer < 40000 then if not IceHUD.UnitGroupRolesReturnsRoleString then
isTank, isHeal, isDPS = UnitGroupRolesAssigned(p) isTank, isHeal, isDPS = UnitGroupRolesAssigned(p)
else else
local grpRole = UnitGroupRolesAssigned(p) local grpRole = UnitGroupRolesAssigned(p)

View File

@ -2,7 +2,7 @@ local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false)
IceTargetInfo = IceCore_CreateClass(IceElement) IceTargetInfo = IceCore_CreateClass(IceElement)
local CooldownFrame_SetTimer = CooldownFrame_SetTimer local CooldownFrame_SetTimer = CooldownFrame_SetTimer
if IceHUD.WowVer >= 70000 then if CooldownFrame_Set then
CooldownFrame_SetTimer = CooldownFrame_Set CooldownFrame_SetTimer = CooldownFrame_Set
end end
@ -12,6 +12,10 @@ local internal = "internal"
local ValidAnchors = { "TOPLEFT", "TOPRIGHT", "BOTTOMLEFT", "BOTTOMRIGHT", "CENTER" } local ValidAnchors = { "TOPLEFT", "TOPRIGHT", "BOTTOMLEFT", "BOTTOMRIGHT", "CENTER" }
---- Fulzamoth - 2019-09-04 : support for cooldowns on target buffs/debuffs (classic)
local LibClassicDurations = LibStub("LibClassicDurations", 1)
---- end change by Fulzamoth
IceTargetInfo.prototype.unit = "target" IceTargetInfo.prototype.unit = "target"
IceTargetInfo.prototype.buffSize = nil IceTargetInfo.prototype.buffSize = nil
@ -129,7 +133,9 @@ function IceTargetInfo.prototype:Enable(core)
self:RegisterEvent("UNIT_LEVEL", "TargetLevel") self:RegisterEvent("UNIT_LEVEL", "TargetLevel")
self:RegisterEvent("UNIT_FLAGS", "TargetFlags") self:RegisterEvent("UNIT_FLAGS", "TargetFlags")
self:RegisterEvent("UNIT_DYNAMIC_FLAGS", "TargetFlags") if IceHUD.EventExistsUnitDynamicFlags then
self:RegisterEvent("UNIT_DYNAMIC_FLAGS", "TargetFlags")
end
self:RegisterEvent("RAID_TARGET_UPDATE", "UpdateRaidTargetIcon") self:RegisterEvent("RAID_TARGET_UPDATE", "UpdateRaidTargetIcon")
@ -958,6 +964,23 @@ function IceTargetInfo.prototype:GetOptions()
order = 39.3, order = 39.3,
} }
opts["showRaidIcon"] = {
type = 'toggle',
name = L['Show raid icon'],
desc = L['Whether or not to show the raid icon for this unit.'],
get = function()
return self.moduleSettings.showRaidIcon
end,
set = function(info, v)
self.moduleSettings.showRaidIcon = v
self:UpdateRaidTargetIcon()
end,
disabled = function()
return not self.moduleSettings.enabled
end,
order = 37.02,
}
return opts return opts
end end
@ -1011,6 +1034,7 @@ function IceTargetInfo.prototype:GetDefaultSettings()
["sortByExpiration"] = true, ["sortByExpiration"] = true,
} }
} }
defaults["showRaidIcon"] = true
return defaults return defaults
end end
@ -1112,7 +1136,7 @@ do -- OVERRIDE: IceTargetInfo.prototype:CreateFrame(redraw)
self.frame:SetScale(self.moduleSettings.scale) self.frame:SetScale(self.moduleSettings.scale)
self.frame:SetFrameStrata("BACKGROUND") self.frame:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
self.frame:SetWidth(self.width) self.frame:SetWidth(self.width)
self.frame:SetHeight(32) self.frame:SetHeight(32)
self.frame:ClearAllPoints() self.frame:ClearAllPoints()
@ -1126,7 +1150,7 @@ do -- OVERRIDE: IceTargetInfo.prototype:CreateFrame(redraw)
self.frame:SetScript("OnLeave", function(frame) self:OnLeave(frame) end) self.frame:SetScript("OnLeave", function(frame) self:OnLeave(frame) end)
self.frame:SetAttribute("type1", "target") self.frame:SetAttribute("type1", "target")
self.frame:SetAttribute("type2", "menu") self.frame:SetAttribute("type2", "togglemenu")
-- set up click casting -- set up click casting
ClickCastFrames = ClickCastFrames or {} ClickCastFrames = ClickCastFrames or {}
@ -1149,13 +1173,6 @@ do -- OVERRIDE: IceTargetInfo.prototype:CreateFrame(redraw)
self.frame:SetAttribute("unit", self.unit) self.frame:SetAttribute("unit", self.unit)
if not self.frame.menu then
self.frame.menu = function(this, unit)
IceHUD.DropdownUnit = unit
ToggleDropDownMenu(1, nil, IceHUD_UnitFrame_DropDown, "cursor")
end
end
-- create a fancy highlight frame for mouse over -- create a fancy highlight frame for mouse over
if (not self.frame.highLight) then if (not self.frame.highLight) then
@ -1196,7 +1213,7 @@ function IceTargetInfo.prototype:CreateAuraFrame(aura, redraw)
if (not self.frame[auraFrame]) then if (not self.frame[auraFrame]) then
self.frame[auraFrame] = CreateFrame("Frame", nil, self.frame) self.frame[auraFrame] = CreateFrame("Frame", nil, self.frame)
self.frame[auraFrame]:SetFrameStrata("BACKGROUND") self.frame[auraFrame]:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
self.frame[auraFrame]:SetWidth(1) self.frame[auraFrame]:SetWidth(1)
self.frame[auraFrame]:SetHeight(1) self.frame[auraFrame]:SetHeight(1)
self.frame[auraFrame]:Show() self.frame[auraFrame]:Show()
@ -1220,7 +1237,7 @@ end
do do
local function FrameFactory(frameType, parentFrame, inheritsFrame) local function FrameFactory(frameType, parentFrame, inheritsFrame)
local frame = CreateFrame(frameType, nil, parentFrame, inheritsFrame) local frame = CreateFrame(frameType, nil, parentFrame, inheritsFrame)
frame:SetFrameStrata("BACKGROUND") frame:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
frame:ClearAllPoints() frame:ClearAllPoints()
return frame return frame
end end
@ -1389,7 +1406,29 @@ function IceTargetInfo.prototype:UpdateBuffType(aura)
if self.moduleSettings.auras[aura].show then if self.moduleSettings.auras[aura].show then
for i = 1, IceCore.BuffLimit do for i = 1, IceCore.BuffLimit do
local name, rank, icon, count, debuffType, duration, expirationTime, unitCaster, isStealable = UnitAura(self.unit, i, reaction .. (filter and "|PLAYER" or "")) local name, rank, icon, count, debuffType, duration, expirationTime, unitCaster, isStealable
---- Fulzamoth - 2019-09-04 : support for cooldowns on target buffs/debuffs (classic)
local spellID
---- end change by Fulzamoth
if IceHUD.SpellFunctionsReturnRank then
name, rank, icon, count, debuffType, duration, expirationTime, unitCaster, isStealable = IceHUD.UnitAura(self.unit, i, reaction .. (filter and "|PLAYER" or ""))
else
---- Fulzamoth - 2019-09-04 : support for cooldowns on target buffs/debuffs (classic)
-- 1. in addition to other info, get the spellID for for the (de)buff
name, icon, count, debuffType, duration, expirationTime, unitCaster, isStealable, _, spellID = IceHUD.UnitAura(self.unit, i, reaction .. (filter and "|PLAYER" or ""))
if duration == 0 and LibClassicDurations then
-- 2. if no duration defined for the (de)buff, look up the spell in LibClassicDurations
local classicDuration, classicExpirationTime = LibClassicDurations:GetAuraDurationByUnit(self.unit, spellID, caster)
-- 3. set the duration if we found one.
if classicDuration then
duration = classicDuration
expirationTime = classicExpirationTime
end
end
---- end change by Fulzamoth
end
local isFromMe = (unitCaster == "player") local isFromMe = (unitCaster == "player")
if not icon and IceHUD.IceCore:IsInConfigMode() and UnitExists(self.unit) then if not icon and IceHUD.IceCore:IsInConfigMode() and UnitExists(self.unit) then
@ -1407,7 +1446,7 @@ function IceTargetInfo.prototype:UpdateBuffType(aura)
end end
else else
self.frame[auraFrame].iconFrames[i]:Hide() self.frame[auraFrame].iconFrames[i]:Hide()
buffData[aura][i] = nil table.remove(buffData[aura], i)
end end
end end
end end
@ -1480,7 +1519,7 @@ function IceTargetInfo.prototype:AuraChanged(event, unit)
end end
function IceTargetInfo.prototype:UpdateRaidTargetIcon() function IceTargetInfo.prototype:UpdateRaidTargetIcon()
if not (UnitExists(self.unit)) then if not (UnitExists(self.unit)) or not self.moduleSettings.showRaidIcon then
self.frame.raidIcon:Hide() self.frame.raidIcon:Hide()
return return
end end
@ -1559,7 +1598,7 @@ function IceTargetInfo.prototype:TargetName(event, unit)
end end
if IceHUD.WowVer < 50000 then if UnitIsPartyLeader then
self.leader = UnitIsPartyLeader(self.unit) and " |cffcccc11Leader|r" or "" self.leader = UnitIsPartyLeader(self.unit) and " |cffcccc11Leader|r" or ""
else else
self.leader = UnitIsGroupLeader(self.unit) and " |cffcccc11Leader|r" or "" self.leader = UnitIsGroupLeader(self.unit) and " |cffcccc11Leader|r" or ""
@ -1630,7 +1669,7 @@ end
function IceTargetInfo.prototype:TargetFlags(event, unit) function IceTargetInfo.prototype:TargetFlags(event, unit)
if (unit == self.unit or unit == internal) then if (unit == self.unit or unit == internal) then
if IceHUD.WowVer < 70000 then if UnitIsTapped then
self.tapped = UnitIsTapped(self.unit) and (not UnitIsTappedByPlayer(self.unit)) self.tapped = UnitIsTapped(self.unit) and (not UnitIsTappedByPlayer(self.unit))
else else
self.tapped = UnitIsTapDenied(self.unit) self.tapped = UnitIsTapDenied(self.unit)

View File

@ -7,11 +7,30 @@ TargetInvuln.prototype.buffRemaining = 0
TargetInvuln.prototype.buffDuration = 0 TargetInvuln.prototype.buffDuration = 0
local GetNumPartyMembers, GetNumRaidMembers = GetNumPartyMembers, GetNumRaidMembers local GetNumPartyMembers, GetNumRaidMembers = GetNumPartyMembers, GetNumRaidMembers
if IceHUD.WowVer >= 50000 then if GetNumGroupMembers then
GetNumPartyMembers = GetNumGroupMembers GetNumPartyMembers = GetNumGroupMembers
GetNumRaidMembers = GetNumGroupMembers GetNumRaidMembers = GetNumGroupMembers
end end
local GetSpellInfo = GetSpellInfo
if not GetSpellInfo and C_Spell and C_Spell.GetSpellInfo then
GetSpellInfo = function(spellID)
if not spellID then
return nil
end
local spellInfo = C_Spell.GetSpellInfo(spellID)
if spellInfo then
return spellInfo.name, nil, spellInfo.iconID, spellInfo.castTime, spellInfo.minRange, spellInfo.maxRange, spellInfo.spellID, spellInfo.originalIconID
end
end
end
local GetSpellName = GetSpellInfo
if C_Spell and C_Spell.GetSpellName then
GetSpellName = C_Spell.GetSpellName
end
-- list of spell ID's for each CC type so we can avoid localization issues -- list of spell ID's for each CC type so we can avoid localization issues
local InvulnList= { local InvulnList= {
-- Anti-Magic Shell -- Anti-Magic Shell
@ -76,7 +95,7 @@ function TargetInvuln.prototype:PopulateSpellList(buffListVar, ccList, ccName)
local spellName local spellName
for i=1,#ccList do for i=1,#ccList do
spellName = GetSpellInfo(ccList[i]) spellName = GetSpellName(ccList[i])
if spellName and spellName ~= "" then if spellName and spellName ~= "" then
buffListVar[spellName] = ccName buffListVar[spellName] = ccName
@ -146,7 +165,12 @@ end
function TargetInvuln.prototype:GetMaxbuffDuration(unitName, buffNames) function TargetInvuln.prototype:GetMaxbuffDuration(unitName, buffNames)
local i = 1 local i = 1
local buff, rank, texture, count, buffType, duration, endTime, unitCaster = UnitAura(unitName, i, "HELPFUL") local buff, rank, texture, count, buffType, duration, endTime, unitCaster
if IceHUD.SpellFunctionsReturnRank then
buff, rank, texture, count, buffType, duration, endTime, unitCaster = IceHUD.UnitAura(unitName, i, "HELPFUL")
else
buff, texture, count, buffType, duration, endTime, unitCaster = IceHUD.UnitAura(unitName, i, "HELPFUL")
end
local isMine = unitCaster == "player" local isMine = unitCaster == "player"
local result = {nil, nil, nil} local result = {nil, nil, nil}
local remaining local remaining
@ -173,7 +197,11 @@ function TargetInvuln.prototype:GetMaxbuffDuration(unitName, buffNames)
i = i + 1; i = i + 1;
buff, rank, texture, count, buffType, duration, endTime, unitCaster = UnitAura(unitName, i, "HELPFUL") if IceHUD.SpellFunctionsReturnRank then
buff, rank, texture, count, buffType, duration, endTime, unitCaster = IceHUD.UnitAura(unitName, i, "HELPFUL")
else
buff, texture, count, buffType, duration, endTime, unitCaster = IceHUD.UnitAura(unitName, i, "HELPFUL")
end
isMine = unitCaster == "player" isMine = unitCaster == "player"
end end
@ -182,13 +210,14 @@ end
function TargetInvuln.prototype:MyOnUpdate() function TargetInvuln.prototype:MyOnUpdate()
TargetInvuln.super.prototype.MyOnUpdate(self) TargetInvuln.super.prototype.MyOnUpdate(self)
self:UpdateTargetBuffs(nil, self.unit, true) self:UpdateTargetBuffs("internal", self.unit)
end end
function TargetInvuln.prototype:UpdateTargetBuffs(event, unit, isUpdate) function TargetInvuln.prototype:UpdateTargetBuffs(event, unit)
local name, duration, remaining local name, duration, remaining
local isUpdate = event == "internal"
if not isUpdate then if not isUpdate or not self.lastUpdateTime then
self.buffName, self.buffDuration, self.buffRemaining = self:GetMaxbuffDuration(self.unit, self.buffList) self.buffName, self.buffDuration, self.buffRemaining = self:GetMaxbuffDuration(self.unit, self.buffList)
else else
self.buffRemaining = math.max(0, self.buffRemaining - (GetTime() - self.lastUpdateTime)) self.buffRemaining = math.max(0, self.buffRemaining - (GetTime() - self.lastUpdateTime))

View File

@ -4,6 +4,28 @@ IceTargetMana.prototype.registerEvents = true
IceTargetMana.prototype.color = nil IceTargetMana.prototype.color = nil
IceTargetMana.prototype.determineColor = true IceTargetMana.prototype.determineColor = true
local SPELL_POWER_MANA = SPELL_POWER_MANA
local SPELL_POWER_RAGE = SPELL_POWER_RAGE
local SPELL_POWER_FOCUS = SPELL_POWER_FOCUS
local SPELL_POWER_ENERGY = SPELL_POWER_ENERGY
local SPELL_POWER_RUNIC_POWER = SPELL_POWER_RUNIC_POWER
local SPELL_POWER_INSANITY = SPELL_POWER_INSANITY
local SPELL_POWER_FURY = SPELL_POWER_FURY
local SPELL_POWER_MAELSTROM = SPELL_POWER_MAELSTROM
local SPELL_POWER_PAIN = SPELL_POWER_PAIN
local SPELL_POWER_LUNAR_POWER = SPELL_POWER_LUNAR_POWER
if Enum and Enum.PowerType then
SPELL_POWER_MANA = Enum.PowerType.Mana
SPELL_POWER_RAGE = Enum.PowerType.Rage
SPELL_POWER_FOCUS = Enum.PowerType.Focus
SPELL_POWER_ENERGY = Enum.PowerType.Energy
SPELL_POWER_RUNIC_POWER = Enum.PowerType.RunicPower
SPELL_POWER_INSANITY = Enum.PowerType.Insanity
SPELL_POWER_FURY = Enum.PowerType.Fury
SPELL_POWER_MAELSTROM = Enum.PowerType.Maelstrom
SPELL_POWER_PAIN = Enum.PowerType.Pain
SPELL_POWER_LUNAR_POWER = Enum.PowerType.LunarPower
end
-- Constructor -- -- Constructor --
function IceTargetMana.prototype:init(moduleName, unit) function IceTargetMana.prototype:init(moduleName, unit)
@ -33,7 +55,7 @@ function IceTargetMana.prototype:GetDefaultSettings()
settings["side"] = IceCore.Side.Right settings["side"] = IceCore.Side.Right
settings["offset"] = 2 settings["offset"] = 2
settings["upperText"] = "[PercentMP:Round]" settings["upperText"] = "[PercentMP:Round]"
settings["lowerText"] = "[FractionalMP:PowerColor]" settings["lowerText"] = "[FractionalMP:Short:PowerColor]"
settings["onlyShowMana"] = false settings["onlyShowMana"] = false
return settings return settings
@ -44,9 +66,11 @@ function IceTargetMana.prototype:Enable(core)
IceTargetMana.super.prototype.Enable(self, core) IceTargetMana.super.prototype.Enable(self, core)
if self.registerEvents then if self.registerEvents then
if IceHUD.WowVer >= 40000 then if not IceHUD.PerPowerEventsExist then
self:RegisterEvent("UNIT_POWER", "UpdateEvent") self:RegisterEvent(IceHUD.UnitPowerEvent, "UpdateEvent")
self:RegisterEvent("UNIT_MAXPOWER", "UpdateEvent") if IceHUD.EventExistsUnitMaxPower then
self:RegisterEvent("UNIT_MAXPOWER", "UpdateEvent")
end
else else
self:RegisterEvent("UNIT_MAXMANA", "UpdateEvent") self:RegisterEvent("UNIT_MAXMANA", "UpdateEvent")
self:RegisterEvent("UNIT_MAXRAGE", "UpdateEvent") self:RegisterEvent("UNIT_MAXRAGE", "UpdateEvent")
@ -59,7 +83,7 @@ function IceTargetMana.prototype:Enable(core)
self:RegisterEvent("UNIT_FOCUS", "UpdateEvent") self:RegisterEvent("UNIT_FOCUS", "UpdateEvent")
-- DK rune stuff -- DK rune stuff
if IceHUD.WowVer >= 30000 then if SPELL_POWER_RUNIC_POWER then
self:RegisterEvent("UNIT_RUNIC_POWER", "UpdateEvent") self:RegisterEvent("UNIT_RUNIC_POWER", "UpdateEvent")
self:RegisterEvent("UNIT_MAXRUNIC_POWER", "UpdateEvent") self:RegisterEvent("UNIT_MAXRUNIC_POWER", "UpdateEvent")
end end
@ -101,6 +125,8 @@ function IceTargetMana.prototype:Update(unit)
if (self.moduleSettings.scaleManaColor) then if (self.moduleSettings.scaleManaColor) then
self.color = "ScaledManaColor" self.color = "ScaledManaColor"
elseif self.moduleSettings.lowThresholdColor and self.manaPercentage <= self.moduleSettings.lowThreshold then
self.color = "ScaledManaColor"
end end
if (manaType == SPELL_POWER_RAGE) then if (manaType == SPELL_POWER_RAGE) then
@ -111,13 +137,13 @@ function IceTargetMana.prototype:Update(unit)
self.color = "TargetEnergy" self.color = "TargetEnergy"
elseif (manaType == SPELL_POWER_RUNIC_POWER) then elseif (manaType == SPELL_POWER_RUNIC_POWER) then
self.color = "TargetRunicPower" self.color = "TargetRunicPower"
elseif (IceHUD.WowVer >= 70000 and manaType == SPELL_POWER_INSANITY) then elseif (manaType == SPELL_POWER_INSANITY) then
self.color = "TargetInsanity" self.color = "TargetInsanity"
elseif (IceHUD.WowVer >= 70000 and manaType == SPELL_POWER_FURY) then elseif (manaType == SPELL_POWER_FURY) then
self.color = "TargetFury" self.color = "TargetFury"
elseif (IceHUD.WowVer >= 70000 and manaType == SPELL_POWER_MAELSTROM) then elseif (manaType == SPELL_POWER_MAELSTROM) then
self.color = "TargetMaelstrom" self.color = "TargetMaelstrom"
elseif (IceHUD.WowVer >= 70000 and manaType == SPELL_POWER_PAIN) then elseif (manaType == SPELL_POWER_PAIN) then
self.color = "TargetPain" self.color = "TargetPain"
end end
@ -132,7 +158,7 @@ function IceTargetMana.prototype:Update(unit)
if not IceHUD.IceCore:ShouldUseDogTags() then if not IceHUD.IceCore:ShouldUseDogTags() then
self:SetBottomText1(math.floor(self.manaPercentage * 100)) self:SetBottomText1(math.floor(self.manaPercentage * 100))
self:SetBottomText2(self:GetFormattedText(self.mana, self.maxMana), color) self:SetBottomText2(self:GetFormattedText(self.mana, self.maxMana), self.color)
end end
end end

View File

@ -4,6 +4,18 @@ local DogTag = nil
local TargetOfTarget = IceCore_CreateClass(IceElement) local TargetOfTarget = IceCore_CreateClass(IceElement)
local UnitDebuff = UnitDebuff
if not UnitDebuff and C_UnitAuras and AuraUtil then
UnitDebuff = function(unitToken, index, filter)
local auraData = C_UnitAuras.GetDebuffDataByIndex(unitToken, index, filter)
if not auraData then
return nil
end
return AuraUtil.UnpackAuraData(auraData)
end
end
TargetOfTarget.prototype.stackedDebuffs = nil TargetOfTarget.prototype.stackedDebuffs = nil
TargetOfTarget.prototype.buffSize = nil TargetOfTarget.prototype.buffSize = nil
TargetOfTarget.prototype.height = nil TargetOfTarget.prototype.height = nil
@ -124,24 +136,26 @@ function TargetOfTarget.prototype:GetOptions()
order = 34 order = 34
} }
opts["texture"] = { if AceGUIWidgetLSMlists then
type = 'select', opts["texture"] = {
dialogControl = "LSM30_Statusbar", type = 'select',
name = L["Texture"], dialogControl = "LSM30_Statusbar",
desc = L["ToT frame texture"], name = L["Texture"],
get = function(info) desc = L["ToT frame texture"],
return self.moduleSettings.texture get = function(info)
end, return self.moduleSettings.texture
set = function(info, v) end,
self.moduleSettings.texture = v set = function(info, v)
self:Redraw() self.moduleSettings.texture = v
end, self:Redraw()
disabled = function() end,
return not self.moduleSettings.enabled disabled = function()
end, return not self.moduleSettings.enabled
values = AceGUIWidgetLSMlists.statusbar, end,
order = 35 values = AceGUIWidgetLSMlists.statusbar,
} order = 35
}
end
opts["sizeToGap"] = { opts["sizeToGap"] = {
type = 'toggle', type = 'toggle',
@ -314,7 +328,7 @@ function TargetOfTarget.prototype:CreateFrame()
self.frame:SetAttribute("unit", self.unit) self.frame:SetAttribute("unit", self.unit)
end end
self.frame:SetFrameStrata("BACKGROUND") self.frame:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
if self.moduleSettings.sizeToGap then if self.moduleSettings.sizeToGap then
self.frame:SetWidth(self.settings.gap) self.frame:SetWidth(self.settings.gap)
else else
@ -368,7 +382,7 @@ function TargetOfTarget.prototype:CreateBarFrame()
self.frame.bg:SetTexture(0,0,0) self.frame.bg:SetTexture(0,0,0)
self.frame.bar:SetFrameStrata("BACKGROUND") self.frame.bar:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
if self.moduleSettings.sizeToGap then if self.moduleSettings.sizeToGap then
self.frame.bg:SetWidth(self.settings.gap + 2) self.frame.bg:SetWidth(self.settings.gap + 2)
self.frame.bar:SetWidth(self.settings.gap) self.frame.bar:SetWidth(self.settings.gap)
@ -410,7 +424,7 @@ function TargetOfTarget.prototype:CreateToTFrame()
self.frame.totName:SetHeight(self.moduleSettings.moduleHeight) self.frame.totName:SetHeight(self.moduleSettings.moduleHeight)
self.frame.totName:SetJustifyH("LEFT") self.frame.totName:SetJustifyH("LEFT")
self.frame.totName:SetJustifyV("CENTER") self.frame.totName:SetJustifyV("MIDDLE")
self.frame.totName:SetPoint("LEFT", self.frame, "LEFT", 0, -1) self.frame.totName:SetPoint("LEFT", self.frame, "LEFT", 0, -1)
self.frame.totName:Show() self.frame.totName:Show()
@ -422,7 +436,7 @@ function TargetOfTarget.prototype:CreateToTHPFrame()
self.frame.totHealth:SetHeight(self.moduleSettings.moduleHeight) self.frame.totHealth:SetHeight(self.moduleSettings.moduleHeight)
self.frame.totHealth:SetJustifyH("RIGHT") self.frame.totHealth:SetJustifyH("RIGHT")
self.frame.totHealth:SetJustifyV("CENTER") self.frame.totHealth:SetJustifyV("MIDDLE")
self.frame.totHealth:SetPoint("RIGHT", self.frame, "RIGHT", 0, 0) self.frame.totHealth:SetPoint("RIGHT", self.frame, "RIGHT", 0, 0)
self.frame.totHealth:Show() self.frame.totHealth:Show()
@ -435,7 +449,7 @@ function TargetOfTarget.prototype:CreateDebuffFrame()
end end
self.frame.debuffFrame = CreateFrame("Frame", nil, self.frame) self.frame.debuffFrame = CreateFrame("Frame", nil, self.frame)
self.frame.debuffFrame:SetFrameStrata("BACKGROUND") self.frame.debuffFrame:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
self.frame.debuffFrame:SetWidth(10) self.frame.debuffFrame:SetWidth(10)
self.frame.debuffFrame:SetHeight(self.height) self.frame.debuffFrame:SetHeight(self.height)
@ -451,7 +465,7 @@ function TargetOfTarget.prototype:CreateIconFrames(parent)
for i = 1, IceCore.BuffLimit do for i = 1, IceCore.BuffLimit do
buffs[i] = CreateFrame("Frame", nil, parent) buffs[i] = CreateFrame("Frame", nil, parent)
buffs[i]:SetFrameStrata("BACKGROUND") buffs[i]:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
buffs[i]:SetWidth(self.buffSize) buffs[i]:SetWidth(self.buffSize)
buffs[i]:SetHeight(self.buffSize) buffs[i]:SetHeight(self.buffSize)
buffs[i]:SetPoint("LEFT", (i-1) * self.buffSize + (i-1), 0) buffs[i]:SetPoint("LEFT", (i-1) * self.buffSize + (i-1), 0)
@ -485,7 +499,12 @@ function TargetOfTarget.prototype:UpdateBuffs()
if (self.moduleSettings.showDebuffs) then if (self.moduleSettings.showDebuffs) then
for i = 1, IceCore.BuffLimit do for i = 1, IceCore.BuffLimit do
local buffName, buffRank, buffTexture, buffApplications = UnitDebuff(self.unit, i) local buffName, buffRank, buffTexture, buffApplications
if IceHUD.SpellFunctionsReturnRank then
buffName, buffRank, buffTexture, buffApplications = UnitDebuff(self.unit, i)
else
buffName, buffTexture, buffApplications = UnitDebuff(self.unit, i)
end
if (buffApplications and (buffApplications > 1)) then if (buffApplications and (buffApplications > 1)) then
debuffs = debuffs + 1 debuffs = debuffs + 1

View File

@ -58,16 +58,20 @@ function TargetTargetCast.prototype:UpdateTargetTarget()
return return
end end
local spell = UnitCastingInfo(self.unit) if UnitCastingInfo then
if (spell) then local spell = UnitCastingInfo(self.unit)
self:StartBar(IceCastBar.Actions.Cast) if spell then
return self:StartBar(IceCastBar.Actions.Cast)
return
end
end end
local channel = UnitChannelInfo(self.unit) if UnitChannelInfo then
if (channel) then local channel = UnitChannelInfo(self.unit)
self:StartBar(IceCastBar.Actions.Channel) if channel then
return self:StartBar(IceCastBar.Actions.Channel)
return
end
end end
self:StopBar() self:StopBar()
@ -144,4 +148,6 @@ end
-- Load us up -- Load us up
IceHUD.TargetTargetCast = TargetTargetCast:new() if not IceHUD.WowClassic then
IceHUD.TargetTargetCast = TargetTargetCast:new()
end

View File

@ -24,7 +24,7 @@ function TargetTargetHealth.prototype:GetDefaultSettings()
settings["selfColor"] = { r = 0, g = 0, b = 1 } settings["selfColor"] = { r = 0, g = 0, b = 1 }
settings["selfDisplayMode"] = "Color as SelfColor" settings["selfDisplayMode"] = "Color as SelfColor"
settings["upperText"] = "[PercentHP:Round]" settings["upperText"] = "[PercentHP:Round]"
settings["lowerText"] = "[(HP:Round \"/\" MaxHP:Round):HPColor:Bracket]" settings["lowerText"] = "[FractionalHP:Short:HPColor:Bracket]"
settings["barVerticalOffset"] = 35 settings["barVerticalOffset"] = 35
settings["scale"] = 0.7 settings["scale"] = 0.7
settings["enabled"] = false settings["enabled"] = false
@ -136,6 +136,8 @@ function TargetTargetHealth.prototype:Update(unit)
if (self.moduleSettings.scaleHealthColor) then if (self.moduleSettings.scaleHealthColor) then
self.color = "ScaledHealthColor" self.color = "ScaledHealthColor"
elseif self.moduleSettings.lowThresholdColor and self.healthPercentage and self.healthPercentage <= self.moduleSettings.lowThreshold then
self.color = "ScaledHealthColor"
end end
if (self.tapped) then if (self.tapped) then

View File

@ -21,7 +21,7 @@ function TargetTargetMana.prototype:GetDefaultSettings()
settings["side"] = IceCore.Side.Right settings["side"] = IceCore.Side.Right
settings["offset"] = 11 settings["offset"] = 11
settings["upperText"] = "[PercentMP:Round]" settings["upperText"] = "[PercentMP:Round]"
settings["lowerText"] = "[FractionalMP:PowerColor]" settings["lowerText"] = "[FractionalMP:Short:PowerColor]"
settings["barVerticalOffset"] = 35 settings["barVerticalOffset"] = 35
settings["scale"] = 0.7 settings["scale"] = 0.7
settings["enabled"] = false settings["enabled"] = false
@ -83,6 +83,8 @@ function TargetTargetMana.prototype:Update(unit)
if (self.moduleSettings.scaleManaColor) then if (self.moduleSettings.scaleManaColor) then
self.color = "ScaledManaColor" self.color = "ScaledManaColor"
elseif self.moduleSettings.lowThresholdColor and self.manaPercentage and self.manaPercentage <= self.moduleSettings.lowThreshold then
self.color = "ScaledManaColor"
end end
if (manaType == 1) then if (manaType == 1) then

View File

@ -16,13 +16,25 @@ IceThreat.prototype.scheduledEvent = nil
local GetNumPartyMembers, GetNumRaidMembers = GetNumPartyMembers, GetNumRaidMembers local GetNumPartyMembers, GetNumRaidMembers = GetNumPartyMembers, GetNumRaidMembers
local MAX_NUM_RAID_MEMBERS, MAX_NUM_PARTY_MEMBERS = MAX_NUM_RAID_MEMBERS, MAX_NUM_PARTY_MEMBERS local MAX_NUM_RAID_MEMBERS, MAX_NUM_PARTY_MEMBERS = MAX_NUM_RAID_MEMBERS, MAX_NUM_PARTY_MEMBERS
if IceHUD.WowVer >= 50000 then if not GetNumPartyMembers then
GetNumPartyMembers = GetNumGroupMembers GetNumPartyMembers = GetNumGroupMembers
GetNumRaidMembers = GetNumGroupMembers GetNumRaidMembers = GetNumGroupMembers
MAX_NUM_PARTY_MEMBERS = MAX_PARTY_MEMBERS MAX_NUM_PARTY_MEMBERS = MAX_PARTY_MEMBERS
MAX_NUM_RAID_MEMBERS = MAX_RAID_MEMBERS MAX_NUM_RAID_MEMBERS = MAX_RAID_MEMBERS
end end
local UnitGroupRolesAssigned = UnitGroupRolesAssigned
if not UnitGroupRolesAssigned then
UnitGroupRolesAssigned = function()
return "NONE"
end
end
local GetItemInfo = GetItemInfo
if not GetItemInfo and C_Item then
GetItemInfo = C_Item.GetItemInfo
end
local MAX_NUM_RAID_MEMBERS = 40 local MAX_NUM_RAID_MEMBERS = 40
local MAX_NUM_PARTY_MEMBERS = 5 local MAX_NUM_PARTY_MEMBERS = 5
@ -224,7 +236,7 @@ end
-- create the aggro range indicator bar -- create the aggro range indicator bar
function IceThreat.prototype:CreateAggroBar() function IceThreat.prototype:CreateAggroBar()
self.aggroBar = self:BarFactory(self.aggroBar, "BACKGROUND","ARTWORK") self.aggroBar = self:BarFactory(self.aggroBar, "BACKGROUND", "ARTWORK", "Aggro")
local r, g, b = self:GetColor("ThreatPullAggro") local r, g, b = self:GetColor("ThreatPullAggro")
if (self.settings.backgroundToggle) then if (self.settings.backgroundToggle) then
@ -236,7 +248,7 @@ function IceThreat.prototype:CreateAggroBar()
end end
function IceThreat.prototype:CreateSecondThreatBar() function IceThreat.prototype:CreateSecondThreatBar()
self.secondThreatBar = self:BarFactory(self.secondThreatBar, "MEDIUM", "OVERLAY") self.secondThreatBar = self:BarFactory(self.secondThreatBar, "MEDIUM", "OVERLAY", "SecondThreat")
self.secondThreatBar.bar:SetVertexColor(self:GetColor("ThreatSecondPlace", self.alpha * self.moduleSettings.secondPlaceThreatAlpha)) self.secondThreatBar.bar:SetVertexColor(self:GetColor("ThreatSecondPlace", self.alpha * self.moduleSettings.secondPlaceThreatAlpha))
@ -468,4 +480,6 @@ function IceThreat.prototype:Show(bShouldShow)
end end
-- Load us up -- Load us up
IceHUD.IceThreat = IceThreat:new() if UnitDetailedThreatSituation then
IceHUD.IceThreat = IceThreat:new()
end

View File

@ -2,7 +2,7 @@ local L = LibStub("AceLocale-3.0"):GetLocale("IceHUD", false)
local Totems = IceCore_CreateClass(IceElement) local Totems = IceCore_CreateClass(IceElement)
local CooldownFrame_SetTimer = CooldownFrame_SetTimer local CooldownFrame_SetTimer = CooldownFrame_SetTimer
if IceHUD.WowVer >= 70000 then if CooldownFrame_Set then
CooldownFrame_SetTimer = CooldownFrame_Set CooldownFrame_SetTimer = CooldownFrame_Set
end end
@ -89,11 +89,11 @@ function Totems.prototype:GetOptions()
end, end,
order = 31 order = 31
} }
--[[
opts["hideBlizz"] = { opts["hideBlizz"] = {
type = "toggle", type = "toggle",
name = L["Hide Blizzard Frame"], name = L["Hide Blizzard Frame"],
desc = L["Hides Blizzard Rune frame and disables all events related to it"], desc = L["Hides Blizzard frame and disables all events related to it.\n\nNOTE: Blizzard attaches this UI to the player's unitframe, so if you have that hidden in PlayerHealth, then this won't do anything."],
get = function() get = function()
return self.moduleSettings.hideBlizz return self.moduleSettings.hideBlizz
end, end,
@ -110,7 +110,7 @@ function Totems.prototype:GetOptions()
end, end,
order = 32 order = 32
} }
--]]
opts["displayMode"] = { opts["displayMode"] = {
type = 'select', type = 'select',
name = L["Totem orientation"], name = L["Totem orientation"],
@ -193,7 +193,7 @@ function Totems.prototype:GetDefaultSettings()
defaults["totemFontSize"] = 20 defaults["totemFontSize"] = 20
defaults["totemMode"] = "Graphical" defaults["totemMode"] = "Graphical"
defaults["usesDogTagStrings"] = false defaults["usesDogTagStrings"] = false
defaults["hideBlizz"] = true defaults["hideBlizz"] = IceHUD.CanHookDestroyTotem
defaults["alwaysFullAlpha"] = false defaults["alwaysFullAlpha"] = false
defaults["displayMode"] = "Horizontal" defaults["displayMode"] = "Horizontal"
defaults["cooldownMode"] = "Cooldown" defaults["cooldownMode"] = "Cooldown"
@ -215,7 +215,7 @@ function Totems.prototype:Enable(core)
Totems.super.prototype.Enable(self, core) Totems.super.prototype.Enable(self, core)
self:RegisterEvent("PLAYER_TOTEM_UPDATE", "UpdateTotem"); self:RegisterEvent("PLAYER_TOTEM_UPDATE", "UpdateTotem");
self:RegisterEvent("PLAYER_ENTERING_WORLD", "ResetTotemAvailability"); self:RegisterEvent("PLAYER_ENTERING_WORLD", "EnteringWorld");
if self.moduleSettings.hideBlizz then if self.moduleSettings.hideBlizz then
self:HideBlizz() self:HideBlizz()
@ -230,6 +230,11 @@ function Totems.prototype:Disable(core)
end end
end end
function Totems.prototype:EnteringWorld()
self:TargetChanged()
self:ResetTotemAvailability()
end
function Totems.prototype:ResetTotemAvailability() function Totems.prototype:ResetTotemAvailability()
for i=1, self.numTotems do for i=1, self.numTotems do
self:UpdateTotem(nil, i) self:UpdateTotem(nil, i)
@ -237,16 +242,17 @@ function Totems.prototype:ResetTotemAvailability()
end end
function Totems.prototype:UpdateTotem(event, totem, ...) function Totems.prototype:UpdateTotem(event, totem, ...)
if not totem or tonumber(totem) ~= totem or totem < 1 or totem > self.numTotems then if not totem or tonumber(totem) ~= totem or totem < 1 or totem > self.numTotems or not GetTotemInfo then
return return
end end
local thisTotemName = self.totemNames[TOTEM_PRIORITIES[totem]]
local haveTotem, name, startTime, duration, icon = GetTotemInfo(totem); local haveTotem, name, startTime, duration, icon = GetTotemInfo(totem);
if duration > 0 then if duration > 0 then
self.frame.graphical[totem].totem:SetTexture(icon) self.frame.graphical[totem].totem:SetTexture(icon)
CooldownFrame_SetTimer(self.frame.graphical[totem].cd, startTime, duration, true) CooldownFrame_SetTimer(self.frame.graphical[totem].cd, startTime, duration, true)
self.frame.graphical[totem].cd:Show() self.frame.graphical[totem].cd:Show()
self.frame.graphical[totem]:Show() self.frame.graphical[totem]:Show()
self.frame.graphical[totem].name = name
else else
self.frame.graphical[totem].cd:Hide() self.frame.graphical[totem].cd:Hide()
self.frame.graphical[totem]:Hide() self.frame.graphical[totem]:Hide()
@ -259,7 +265,7 @@ end
function Totems.prototype:CreateFrame() function Totems.prototype:CreateFrame()
Totems.super.prototype.CreateFrame(self) Totems.super.prototype.CreateFrame(self)
self.frame:SetFrameStrata("BACKGROUND") self.frame:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
self.frame:SetWidth(self.totemSize*self.numTotems) self.frame:SetWidth(self.totemSize*self.numTotems)
self.frame:SetHeight(1) self.frame:SetHeight(1)
self.frame:ClearAllPoints() self.frame:ClearAllPoints()
@ -281,10 +287,9 @@ function Totems.prototype:CreateTotemFrame()
self.frame.graphical = {} self.frame.graphical = {}
end end
local totemType
for i=1, self.numTotems do for i=1, self.numTotems do
slot = TOTEM_PRIORITIES[i] local slot = TOTEM_PRIORITIES[i]
self:CreateTotem(slot, self.totemNames[slot]) self:CreateTotem(slot, self.totemNames[slot])
end end
end end
@ -293,14 +298,18 @@ function Totems.prototype:GetAlphaAdd()
end end
function Totems.prototype:ShowBlizz() function Totems.prototype:ShowBlizz()
TotemFrame:Show() if TotemFrame then
TotemFrame:GetScript("OnLoad")(TotemFrame) TotemFrame:Show()
TotemFrame:GetScript("OnLoad")(TotemFrame)
end
end end
function Totems.prototype:HideBlizz() function Totems.prototype:HideBlizz()
TotemFrame:Hide() if TotemFrame then
TotemFrame:UnregisterAllEvents() TotemFrame:Hide()
TotemFrame:UnregisterAllEvents()
end
end end
function Totems.prototype:TargetChanged() function Totems.prototype:TargetChanged()
@ -326,24 +335,21 @@ function Totems.prototype:CheckCombat()
end end
function Totems.prototype:CreateTotem(i, name) function Totems.prototype:CreateTotem(i, name)
-- whiskey tango foxtrot?! apparently arenas can cause this? I can't test out the real cause myself, so putting in a stopgap for now if not name or not GetTotemInfo then
if not name then
return return
end end
local haveTotem, name, startTime, duration, icon = GetTotemInfo(i) local haveTotem, name, startTime, duration, icon = GetTotemInfo(i)
local bWasNewFrame = false
if (not self.frame.graphical[i]) then if (not self.frame.graphical[i]) then
self.frame.graphical[i] = CreateFrame("Frame", nil, self.frame) self.frame.graphical[i] = CreateFrame("Frame", nil, self.frame)
self.frame.graphical[i].totem = self.frame.graphical[i]:CreateTexture(nil, "LOW") self.frame.graphical[i].totem = self.frame.graphical[i]:CreateTexture(nil, "BACKGROUND")
self.frame.graphical[i].cd = CreateFrame("Cooldown", nil, self.frame.graphical[i], "CooldownFrameTemplate") self.frame.graphical[i].cd = CreateFrame("Cooldown", nil, self.frame.graphical[i], "CooldownFrameTemplate")
self.frame.graphical[i].shine = self.frame.graphical[i]:CreateTexture(nil, "OVERLAY") self.frame.graphical[i].shine = self.frame.graphical[i]:CreateTexture(nil, "OVERLAY")
self.frame.graphical[i].totem:SetTexture(icon) self.frame.graphical[i].totem:SetTexture(icon)
self.frame.graphical[i].totem:SetAllPoints(self.frame.graphical[i]) self.frame.graphical[i].totem:SetAllPoints(self.frame.graphical[i])
bWasNewFrame = true
end end
self.frame.graphical[i]:SetFrameStrata("BACKGROUND") self.frame.graphical[i]:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
self.frame.graphical[i]:SetWidth(self.totemSize) self.frame.graphical[i]:SetWidth(self.totemSize)
self.frame.graphical[i]:SetHeight(self.totemSize) self.frame.graphical[i]:SetHeight(self.totemSize)
@ -354,20 +360,27 @@ function Totems.prototype:CreateTotem(i, name)
end end
if not self.graphicalOnEnter then if not self.graphicalOnEnter then
self.graphicalOnEnter = function(button) GameTooltip:SetOwner(button); GameTooltip:SetTotem(button.slot) end self.graphicalOnEnter = function(button)
GameTooltip:SetOwner(button)
if IceHUD.WowClassic then
GameTooltip:SetText(button.name)
else
GameTooltip:SetTotem(button.slot)
end
end
end end
if not self.graphicalOnLeave then if not self.graphicalOnLeave then
self.graphicalOnLeave = function() GameTooltip:Hide() end self.graphicalOnLeave = function() GameTooltip:Hide() end
end end
if not self.graphicalOnMouseUp then if not self.graphicalOnMouseUp then
self.graphicalOnMouseUp = function (self, mouseButton) self.graphicalOnMouseUp = function (button, mouseButton)
if mouseButton == "RightButton" then if mouseButton == "RightButton" then
DestroyTotem(self.slot) DestroyTotem(button.slot)
end end
end end
end end
self.frame.graphical[i].cd:SetFrameStrata("BACKGROUND") self.frame.graphical[i].cd:SetFrameStrata(IceHUD.IceCore:DetermineStrata("BACKGROUND"))
self.frame.graphical[i].cd:SetFrameLevel(self.frame.graphical[i]:GetFrameLevel()+1) self.frame.graphical[i].cd:SetFrameLevel(self.frame.graphical[i]:GetFrameLevel()+1)
self.frame.graphical[i].cd:ClearAllPoints() self.frame.graphical[i].cd:ClearAllPoints()
self.frame.graphical[i].cd:SetAllPoints(self.frame.graphical[i]) self.frame.graphical[i].cd:SetAllPoints(self.frame.graphical[i])
@ -390,21 +403,23 @@ function Totems.prototype:CreateTotem(i, name)
self.frame.graphical[i]:EnableMouse(true) self.frame.graphical[i]:EnableMouse(true)
self.frame.graphical[i]:SetScript("OnEnter", self.graphicalOnEnter) self.frame.graphical[i]:SetScript("OnEnter", self.graphicalOnEnter)
self.frame.graphical[i]:SetScript("OnLeave", self.graphicalOnLeave) self.frame.graphical[i]:SetScript("OnLeave", self.graphicalOnLeave)
if IceHUD.CanHookDestroyTotem then
self.frame.graphical[i]:SetScript("OnMouseUp", self.graphicalOnMouseUp)
end
else else
self.frame.graphical[i]:EnableMouse(false) self.frame.graphical[i]:EnableMouse(false)
self.frame.graphical[i]:SetScript("OnEnter", nil) self.frame.graphical[i]:SetScript("OnEnter", nil)
self.frame.graphical[i]:SetScript("OnLeave", nil) self.frame.graphical[i]:SetScript("OnLeave", nil)
if IceHUD.CanHookDestroyTotem then
self.frame.graphical[i]:SetScript("OnMouseUp", nil)
end
end end
self.frame.graphical[i].slot = i self.frame.graphical[i].slot = i
self.frame.graphical[i].name = name
-- it looks like HookScript will continue to add handlers every time instead of replacing them like SetScript
if (bWasNewFrame) then
--self.frame.graphical[i]:HookScript("OnMouseUp", self.graphicalOnMouseUp)
end
end end
-- Load us up -- Load us up
local _, unitClass = UnitClass("player") local _, unitClass = UnitClass("player")
if (unitClass == "SHAMAN") or (unitClass == "DRUID") then if IceHUD.WowVer >= 90000 or (unitClass == "SHAMAN") or (unitClass == "DRUID") then
IceHUD.Totems = Totems:new() IceHUD.Totems = Totems:new()
end end

View File

@ -3,6 +3,25 @@ local Vengeance = IceCore_CreateClass(IceUnitBar)
local VENGEANCE_SPELL_ID = 93098 local VENGEANCE_SPELL_ID = 93098
local GetSpellInfo = GetSpellInfo
if not GetSpellInfo and C_Spell and C_Spell.GetSpellInfo then
GetSpellInfo = function(spellID)
if not spellID then
return nil
end
local spellInfo = C_Spell.GetSpellInfo(spellID)
if spellInfo then
return spellInfo.name, nil, spellInfo.iconID, spellInfo.castTime, spellInfo.minRange, spellInfo.maxRange, spellInfo.spellID, spellInfo.originalIconID
end
end
end
local GetSpellName = GetSpellInfo
if C_Spell and C_Spell.GetSpellName then
GetSpellName = C_Spell.GetSpellName
end
Vengeance.prototype.current = nil Vengeance.prototype.current = nil
Vengeance.prototype.max = nil Vengeance.prototype.max = nil
@ -50,43 +69,25 @@ end
-- scan the tooltip and extract the vengeance value -- scan the tooltip and extract the vengeance value
do do
-- making these local as they're not used anywhere else -- making these local as they're not used anywhere else
local regions = {} local spellName = GetSpellName(VENGEANCE_SPELL_ID)
local spellName = GetSpellInfo(VENGEANCE_SPELL_ID)
local tooltipBuffer = CreateFrame("GameTooltip","tooltipBuffer",nil,"GameTooltipTemplate")
tooltipBuffer:SetOwner(WorldFrame, "ANCHOR_NONE")
-- suggested by Antiarc as a way to repopulate the same table instead of repeatedly creating a new one
local function makeTable(t, ...)
wipe(t)
for i = 1, select("#", ...) do
t[i] = select(i, ...)
end
end
function Vengeance.prototype:UpdateCurrent(event, unit) function Vengeance.prototype:UpdateCurrent(event, unit)
if (unit and (unit ~= self.unit)) then if (unit and (unit ~= self.unit)) then
return return
end end
local name = UnitAura(self.unit, spellName) if C_UnitAuras and C_UnitAuras.GetAuraDataBySpellName then
if name then local data = C_UnitAuras.GetAuraDataBySpellName(self.unit, spellName)
-- Buff found, copy it into the buffer for scanning if data and data.points and #data.points > 0 then
tooltipBuffer:ClearLines() self.current = (data and data.points and #data.points > 0) and data.points[1] or 0
tooltipBuffer:SetUnitBuff(self.unit, name)
-- Grab all regions, stuff em into our table
makeTable(regions, tooltipBuffer:GetRegions())
-- Convert FontStrings to strings, replace anything else with ""
for i=1, #regions do
local region = regions[i]
regions[i] = region:GetObjectType() == "FontString" and region:GetText() or ""
end end
-- Find the number, save it
self.current = tonumber(string.match(table.concat(regions),"%d+")) or 0
else else
self.current = 0 local _, idx = IceHUD:GetBuffCount(self.unit, spellName, true, true)
if idx then
self.current = select(17, IceHUD.UnitAura(self.unit, idx))
else
self.current = 0
end
end end
self:Update() self:Update()

View File

@ -1,11 +1,13 @@
# IceHUD
IceHUD is a highly configurable and customizable HUD addon in the spirit of DHUD, MetaHUD, and others designed to keep your focus in the center of the screen where your character is. IceHUD is a highly configurable and customizable HUD addon in the spirit of DHUD, MetaHUD, and others designed to keep your focus in the center of the screen where your character is.
## **What it is**
### **What it is** * Player and target health and mana bars, casting and mirror bars, pet health and mana bars, druid mana bar in forms, extensive target info, ToT display, and much more, in a vertically-oriented heads-up display.
* Player and target health and mana bars, casting and mirror bars, pet health and mana bars, druid mana bar in forms, extensive target info, ToT display, and much more
## **Short feature list**
### **Short feature list**
* Lots of different bar shapes and patterns to make the HUD look like you want * Lots of different bar shapes and patterns to make the HUD look like you want
* Class-specific modules such as combo point counters, Slice'n'dice timers, druid mana trackers, Eclipse bar, Holy Power monitoring, Warlock shard tracking, and more * Class-specific modules such as combo point counters, Slice'n'dice timers, druid mana trackers, Eclipse bar, Holy Power monitoring, Warlock shard tracking, and more
* Target-of-target bars, Crowd Control timers, Range Finders, Threat meters, and plenty of other helpful modules * Target-of-target bars, Crowd Control timers, Range Finders, Threat meters, and plenty of other helpful modules
@ -15,13 +17,12 @@ IceHUD is a highly configurable and customizable HUD addon in the spirit of DHUD
* Fully customizable bars and counters capable of tracking buff/debuff applications on any unit, spell/ability cooldowns, and the health/mana of any unit you specify. The custom health/mana bars will even work with crazy unit specifications like "focustargettargetfocustarget" if you want! * Fully customizable bars and counters capable of tracking buff/debuff applications on any unit, spell/ability cooldowns, and the health/mana of any unit you specify. The custom health/mana bars will even work with crazy unit specifications like "focustargettargetfocustarget" if you want!
* Highly configurable (can totally re-arrange all bars, change text display, etc.) * Highly configurable (can totally re-arrange all bars, change text display, etc.)
## **Slash commands**
### **Slash commands**
* /icehud - opens the configuration UI to tweak any setting * /icehud - opens the configuration UI to tweak any setting
* /icehudCL - command-line access to tweak IceHUD settings (for use with macros, etc.) * /icehudCL - command-line access to tweak IceHUD settings (for use with macros, etc.)
## **Frequently Asked Questions**
# **Frequently Asked Questions**
1. **How do I hide the default Blizzard player, target unit frames and party unit frames?** 1. **How do I hide the default Blizzard player, target unit frames and party unit frames?**
Type /icehud, expand the "Module Settings" section, click "Player Health" or "Target Health," and check "Hide Blizzard Frame" and/or "Hide Blizzard Party Frame". (NOTE: before version 1.3.7, the player/target unitframes were hidden by default. Follow the same steps to enable them if desired) Type /icehud, expand the "Module Settings" section, click "Player Health" or "Target Health," and check "Hide Blizzard Frame" and/or "Hide Blizzard Party Frame". (NOTE: before version 1.3.7, the player/target unitframes were hidden by default. Follow the same steps to enable them if desired)
@ -63,7 +64,7 @@ IceHUD is a highly configurable and customizable HUD addon in the spirit of DHUD
Type /icehud, expand Module Settings, expand whatever module you want to move (e.g. PlayerHealth, PlayerMana), and adjust the "Side" and "Offset" settings. "Side" controls whether it's on the left or the right and "Offset" controls how far from center it is. Type /icehud, expand Module Settings, expand whatever module you want to move (e.g. PlayerHealth, PlayerMana), and adjust the "Side" and "Offset" settings. "Side" controls whether it's on the left or the right and "Offset" controls how far from center it is.
1. **Which module displays Monk Chi power?** 1. **Which module displays Monk Chi power?**
This module is called HarmonyPower. Harmony was the original name for Chi back when 5.0 was in beta, so I used Blizzard's name for it while I was developing for Cataclysm. I feel like it's too late to change now that many people are familiar with the Harmony name. Prior to v1.11.2, this module was called HarmonyPower. Harmony was the original name for Chi back when 5.0 was in beta, so I used Blizzard's name for it while I was developing for Cataclysm. IceHUD v1.11.2 changed this module to be called Chi.
1. **How do I add commas/periods into big numbers like health?** 1. **How do I add commas/periods into big numbers like health?**
If you have DogTags enabled, you can open the Text Settings for the module in question and add SeparateDigits() around the tag you're trying to split up. To display Health/MaxHealth with commas, use: [(SeparateDigits(HP):HPColor "/" SeparateDigits(MaxHP):HPColor):Bracket]. To use periods instead of commas, use: [(SeparateDigits(HP, "."):HPColor "/" SeparateDigits(MaxHP, "."):HPColor):Bracket]. Use the /dog help menu to build your own similar tags for Mana, etc. If you have DogTags enabled, you can open the Text Settings for the module in question and add SeparateDigits() around the tag you're trying to split up. To display Health/MaxHealth with commas, use: [(SeparateDigits(HP):HPColor "/" SeparateDigits(MaxHP):HPColor):Bracket]. To use periods instead of commas, use: [(SeparateDigits(HP, "."):HPColor "/" SeparateDigits(MaxHP, "."):HPColor):Bracket]. Use the /dog help menu to build your own similar tags for Mana, etc.
@ -77,5 +78,10 @@ IceHUD is a highly configurable and customizable HUD addon in the spirit of DHUD
1. **How do I get rid of the bars that showed up beneath the player in the 7.0 patch?** 1. **How do I get rid of the bars that showed up beneath the player in the 7.0 patch?**
Blizzard added a "Personal Resource Display" feature in the 7.0 game client. You can disable it in the Game options -> Interface -> Names -> Personal Resource Display. Blizzard added a "Personal Resource Display" feature in the 7.0 game client. You can disable it in the Game options -> Interface -> Names -> Personal Resource Display.
1. **Why is there no target castbar for Classic?**
The Classic game client doesn't offer a reliable way to show castbars for anyone except the player. IceHUD doesn't support the type of inaccurate guessing at combat log details that would be required to get a semi-useful target castbar.
See [here](http://www.wowace.com/addons/ice-hud/tickets/113-basic-guide-to-texture-creation/) for a user-created guide to creating new IceHUD textures. 1. **Why do buff/debuff timers not work in Classic?**
The Classic game client doesn't provide this information to addons because it wasn't a feature when the game first released. You can install the LibClassicDurations addon to enable support, but it's a best guess and not completely accurate.
See [here](https://www.wowace.com/projects/ice-hud/issues/113) for a user-created guide to creating new IceHUD textures.

Binary file not shown.

Before

Width:  |  Height:  |  Size: 256 KiB

After

Width:  |  Height:  |  Size: 118 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 256 KiB

After

Width:  |  Height:  |  Size: 16 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 64 KiB

After

Width:  |  Height:  |  Size: 14 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 64 KiB

After

Width:  |  Height:  |  Size: 3.6 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 256 KiB

After

Width:  |  Height:  |  Size: 37 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 256 KiB

After

Width:  |  Height:  |  Size: 37 KiB

50
this_version.md Normal file
View File

@ -0,0 +1,50 @@
# Changelog
v1.15.10:
- Fix Chi not updating properly when the player's maximum amount of Chi points changes (e.g. via Ascension talent).
- Update TOCs
v1.15.9:
- Update Cataclysm Classic TOC to 4.4.1
- Update Classic-era TOC to 1.15.4
- Update TWW TOC to 11.0.5
v1.15.8:
- Fix reported error with custom cooldown bars set to "when ready" mode due to deprecation in 11.x (wowace issue #368)
v1.15.7:
- Fix cooldown display for overridden spells (such as Evoker spells where Font of Magic replaces the base spell with an override with the same name).
v1.15.6:
- Package new version of LibDogTag-Unit to fix an error with some units on 11.0.2
v1.15.5:
- Fix error when using an invalid spell with a custom bar on 11.x
v1.15.4:
- Update TOC for TWW
v1.15.3:
- Fix custom cooldown bars not working in 11.x (wowace issue #363)
v1.15.2:
- Re-enable right-click context menus on 11.x.
- Update TOC for Classic-era
v1.15.1:
- Fix error opening options.
v1.15.0:
- Support The War Within/11.0
- Add support for exporting and importing profiles through text.