PKHeX/PKHeX.WinForms/Controls/PKM Editor/GenderToggle.cs
2023-02-05 11:31:12 -08:00

95 lines
2.5 KiB
C#

using System;
using System.Drawing;
using System.Windows.Forms;
using System.Windows.Forms.Automation;
using static PKHeX.WinForms.Properties.Resources;
namespace PKHeX.WinForms.Controls;
public partial class GenderToggle : UserControl, IGenderToggle
{
public bool AllowClick { get; set; } = true;
private int Value = -1; // Initial load will trigger gender to appear (-1 => 0)
private string? InitialAccessible;
public int Gender
{
get => Value;
set => Value = SetGender(value);
}
public GenderToggle() => InitializeComponent();
private static readonly Image[] GenderImages =
{
gender_0,
gender_1,
gender_2,
};
private int SetGender(int value)
{
if ((uint)value > 2)
value = 2;
if (Value == value)
return value;
BackgroundImage = GenderImages[value];
AccessibleName = (InitialAccessible ??= AccessibleName) + $" ({value})";
AccessibleDescription = (InitialAccessible ??= AccessibleName) + $" ({value})";
return value;
}
private void GenderToggle_Click(object sender, EventArgs e)
{
if (!AllowClick)
return;
TryToggle();
}
private void GenderToggle_KeyDown(object sender, KeyEventArgs e)
{
if (e.KeyCode is not (Keys.Enter or Keys.Space))
return;
TryToggle();
}
private void TryToggle()
{
if (AllowClick && ToggleGender().CanToggle)
{
AccessibilityObject.RaiseAutomationNotification(AutomationNotificationKind.Other,
AutomationNotificationProcessing.All, $"Gender changed to {Gender}.");
return;
}
AccessibilityObject.RaiseAutomationNotification(AutomationNotificationKind.Other,
AutomationNotificationProcessing.All, $"Cannot change gender. Current value is {Gender}.");
}
public (bool CanToggle, int Value) ToggleGender()
{
if ((uint)Gender < 2)
return (true, Gender ^= 1);
return (false, Gender);
}
}
public interface IGenderToggle
{
/// <summary>
/// Enables use of the built in click action.
/// </summary>
bool AllowClick { get; set; }
/// <summary>
/// Get or set the value the control displays.
/// </summary>
int Gender { get; set; }
/// <summary>
/// Manually flips the gender state if possible.
/// </summary>
/// <returns>True if can toggle, and the resulting value.</returns>
(bool CanToggle, int Value) ToggleGender();
}