Files
RobustToolbox/Robust.Client/UserInterface/Controls/CheckBox.cs
Pieter-Jan Briers dae4041e61 Make CheckBox texture vertically centered.
This makes it look better in circumstances where the checkbox is vertically big, for example due to surrounding inline buttons.
2024-03-20 11:12:06 +01:00

74 lines
2.3 KiB
C#

using Robust.Shared.ViewVariables;
using static Robust.Client.UserInterface.Controls.Label;
namespace Robust.Client.UserInterface.Controls
{
/// <summary>
/// A type of toggleable button that also has a checkbox.
/// </summary>
[Virtual]
public class CheckBox : ContainerButton
{
public const string StyleClassCheckBox = "checkBox";
public const string StyleClassCheckBoxChecked = "checkBoxChecked";
public Label Label { get; }
public TextureRect TextureRect { get; }
public CheckBox()
{
ToggleMode = true;
var hBox = new BoxContainer
{
Orientation = BoxContainer.LayoutOrientation.Horizontal,
StyleClasses = { StyleClassCheckBox },
};
AddChild(hBox);
TextureRect = new TextureRect
{
StyleClasses = { StyleClassCheckBox },
VerticalAlignment = VAlignment.Center,
};
hBox.AddChild(TextureRect);
Label = new Label();
hBox.AddChild(Label);
}
protected override void DrawModeChanged()
{
base.DrawModeChanged();
if (TextureRect != null)
{
if (Pressed)
TextureRect.AddStyleClass(StyleClassCheckBoxChecked);
else
TextureRect.RemoveStyleClass(StyleClassCheckBoxChecked);
}
}
/// <summary>
/// How to align the text inside the button.
/// </summary>
[ViewVariables]
public AlignMode TextAlign { get => Label.Align; set => Label.Align = value; }
/// <summary>
/// If true, the button will allow shrinking and clip text
/// to prevent the text from going outside the bounds of the button.
/// If false, the minimum size will always fit the contained text.
/// </summary>
[ViewVariables]
public bool ClipText { get => Label.ClipText; set => Label.ClipText = value; }
/// <summary>
/// The text displayed by the button.
/// </summary>
[ViewVariables]
public string? Text { get => Label.Text; set => Label.Text = value; }
}
}