SunnyUI/SunnyUI/Controls/UIIntegerUpDown.cs
2024-09-17 22:49:54 +08:00

350 lines
12 KiB
C#
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/******************************************************************************
* SunnyUI 开源控件库、工具类库、扩展类库、多页面开发框架。
* CopyRight (C) 2012-2024 ShenYongHua(沈永华).
* QQ群56829229 QQ17612584 EMailSunnyUI@QQ.Com
*
* Blog: https://www.cnblogs.com/yhuse
* Gitee: https://gitee.com/yhuse/SunnyUI
* GitHub: https://github.com/yhuse/SunnyUI
*
* SunnyUI.dll can be used for free under the GPL-3.0 license.
* If you use this code, please keep this note.
* 如果您使用此代码,请保留此说明。
******************************************************************************
* 文件名称: UIIntegerUpDown.cs
* 文件说明: 数字上下选择框
* 当前版本: V3.1
* 创建日期: 2020-01-01
*
* 2020-01-01: V2.2.0 增加文件说明
* 2020-04-25: V2.2.4 更新主题配置类
* 2020-08-14: V2.2.7 增加字体调整
* 2020-12-10: V3.0.9 增加Readonly属性
* 2022-02-07: V3.1.0 增加圆角控制
* 2022-02-24: V3.1.1 可以设置按钮大小和颜色
* 2022-05-05: V3.1.8 增加禁止输入属性
* 2022-09-16: V3.2.4 增加是否可以双击输入属性
* 2022-11-12: V3.2.8 修改整数离开判断为实时输入判断
* 2022-11-12: V3.2.8 删除MaximumEnabled、MinimumEnabled、HasMaximum、HasMinimum属性
* 2023-01-28: V3.3.1 修改文本框数据输入数据变更事件为MouseLeave
* 2023-03-24: V3.3.3 删除ForbidInput属性使用Inputable属性
* 2023-12-28: V3.6.2 修复设置Style时按钮颜色不一致
* 2024-08-27: V3.6.9 修改编辑框字体与显示字体一致
* 2024-08-27: V3.7.0 增加加按钮字体图标的偏移位置
******************************************************************************/
using System;
using System.ComponentModel;
using System.Drawing;
using System.Windows.Forms;
namespace Sunny.UI
{
[DefaultEvent("ValueChanged")]
[DefaultProperty("Value")]
public sealed partial class UIIntegerUpDown : UIPanel, IToolTip
{
public delegate void OnValueChanged(object sender, int value);
public UIIntegerUpDown()
{
InitializeComponent();
SetStyleFlags();
ShowText = false;
edit.Type = UITextBox.UIEditType.Integer;
edit.Parent = pnlValue;
edit.Visible = false;
edit.BorderStyle = BorderStyle.None;
edit.MouseLeave += Edit_Leave;
pnlValue.Paint += PnlValue_Paint;
btnAdd.Style = UIStyle.Custom;
btnDec.Style = UIStyle.Custom;
}
[Browsable(false)]
public override string[] FormTranslatorProperties { get; }
/// <summary>
/// 需要额外设置ToolTip的控件
/// </summary>
/// <returns>控件</returns>
public Control ExToolTipControl()
{
return pnlValue;
}
private void PnlValue_Paint(object sender, PaintEventArgs e)
{
if (Enabled)
{
e.Graphics.DrawLine(RectColor, 0, 0, pnlValue.Width, 0);
e.Graphics.DrawLine(RectColor, 0, Height - 1, pnlValue.Width, Height - 1);
}
else
{
e.Graphics.DrawLine(RectDisableColor, 0, 0, pnlValue.Width, 0);
e.Graphics.DrawLine(RectDisableColor, 0, Height - 1, pnlValue.Width, Height - 1);
}
}
private void Edit_Leave(object sender, EventArgs e)
{
if (edit.Visible)
{
edit.Visible = false;
pnlValue.FillColor = pnlColor;
Value = edit.IntValue;
}
}
public event OnValueChanged ValueChanged;
private int _value;
[DefaultValue(0)]
[Description("选中数值"), Category("SunnyUI")]
public int Value
{
get => _value;
set
{
value = (int)edit.CheckMaxMin(value);
if (_value != value)
{
_value = value;
pnlValue.Text = _value.ToString();
ValueChanged?.Invoke(this, _value);
}
}
}
/// <summary>
/// 重载字体变更
/// </summary>
/// <param name="e">参数</param>
protected override void OnFontChanged(EventArgs e)
{
base.OnFontChanged(e);
if (DefaultFontSize < 0 && pnlValue != null) pnlValue.Font = this.Font;
if (DefaultFontSize < 0 && edit != null) edit.Font = this.Font;
}
private int step = 1;
[DefaultValue(1)]
[Description("步进值"), Category("SunnyUI")]
public int Step
{
get => step;
set => step = Math.Max(1, value);
}
private void btnAdd_Click(object sender, EventArgs e)
{
if (ReadOnly) return;
Value += Step;
if (edit.Visible)
{
edit.Visible = false;
pnlValue.FillColor = pnlColor;
}
}
private void btnDec_Click(object sender, EventArgs e)
{
if (ReadOnly) return;
Value -= Step;
if (edit.Visible)
{
edit.Visible = false;
pnlValue.FillColor = pnlColor;
}
}
[Description("最大值"), Category("SunnyUI")]
[DefaultValue(int.MaxValue)]
public int Maximum
{
get => (int)edit.MaxValue;
set => edit.MaxValue = value;
}
[Description("最小值"), Category("SunnyUI")]
[DefaultValue(int.MinValue)]
public int Minimum
{
get => (int)edit.MinValue;
set => edit.MinValue = value;
}
[DefaultValue(true)]
[Description("是否可以双击输入"), Category("SunnyUI")]
public bool Inputable { get; set; } = true;
private readonly UIEdit edit = new UIEdit();
private Color pnlColor;
private void pnlValue_DoubleClick(object sender, EventArgs e)
{
if (ReadOnly) return;
if (!Inputable) return;
edit.Left = 1;
edit.Font = pnlValue.Font;
edit.Top = (pnlValue.Height - edit.Height) / 2;
edit.Width = pnlValue.Width - 2;
pnlColor = pnlValue.FillColor;
pnlValue.FillColor = Color.White;
edit.TextAlign = HorizontalAlignment.Center;
edit.IntValue = Value;
edit.BringToFront();
edit.Visible = true;
edit.Focus();
edit.SelectAll();
}
[DefaultValue(false)]
[Description("是否只读"), Category("SunnyUI")]
public bool ReadOnly { get; set; }
protected override void OnRadiusSidesChange()
{
if (btnDec == null || btnAdd == null) return;
btnDec.RadiusSides =
(RadiusSides.HasFlag(UICornerRadiusSides.LeftTop) ? UICornerRadiusSides.LeftTop : UICornerRadiusSides.None) |
(RadiusSides.HasFlag(UICornerRadiusSides.LeftBottom) ? UICornerRadiusSides.LeftBottom : UICornerRadiusSides.None);
btnAdd.RadiusSides =
(RadiusSides.HasFlag(UICornerRadiusSides.RightTop) ? UICornerRadiusSides.RightTop : UICornerRadiusSides.None) |
(RadiusSides.HasFlag(UICornerRadiusSides.RightBottom) ? UICornerRadiusSides.RightBottom : UICornerRadiusSides.None);
}
protected override void OnRadiusChanged(int value)
{
if (btnDec == null || btnAdd == null) return;
btnDec.Radius = btnAdd.Radius = value;
}
/// <summary>
/// 重载控件尺寸变更
/// </summary>
/// <param name="e">参数</param>
protected override void OnSizeChanged(EventArgs e)
{
base.OnSizeChanged(e);
if (Height < UIGlobal.EditorMinHeight) Height = UIGlobal.EditorMinHeight;
if (Height > UIGlobal.EditorMaxHeight) Height = UIGlobal.EditorMaxHeight;
}
public override void SetStyleColor(UIBaseStyle uiColor)
{
base.SetStyleColor(uiColor);
btnAdd.SetStyleColor(uiColor);
btnDec.SetStyleColor(uiColor);
pnlValue.SetStyleColor(uiColor);
btnAdd.Invalidate();
btnDec.Invalidate();
pnlValue.Invalidate();
}
/// <summary>
/// 填充颜色,当值为背景色或透明色或空值则不填充
/// </summary>
[Description("填充颜色"), Category("SunnyUI")]
[DefaultValue(typeof(Color), "80, 160, 255")]
public Color ButtonFillColor
{
get => btnAdd.FillColor;
set => btnDec.FillColor = btnAdd.FillColor = value;
}
/// <summary>
/// 鼠标移上时填充颜色
/// </summary>
[DefaultValue(typeof(Color), "115, 179, 255"), Category("SunnyUI")]
[Description("鼠标移上时填充颜色")]
public Color ButtonFillHoverColor
{
get => btnAdd.FillHoverColor;
set => btnDec.RectHoverColor = btnAdd.RectHoverColor = btnDec.FillHoverColor = btnAdd.FillHoverColor = value;
}
/// <summary>
/// 鼠标按下时填充颜色
/// </summary>
[DefaultValue(typeof(Color), "64, 128, 204"), Category("SunnyUI")]
[Description("鼠标按下时填充颜色")]
public Color ButtonFillPressColor
{
get => btnAdd.FillPressColor;
set => btnDec.RectPressColor = btnAdd.RectPressColor = btnDec.FillPressColor = btnAdd.FillPressColor = value;
}
/// <summary>
/// 字体图标颜色
/// </summary>
[Description("图标颜色"), Category("SunnyUI")]
[DefaultValue(typeof(Color), "White")]
public Color ButtonSymbolColor
{
get => btnAdd.SymbolColor;
set => btnDec.SymbolColor = btnAdd.SymbolColor = value;
}
/// <summary>
/// 边框颜色
/// </summary>
[Description("边框颜色"), Category("SunnyUI")]
[DefaultValue(typeof(Color), "80, 160, 255")]
public Color ButtonRectColor
{
get => btnAdd.RectColor;
set => pnlValue.RectColor = btnDec.RectColor = btnAdd.RectColor = value;
}
protected override void AfterSetFillColor(Color color)
{
base.AfterSetFillColor(color);
if (pnlValue == null) return;
pnlValue.FillColor = color;
}
private int buttonWidth = 29;
[DefaultValue(29)]
public int ButtonWidth
{
get => buttonWidth;
set
{
buttonWidth = Math.Max(value, 29);
if (btnAdd == null || btnDec == null) return;
btnAdd.Width = btnDec.Width = buttonWidth;
}
}
public override Color ForeColor { get => pnlValue.ForeColor; set => pnlValue.ForeColor = value; }
/// <summary>
/// 加按钮字体图标的偏移位置
/// </summary>
[DefaultValue(typeof(Point), "0, 0")]
[Description("加按钮字体图标的偏移位置"), Category("SunnyUI")]
public Point AddSymbolOffset
{
get => btnAdd.SymbolOffset;
set => btnAdd.SymbolOffset = value;
}
/// <summary>
/// 减按钮字体图标的偏移位置
/// </summary>
[DefaultValue(typeof(Point), "0, 0")]
[Description("减按钮字体图标的偏移位置"), Category("SunnyUI")]
public Point DecSymbolOffset
{
get => btnDec.SymbolOffset;
set => btnDec.SymbolOffset = value;
}
}
}