* UIDropControl: 修复在高DPI下,文字垂直不居中的问题

* UIDropControl: 修复在某些字体不显示下划线的问题
This commit is contained in:
Sunny 2023-10-25 22:30:43 +08:00
parent 65edeffedd
commit 85a56809f1
4 changed files with 72 additions and 47 deletions

View File

@ -36,13 +36,11 @@
// //
// UIDropControl // UIDropControl
// //
AutoScaleDimensions = new System.Drawing.SizeF(10F, 21F);
AutoScaleMode = System.Windows.Forms.AutoScaleMode.None; AutoScaleMode = System.Windows.Forms.AutoScaleMode.None;
MinimumSize = new System.Drawing.Size(63, 0); MinimumSize = new System.Drawing.Size(63, 0);
Name = "UIDropControl"; Name = "UIDropControl";
Size = new System.Drawing.Size(150, 29); Size = new System.Drawing.Size(194, 29);
ResumeLayout(false); ResumeLayout(false);
} }
#endregion #endregion

View File

@ -27,6 +27,8 @@
* 2023-05-16: V3.3.6 DrawFontImage函数 * 2023-05-16: V3.3.6 DrawFontImage函数
* 2023-08-24: V3.4.2 * 2023-08-24: V3.4.2
* 2023-08-28: V3.4.2 * 2023-08-28: V3.4.2
* 2023-10-25: V3.5.1 DPI下
* 2023-10-25: V3.5.1 线
******************************************************************************/ ******************************************************************************/
using System; using System;
@ -47,8 +49,7 @@ namespace Sunny.UI
SetStyleFlags(); SetStyleFlags();
Padding = new Padding(0, 0, 30, 2); Padding = new Padding(0, 0, 30, 2);
edit.AutoSize = false; edit.AutoSize = true;
//edit.Font = UIStyles.Font();
edit.Left = 4; edit.Left = 4;
edit.Top = 3; edit.Top = 3;
edit.Text = String.Empty; edit.Text = String.Empty;
@ -59,9 +60,14 @@ namespace Sunny.UI
edit.KeyUp += EditOnKeyUp; edit.KeyUp += EditOnKeyUp;
edit.KeyPress += EditOnKeyPress; edit.KeyPress += EditOnKeyPress;
edit.LostFocus += Edit_LostFocus; edit.LostFocus += Edit_LostFocus;
edit.SizeChanged += Edit_SizeChanged;
edit.Invalidate(); edit.Invalidate();
Controls.Add(edit); Controls.Add(edit);
lastEditHeight = edit.Height;
Width = 150;
Height = 29;
TextAlignment = ContentAlignment.MiddleLeft; TextAlignment = ContentAlignment.MiddleLeft;
fillColor = Color.White; fillColor = Color.White;
edit.BackColor = Color.White; edit.BackColor = Color.White;
@ -70,6 +76,16 @@ namespace Sunny.UI
ControlBoxRect = new Rectangle(Width - 24, 0, 24, Height); ControlBoxRect = new Rectangle(Width - 24, 0, 24, Height);
} }
int lastEditHeight = -1;
private void Edit_SizeChanged(object sender, EventArgs e)
{
if (lastEditHeight != edit.Height)
{
lastEditHeight = edit.Height;
SizeChange();
}
}
public override void SetDPIScale() public override void SetDPIScale()
{ {
base.SetDPIScale(); base.SetDPIScale();
@ -87,7 +103,6 @@ namespace Sunny.UI
{ {
base.OnFontChanged(e); base.OnFontChanged(e);
if (DefaultFontSize < 0 && edit != null) edit.Font = this.Font; if (DefaultFontSize < 0 && edit != null) edit.Font = this.Font;
SizeChange();
Invalidate(); Invalidate();
} }
@ -371,19 +386,36 @@ namespace Sunny.UI
/// <param name="e">参数</param> /// <param name="e">参数</param>
protected override void OnSizeChanged(EventArgs e) protected override void OnSizeChanged(EventArgs e)
{ {
SizeChange(); base.OnSizeChanged(e);
if (!NoNeedChange)
{
SizeChange();
}
if (tipsBtn != null) if (tipsBtn != null)
{ {
tipsBtn.Location = new System.Drawing.Point(Width - 8, 2); tipsBtn.Location = new System.Drawing.Point(Width - 8, 2);
} }
} }
private bool NoNeedChange = false;
private void SizeChange() private void SizeChange()
{ {
if (Height < UIGlobal.EditorMinHeight) Height = UIGlobal.EditorMinHeight; if (Height < edit.Height + RectSize * 2 + 2)
if (Height > UIGlobal.EditorMaxHeight) Height = UIGlobal.EditorMaxHeight; {
edit.Height = Math.Min(Height - RectSize * 2, edit.PreferredHeight); NoNeedChange = true;
edit.Top = (Height - edit.Height) / 2; Height = edit.Height + RectSize * 2 + 2;
edit.Top = (Height - edit.Height) / 2;
NoNeedChange = false;
}
if (edit.Top != (Height - edit.Height) / 2 + 1)
{
edit.Top = (Height - edit.Height) / 2 + 1;
}
edit.Left = 4 + Padding.Left; edit.Left = 4 + Padding.Left;
edit.Width = Width - Padding.Left - Padding.Right - 4; edit.Width = Width - Padding.Left - Padding.Right - 4;
ControlBoxRect = new Rectangle(Width - 24, 0, 24, Height); ControlBoxRect = new Rectangle(Width - 24, 0, 24, Height);

View File

@ -109,9 +109,6 @@ namespace Sunny.UI
edit.MouseDoubleClick += Edit_MouseDoubleClick; edit.MouseDoubleClick += Edit_MouseDoubleClick;
edit.SizeChanged += Edit_SizeChanged; edit.SizeChanged += Edit_SizeChanged;
Width = 150;
Height = 29;
btn.Parent = this; btn.Parent = this;
btn.Visible = false; btn.Visible = false;
btn.Text = ""; btn.Text = "";
@ -135,8 +132,10 @@ namespace Sunny.UI
bar.MouseEnter += Bar_MouseEnter; bar.MouseEnter += Bar_MouseEnter;
TextAlignment = ContentAlignment.MiddleLeft; TextAlignment = ContentAlignment.MiddleLeft;
SizeChange();
lastEditHeight = edit.Height; lastEditHeight = edit.Height;
Width = 150;
Height = 29;
editCursor = Cursor; editCursor = Cursor;
TextAlignmentChange += UITextBox_TextAlignmentChange; TextAlignmentChange += UITextBox_TextAlignmentChange;
} }
@ -674,12 +673,8 @@ namespace Sunny.UI
base.OnFontChanged(e); base.OnFontChanged(e);
if (DefaultFontSize < 0 && edit != null) if (DefaultFontSize < 0 && edit != null)
{
edit.Font = this.Font; edit.Font = this.Font;
edit.Invalidate();
}
SizeChange();
Invalidate(); Invalidate();
} }
@ -739,9 +734,9 @@ namespace Sunny.UI
NoNeedChange = false; NoNeedChange = false;
} }
if (edit.Top != (Height - edit.Height) / 2) if (edit.Top != (Height - edit.Height) / 2 + 1)
{ {
edit.Top = (Height - edit.Height) / 2; edit.Top = (Height - edit.Height) / 2 + 1;
} }
if (icon == null && Symbol == 0) if (icon == null && Symbol == 0)
@ -783,7 +778,7 @@ namespace Sunny.UI
int barWidth = Math.Max(ScrollBarInfo.VerticalScrollBarWidth() + 1, ScrollBarWidth); int barWidth = Math.Max(ScrollBarInfo.VerticalScrollBarWidth() + 1, ScrollBarWidth);
bar.Top = 2; bar.Top = 2;
bar.Width = barWidth; bar.Width = barWidth;
bar.Left = Width - bar.Width - 1; bar.Left = Width - bar.Width - 2;
bar.Height = Height - 4; bar.Height = Height - 4;
bar.BringToFront(); bar.BringToFront();