From d2fcbd66d1b5f1233a4ae82092ceb816a844a2ff Mon Sep 17 00:00:00 2001 From: EtK2000 Date: Wed, 20 Nov 2024 14:16:48 +0200 Subject: [PATCH] Support focus font colors in VisImageTextButton --- ui/CHANGES.md | 1 + .../vis/ui/widget/VisImageTextButton.java | 41 ++++++++++++++----- 2 files changed, 31 insertions(+), 11 deletions(-) diff --git a/ui/CHANGES.md b/ui/CHANGES.md index 28692aa4..d45ee8bc 100644 --- a/ui/CHANGES.md +++ b/ui/CHANGES.md @@ -1,5 +1,6 @@ #### Version: 1.5.4-SNAPSHOT (libGDX 1.12.1) - **Changed**: [#393](https://github.com/kotcrab/vis-ui/pull/393) - Removed use of Apple Java extensions in `FileUtils` +- **Added**: `VisImageTextButton` now supports focus font colors #### Version: 1.5.3 (libGDX 1.12.1) - Updated to libGDX 1.12.1 diff --git a/ui/src/main/java/com/kotcrab/vis/ui/widget/VisImageTextButton.java b/ui/src/main/java/com/kotcrab/vis/ui/widget/VisImageTextButton.java index 0fe4727e..2999b892 100644 --- a/ui/src/main/java/com/kotcrab/vis/ui/widget/VisImageTextButton.java +++ b/ui/src/main/java/com/kotcrab/vis/ui/widget/VisImageTextButton.java @@ -27,6 +27,7 @@ import com.badlogic.gdx.scenes.scene2d.utils.ClickListener; import com.badlogic.gdx.scenes.scene2d.utils.Drawable; import com.badlogic.gdx.utils.Align; +import com.badlogic.gdx.utils.Null; import com.badlogic.gdx.utils.Scaling; import com.kotcrab.vis.ui.FocusManager; import com.kotcrab.vis.ui.Focusable; @@ -178,20 +179,38 @@ else if (style.imageUp != null) } } + /** + * Returns the appropriate label font color from the style based on the current button state. + *

+ * Taken from LibGDX 1.13.0's {@link TextButton#getFontColor()} + **/ + protected @Null Color getFontColor () { + if (isDisabled() && style.disabledFontColor != null) return style.disabledFontColor; + if (isPressed()) { + if (isChecked() && style.checkedDownFontColor != null) return style.checkedDownFontColor; + if (style.downFontColor != null) return style.downFontColor; + } + if (isOver()) { + if (isChecked()) { + if (style.checkedOverFontColor != null) return style.checkedOverFontColor; + } else { + if (style.overFontColor != null) return style.overFontColor; + } + } + boolean focused = hasKeyboardFocus(); + if (isChecked()) { + if (focused && style.checkedFocusedFontColor != null) return style.checkedFocusedFontColor; + if (style.checkedFontColor != null) return style.checkedFontColor; + if (isOver() && style.overFontColor != null) return style.overFontColor; + } + if (focused && style.focusedFontColor != null) return style.focusedFontColor; + return style.fontColor; + } + @Override public void draw (Batch batch, float parentAlpha) { updateImage(); - Color fontColor; - if (isDisabled() && style.disabledFontColor != null) - fontColor = style.disabledFontColor; - else if (isPressed() && style.downFontColor != null) - fontColor = style.downFontColor; - else if (isChecked() && style.checkedFontColor != null) - fontColor = (isOver() && style.checkedOverFontColor != null) ? style.checkedOverFontColor : style.checkedFontColor; - else if (isOver() && style.overFontColor != null) - fontColor = style.overFontColor; - else - fontColor = style.fontColor; + Color fontColor = getFontColor(); if (fontColor != null) label.getStyle().fontColor = fontColor; super.draw(batch, parentAlpha); if (focusBorderEnabled && drawBorder && style.focusBorder != null)