This commit is contained in:
陈思海 2025-10-14 17:07:30 +08:00
parent 761b7b1827
commit 289bfc6111
2 changed files with 25 additions and 11 deletions

View File

@ -94,7 +94,20 @@ public class UXButton : UIBehaviour, IButton,
public bool Selected
{
get => _mTogSelected;
internal set
set
{
if ((m_Mode == ButtonModeType.Normal && value) || m_Mode == ButtonModeType.Toggle)
{
if (m_Mode == ButtonModeType.Toggle) _mTogSelected = !value;
HandleClick();
}
}
}
internal bool InternalTogSelected
{
get => _mTogSelected;
set
{
if (_mTogSelected == value) return;
_mTogSelected = value;
@ -223,7 +236,7 @@ public class UXButton : UIBehaviour, IButton,
}
else
{
Selected = !Selected;
InternalTogSelected = !Selected;
}
}

View File

@ -30,7 +30,7 @@ public class UXGroup : UIBehaviour
{
foreach (var btn in m_Buttons)
if (btn)
btn.Selected = false;
btn.InternalTogSelected = false;
m_Buttons.Clear();
base.OnDestroy();
}
@ -41,10 +41,10 @@ public class UXGroup : UIBehaviour
if (m_Buttons.Contains(button)) return;
m_Buttons.Add(button);
if (button.Selected)
if (button.InternalTogSelected)
{
if (_current && _current != button)
_current.Selected = false;
_current.InternalTogSelected = false;
_current = button;
}
@ -57,14 +57,14 @@ public class UXGroup : UIBehaviour
m_Buttons.Remove(button);
if (_current == button)
_current = null;
button.Selected = false;
button.InternalTogSelected = false;
}
internal void NotifyButtonClicked(UXButton button)
{
if (!button) return;
if (button.Selected)
if (button.InternalTogSelected)
{
if (m_AllowSwitchOff) SetSelected(null);
}
@ -76,14 +76,15 @@ public class UXGroup : UIBehaviour
private void SetSelected(UXButton target)
{
if (_current == target) return;
var previous = _current;
_current = null;
foreach (var btn in m_Buttons)
{
bool select = (btn == target);
if (btn.Selected != select)
btn.Selected = select;
if (btn.InternalTogSelected != select)
btn.InternalTogSelected = select;
if (select) _current = btn;
}
@ -93,7 +94,7 @@ public class UXGroup : UIBehaviour
private void ValidateGroup()
{
if (_current != null && _current.Selected) return;
if (_current != null && _current.InternalTogSelected) return;
if (!m_AllowSwitchOff && m_Buttons.Count > 0)
SetSelected(m_Buttons[0]);
@ -102,7 +103,7 @@ public class UXGroup : UIBehaviour
public bool AnyOtherSelected(UXButton exclude)
{
foreach (var btn in m_Buttons)
if (btn != exclude && btn.Selected)
if (btn != exclude && btn.InternalTogSelected)
return true;
return false;
}