Shadowed Unit Frames
SUF focuses on a simple configuration while maintaining the flexibility that most users will care about, preventing unnecessary bloating of the addon that sacrifices performance. While you aren't going to be able to set the health bar to be exactly 3.14 pixels outside of the unit frames, you can change options you actually care about such as bar height, ordering, frame height and so on. To speed up configuration, you can configure multiple units at the same time through the global configuration. For example, if you want to set the height of the Player, Target, Focus and Party frames to 50 then the height of Target's Target, Target's Target of Target, Focus Target to 30 you can easily do this by changing two options instead of having to do it seven times.
However, should you need a little bit of extra configuration do not despair! An advanced option is included that will unlock additional configuration giving finer control over the configuration.
Shadowed Unit Frames in WoW Classic
There is in-development Beta versions available for WoW Classic!
Note that WoW Classic does not provide all the information that you might be used to:
- There is no Focus Frame
- Information about the HP of enemies is not available, and they'll show as 100 HP
- Cast Bars for anyone but the player himself are not available
- Debuffs have no duration information
Some of this data can be restored with additional libraries/addons, but it'll always be guesswork and potentially inaccurate. Shadowed Unit Frames comes bundled with LibClassicDurations for debuff durations. Mob HP can be provided by Real Mob Health, which you need to install manually.
Note on copying your layout from Retail to Classic:
In general you cannot copy your layout between the two versions, since they are quite different, and doing so will result in certain elements exclusive to one version (like Pet Happiness on Classic) not always working properly. There are some provisions in the code that makes copying from Retail to Classic mostly work, use at your own risk - however, never copy a Layout from Classic to Retail, this will absolutely result in the Class-specific power bars and other elements not available on Classic to cease to function.
Slash commands: /shadoweduf (/suf)
Anchoring
Are you driven crazy by your party frames not aligning up exactly with your player frames, even if it's only half a pixel off? The anchoring system will let you solve all alignment issues, by allowing you to anchor a frame to another and set a simple offset from the frame it is anchored to, or by manually setting the X/Y position of the frame.
Using the screen shot as an example, if you drag the player frame the other frames will move with the player frame preserving the alignment and spacing. Each frame can still be manually positioned wherever you want, but this gives you a way of easily anchoring and moving frames around without having to use a ruler.
Zone configuration (Disabling options/units by zone type)
Units and modules can be enabled or disabled based on the type of zone you are in. For example, if you want to see party targets and party pets while you are in an arena but nowhere else then you can use the visibility options to enable it only while inside an arena. Modules can also be disabled by zone type, if you want to see party auras while in a raid instance but nowhere else you can disable the module in raid instances only.
Profiles do not have to be swapped and it is all automatic.
Units
Supports unit frames are as follows:
Player: Player, Pet, Pet Target
General: Target, Target of Target, Target of Target of Target, Focus, Focus Target
Party: Party, Party Pets, Party Targets, Party ToT
Raid: Raid, Raid Pet, Main Tank, Main Tank Target, Main Assist, Main Assist Target, Boss, Boss Target, Boss ToT, Main Assist ToT, Main Tank ToT
Arena: Arena, Arena Target, Arena Pets, Arena ToT
Battleground: Battleground, Battleground Target, Battleground Target
Features
- Tags: Includes a simple tagging system that can be customized in virtually any way using Lua, even if something isn't included by default odds are you can make the tags
- Incoming Heals: Supports the Blizzard Events for incoming heal data, no external libraries needed
- Auras: Can be set to only show auras you casted, or can cast on others. Can enlarge auras that you casted, and hide the cooldown ring on the timers of auras you didn't cast as well to make it more obvious which ones you casted and which ones you didn't
- Aura Timers: You will need a mod such as OmniCC to show timers on buffs and debuffs
- Aura Indicators: Display colored squares or icons for certain auras on any unit
- Fader: Fades frames when out of combat and inactive (100% mana/no target)
- Class Power (Eclipse, Holy Power, etc): Supports all of the class power features from Eclipse to Burning Embers.
- Highlighting: Border highlighting of frames based on mousing over them, curable debuffs, aggro or you are targeting/focusing them
- Range Checking: Fades frames out that are out of range of you
- Exportable Layouts: If you have a layout, or your friend has a layout you want to try out you can export/import SUF layouts by going to /suf -> Layout Manager
- Profiles: You can change from any profile to another one without reloading your UI, should you want to use a completely different layout based on zone you can easily switch profiles without hassle
Pretty much all the general unit frame settings are in, health bars, cast bars, power bars, portraits, indicators and so on.
Modules
Basic module support is included, should you be interested in building a module see the documentation on github for more information.
Feedback
For feature requests and bug reports, please continue to use the Ticket tracker. Feel free to ask on the thread first, if you're unsure what to do!
Hello, i'm trying to find the option to disable raid frames, but only in Bgs or AV, possible?
again, I'm really noticing the absence of the inability to ping on the frames.. being able to ping is just such a crazy useful feature :(
In reply to b9ty: Author has a pull request in from someone else to add this function back to the unitframe
I took that and added it into my git as well as the Follower Dungeon class colors. I'm starting to work back into fixing addons before next patch, so hopefully it'll be added to curse version
In the mean time, link to git: https://github.com/Hyphie24/ShadowedUnitFrames
I have this error pop up any time I try to edit the vanilla UI elements while also having SUF enabled in add-ons. i pinpointed it tot his specific add-on by a process of elimination of turning off every single add-on and testing till the error came up.
Basically any time i need to move a vanilla element, i have to turn off SUF , make my changes then turn it back on.
Message: ...izzard_EditMode/Mainline/EditModeSystemTemplates.lua:560: attempt to perform arithmetic on local 'left' (a nil value)
Time: Sun Jan 5 12:47:37 2025
Count: 433
Stack: ...izzard_EditMode/Mainline/EditModeSystemTemplates.lua:560: attempt to perform arithmetic on local 'left' (a nil value)
[string "@Interface/AddOns/Blizzard_EditMode/Mainline/EditModeSystemTemplates.lua"]:560: in function `GetScaledSelectionSides'
[string "@Interface/AddOns/Blizzard_EditMode/Mainline/EditModeSystemTemplates.lua"]:532: in function `IsVerticallyAlignedWithFrame'
[string "@Interface/AddOns/Blizzard_EditMode/Mainline/EditModeSystemTemplates.lua"]:755: in function `GetFrameMagneticEligibility'
[string "@Interface/AddOns/Blizzard_EditMode/Mainline/EditModeUtil.lua"]:152: in function `GetEligibleMagneticFrames'
[string "@Interface/AddOns/Blizzard_EditMode/Mainline/EditModeUtil.lua"]:341: in function `GetMagneticFrameInfoOptions'
[string "@Interface/AddOns/Blizzard_EditMode/Mainline/EditModeUtil.lua"]:424: in function `GetMagneticFrameInfos'
[string "@Interface/AddOns/Blizzard_EditMode/Mainline/EditModeManager.lua"]:967: in function `RefreshSnapPreviewLines'
[string "@Interface/AddOns/Blizzard_EditMode/Mainline/EditModeManager.lua"]:72: in function <...ddOns/Blizzard_EditMode/Mainline/EditModeManager.lua:70>
Locals: self = BossTargetFrameContainer {
systemInfo = <table> {
}
downKeys = <table> {
}
breakSnappedFramesOnSave = true
smallSize = true
spacing = 10
alwaysUseTopRightAnchor = true
isManagedFrame = true
hasActiveChanges = false
dirty = false
isHighlighted = true
systemIndex = 6
isInEditMode = true
snappedFrames = <table> {
}
isRightManagedFrame = true
layoutParent = UIParentRightManagedFrameContainer {
}
savedSystemInfo = <table> {
}
systemNameString = "Boss Frames"
isSelected = false
castBarOnSide = true
dirtySettings = <table> {
}
settingMap = <table> {
}
settingsDialogAnchor = <table> {
}
settingDisplayInfoMap = <table> {
}
BossTargetFrames = <table> {
}
hideWhenActionBarIsOverriden = false
Selection = Frame {
}
respectChildScale = true
layoutIndex = 4
align = "right"
defaultHideSelection = true
system = 3
rightPadding = -70
}
left = nil
bottom = nil
width = nil
height = nil
scale = 1
(*temporary) = BossTargetFrameContainer {
systemInfo = <table> {
}
downKeys = <table> {
}
breakSnappedFramesOnSave = true
smallSize = true
spacing = 10
alwaysUseTopRightAnchor = true
isManagedFrame = true
hasActiveChanges = false
dirty = false
isHighlighted = true
systemIndex = 6
isInEditMode = true
snappedFrames = <table> {
}
isRightManagedFrame = true
layoutParent = UIParentRightManagedFrameContainer {
}
savedSystemInfo = <table> {
}
systemNameString = "Boss Frames"
isSelected = false
castBarOnSide = true
dirtySettings = <table> {
}
settingMap = <table> {
}
settingsDialogAnchor = <table> {
}
settingDisplayInfoMap = <table> {
}
BossTargetFrames = <table> {
}
hideWhenActionBarIsOverriden = false
Selection = Frame {
}
respectChildScale = true
layoutIndex = 4
align = "right"
defaultHideSelection = true
system = 3
rightPadding = -70
}
(*temporary) = 1
(*temporary) = nil
(*temporary) = nil
(*temporary) = "attempt to perform arithmetic on local 'left' (a nil value)"
In reply to BaronSolace:
Message: ...izzard_EditMode/Mainline/EditModeSystemTemplates.lua:560: attempt to perform arithmetic on local 'left' (a nil value)
Time: Sun Jan 5 12:47:37 2025
Count: 2
Stack: ...izzard_EditMode/Mainline/EditModeSystemTemplates.lua:560: attempt to perform arithmetic on local 'left' (a nil value)
[string "@Interface/AddOns/Blizzard_EditMode/Mainline/EditModeSystemTemplates.lua"]:560: in function `GetScaledSelectionSides'
[string "@Interface/AddOns/Blizzard_EditMode/Mainline/EditModeSystemTemplates.lua"]:532: in function `IsVerticallyAlignedWithFrame'
[string "@Interface/AddOns/Blizzard_EditMode/Mainline/EditModeSystemTemplates.lua"]:755: in function `GetFrameMagneticEligibility'
[string "@Interface/AddOns/Blizzard_EditMode/Mainline/EditModeUtil.lua"]:152: in function `GetEligibleMagneticFrames'
[string "@Interface/AddOns/Blizzard_EditMode/Mainline/EditModeUtil.lua"]:341: in function `GetMagneticFrameInfoOptions'
[string "@Interface/AddOns/Blizzard_EditMode/Mainline/EditModeUtil.lua"]:424: in function `GetMagneticFrameInfos'
[string "@Interface/AddOns/Blizzard_EditMode/Mainline/EditModeUtil.lua"]:445: in function `ApplyMagnetism'
[string "@Interface/AddOns/Blizzard_EditMode/Mainline/EditModeSystemTemplates.lua"]:846: in function `OnDragStop'
[string "@Interface/AddOns/Blizzard_EditMode/Mainline/EditModeSystemTemplates.lua"]:2507: in function <...izzard_EditMode/Mainline/EditModeSystemTemplates.lua:2506>
Locals: self = BossTargetFrameContainer {
systemInfo = <table> {
}
downKeys = <table> {
}
breakSnappedFramesOnSave = true
smallSize = true
spacing = 10
alwaysUseTopRightAnchor = true
isManagedFrame = true
hasActiveChanges = false
dirty = false
isHighlighted = true
systemIndex = 6
isInEditMode = true
snappedFrames = <table> {
}
isRightManagedFrame = true
layoutParent = UIParentRightManagedFrameContainer {
}
savedSystemInfo = <table> {
}
systemNameString = "Boss Frames"
isSelected = false
castBarOnSide = true
dirtySettings = <table> {
}
settingMap = <table> {
}
settingsDialogAnchor = <table> {
}
settingDisplayInfoMap = <table> {
}
BossTargetFrames = <table> {
}
hideWhenActionBarIsOverriden = false
Selection = Frame {
}
respectChildScale = true
layoutIndex = 4
align = "right"
defaultHideSelection = true
system = 3
rightPadding = -70
}
left = nil
bottom = nil
width = nil
height = nil
scale = 1
(*temporary) = BossTargetFrameContainer {
systemInfo = <table> {
}
downKeys = <table> {
}
breakSnappedFramesOnSave = true
smallSize = true
spacing = 10
alwaysUseTopRightAnchor = true
isManagedFrame = true
hasActiveChanges = false
dirty = false
isHighlighted = true
systemIndex = 6
isInEditMode = true
snappedFrames = <table> {
}
isRightManagedFrame = true
layoutParent = UIParentRightManagedFrameContainer {
}
savedSystemInfo = <table> {
}
systemNameString = "Boss Frames"
isSelected = false
castBarOnSide = true
dirtySettings = <table> {
}
settingMap = <table> {
}
settingsDialogAnchor = <table> {
}
settingDisplayInfoMap = <table> {
}
BossTargetFrames = <table> {
}
hideWhenActionBarIsOverriden = false
Selection = Frame {
}
respectChildScale = true
layoutIndex = 4
align = "right"
defaultHideSelection = true
system = 3
rightPadding = -70
}
(*temporary) = 1
(*temporary) = nil
(*temporary) = nil
(*temporary) = "attempt to perform arithmetic on local 'left' (a nil value)"
How do I turn off the swing timer in SUF?
The add-on does not work correctly in follower dungeons. I set the party to display the health bars using class colours, but it keeps showing everyone with green colour. This is a pity. as it is a well known trick to use them to configure everything. As it does not work, I cannot use it for that. Happy Christmas!!!
Update: I got it working by modifying the method UpdateColor in the health.lua file. It seems that the followers are not contemplated in the logic. I added a final "else" at the end of the "if .. else if" chain with this code:
else
local class = select(2, UnitClass(unit))
color = class and ShadowUF.db.profile.classColors[class]
end
It is just quick and dirty, but I don't have enough know how to understand how to do it better.
In reply to user_mubquzca0ct4ivuc: I never did follower dungeons, was testing something in it and noticed this as an issue, I have found a much easier and simpler fix.
in health.lua change line 118 from
elseif( ShadowUF.db.profile.units[frame.unitType].healthBar.colorType == "class" and (UnitIsPlayer(unit) or unit == "pet") ) then
to: elseif( ShadowUF.db.profile.units[frame.unitType].healthBar.colorType == "class" and (UnitIsPlayer(unit) or UnitInPartyIsAI(unit) or unit == "pet") ) then
I also pushed this to my git repo https://github.com/Hyphie24/ShadowedUnitFrames.git
whenever I enter a random dungeon as qued as tank on my monk from dps spec(so it auto switches your spec to tank) it shows all party members out of range. I have to switch back to dps spec and back to tank spec and it fixes it. Only appears to happen on monk.
How do i show healer and dps role icons on raid frames ?
Hi! Been getting alot of LUA errors lately, causing drop in preformance(5-10 sec compter freeze). BUGSAC looking something like this:
..'ShadowedUnitFrames' tried to call the protected function 'CompactPartyFrameMember1:SetSize()'...
Any idead/fixes?
How does one make it so where for your target, if it is friendly, have only debuffs at the top, but if it is an enemy, have only buffs at the top? Trying to figure this out but even with the smart selection that says the opposite.
Maybe I'm just dumb, but I cannot find the Balance Druid Power Bar (the eclipse bar).
If this addon doesn't support it, how can i get the default one back?
When fiddling around with the edit mode of suf the test buffs no longer show up is this a bug or a setting I can't find?
In reply to Kemme: I believe this happened to me so I had to just kinda test in game, but they are working
Hi-been using SUF forever only one I've used. I'm trying to figure out how to Color Target Names by Level, but can't really find it in options (Target=Text/Tags tab) I am able to change the Level (Number) to reflect white, green yellow etc, but I really would like the targets name to reflect that same info from a distance. Number is pretty small...I'm play Hardcore it is much more important to know what I'm against beforehand than the regular Disney version.
Thanks
can't ping the unit frames, no way to show healer mana only, any fixes for these issues?
Update for WoW Classic 1.15.4? 3D portrait of the Player frame will not fade.
On Retail TWW, SUF's Aura Indicators are unable to track the resto druid spell Lifebloom because an incorrect spell ID is hardcoded for Lifebloom. To resolve this issue, edit Interface/AddOns/ShadowedUnitFrames/ShadowedUnitFrames.lua and change the beginning of line 517 from
["33763"] =
to
["188550"] =
WoW classic era 4.4.11 version encounters issues with screen tearing, and flickering lighting. the issue goes away only when SUF is disabled.