diff --git a/CHANGELOG.md b/CHANGELOG.md index 9a71dbba..e45c25ca 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -36,6 +36,7 @@ Additions - Added TextField.OnEnterPressed event - Added Tooltip.IgnoreViewport and allow overriding the default viewport using Tooltip.Viewport - Added the ability for Dropdown to display an arrow texture based on its open state +- Added the ability to specify Dropdown paragraph colors through style properties Fixes - Fixed tooltips not being bounded correctly for viewports that don't start at the origin diff --git a/MLEM.Ui/Elements/Dropdown.cs b/MLEM.Ui/Elements/Dropdown.cs index ab839c81..89053ccd 100644 --- a/MLEM.Ui/Elements/Dropdown.cs +++ b/MLEM.Ui/Elements/Dropdown.cs @@ -8,11 +8,13 @@ namespace MLEM.Ui.Elements { /// /// A dropdown component to use inside of a . /// A dropdown is a component that contains a hidden panel which is displayed upon pressing the dropdown button. + /// Elements can be added to the dropdown's through or one of its overloads, which additionally causes them to have correct gamepad navigation behavior. /// public class Dropdown : Button { /// /// The panel that this dropdown contains. It will be displayed upon pressing the dropdown button. + /// To add elements to this panel, you can use or one of its overloads, which additionally causes them to have correct gamepad navigation behavior. /// public Panel Panel { get; private set; } /// @@ -65,6 +67,16 @@ public StyleProp OpenedArrowTexture { this.UpdateArrowStyle(); } } + /// + /// A style property containing the that a paragraph added to this dropdown through should have by default. + /// For elements added through other overloads of , this property has no effect. + /// + public StyleProp TextColor; + /// + /// A style property containing the that a paragraph added to this dropdown through should have when hovered. + /// For elements added through other overloads of , this property has no effect. + /// + public StyleProp HoveredTextColor; private StyleProp openedArrowTexture; private StyleProp closedArrowTexture; @@ -144,7 +156,7 @@ public Element AddElement(string text, GenericCallback pressed = null, int index /// /// Adds a pressable element to this dropdown's . - /// By default, the paragraph's text color will change from to when hovering over it. + /// By default, the paragraph's text color will change from to when hovering over it. /// /// The text to display /// The resulting paragraph's event @@ -157,8 +169,8 @@ public Element AddElement(Paragraph.TextCallback text, GenericCallback pressed = }; if (pressed != null) paragraph.OnPressed += pressed; - paragraph.OnMouseEnter += e => paragraph.TextColor = Color.LightGray; - paragraph.OnMouseExit += e => paragraph.TextColor = Color.White; + paragraph.OnMouseEnter += e => paragraph.TextColor = this.HoveredTextColor; + paragraph.OnMouseExit += e => paragraph.TextColor = this.TextColor; this.AddElement(paragraph, index); return paragraph; } @@ -198,6 +210,8 @@ protected override void InitStyle(UiStyle style) { this.ArrowPadding = this.ArrowPadding.OrStyle(style.DropdownArrowPadding); this.ClosedArrowTexture = this.ClosedArrowTexture.OrStyle(style.DropdownClosedArrowTexture); this.OpenedArrowTexture = this.OpenedArrowTexture.OrStyle(style.DropdownOpenedArrowTexture); + this.TextColor = this.TextColor.OrStyle(style.DropdownTextColor); + this.HoveredTextColor = this.HoveredTextColor.OrStyle(style.DropdownHoveredTextColor); this.UpdateArrowStyle(); } diff --git a/MLEM.Ui/Style/UiStyle.cs b/MLEM.Ui/Style/UiStyle.cs index cb37e48f..ab6f5824 100644 --- a/MLEM.Ui/Style/UiStyle.cs +++ b/MLEM.Ui/Style/UiStyle.cs @@ -257,6 +257,16 @@ public class UiStyle : GenericDataHolder { /// This value is passed to . /// public TextureRegion DropdownOpenedArrowTexture; + /// + /// The color that a 's paragraphs should have by default. + /// This value is passed to . + /// + public Color DropdownTextColor = Color.White; + /// + /// The color that a 's paragraphs should have when hovered. + /// This value is passed to . + /// + public Color DropdownHoveredTextColor = Color.LightGray; /// /// A set of additional fonts that can be used for the <f FontName> formatting code