in blueprints I use the “Set Is Enabled Node” on widgets to prevent them from being focused. So far everything work as intented but Unreal automatically apply a greyed out state to disabled widgets . Can I prevent this and keep their 100% opacity look
Thanks for your answer, this work well with standard UMG buttons. I forgot to mention that I use “Common UI plugin” that use CommonButtonStyle for states styles . My buttons reference that style sheet and I do have a style with a tint of (1.0,1.0,1.0,1.0) for my Disabled state . But I still got a greyed out effect.
So maybe it’s an issue more related to CommonUI itself
After further investigation I realized that what I want is to prevent Button child to have an opacity effect when the button is disabled. Same concern as this post :
Any idea on how to achieve that thanks a lto for your help
Bump because I also have this issue. I’ve configured the “Disabled” section under button’s appearance to exactly match the “Normal” section, with Opacity set to 1.0 everywhere, but it still appears greyed out.
I guess it’s not possible unless you change it from c++ “I didn’t check that”, but I believe if the purpose is only to make the user cannot use it like hover, click, etc… try to change the visibility of the button to “not hit testable (Self and all Children)”. That the first thing came to my mind.
On common buttons there is a bool option called ApplyAlphaOnDisable. The comment is wrong. What it actually does is apply an opacity effect if the button is disabled.
Or it should anyways if I’m understanding the code correctly. Haven’t been able to get it to work yet, puzzlingly enough. but according to the code it sets the alpha to .5 if it’s set to true (which it is by default).
I am not sure where “interaction disabled” can be found, but setting the visibility to Not Hit-Testable instead of using IsEnabled may work for most issues
Had issues with this too. Perhaps @Mewbits meant to say “isFocusable” instead of “interaction disabled.” IsFocusable is a property that can be accessed in the Details tab of a Widget BP and added in the Animations. It can also be accessed within BPs as the node “Set isFocusable” and “Get isFocusable” for a specific widget.
TL;DR: this is hard-coded functionality built into UWidget::SetIsEnabled. The only way to avoid that is by not using the built-in Enabled field, making a widget in C++ that lies to the renderer about being disabled, or modifying the engine.