[英]How to avoid color changes when button is disabled?
我們有一個 Windows Forms 項目,其中包含很多 FlatStyle 按鈕。
當我們禁用按鈕時,按鈕的 colors 會自動更改 皺眉|:(
是否有可能以某種方式覆蓋它,以便我們自己控制 colors?
您需要使用 EnabledChanged 事件來設置所需的顏色。 這是一個例子。
private void Button1_EnabledChanged(object sender, System.EventArgs e)
{
Button1.ForeColor = sender.enabled == false ? Color.Blue : Color.Red;
Button1.BackColor = Color.AliceBlue;
}
根據您的要求使用所需的顏色。
您還需要使用paint事件。
private void Button1_Paint(object sender, System.Windows.Forms.PaintEventArgs e)
{
dynamic btn = (Button)sender;
dynamic drawBrush = new SolidBrush(btn.ForeColor);
dynamic sf = new StringFormat {
Alignment = StringAlignment.Center,
LineAlignment = StringAlignment.Center };
Button1.Text = string.Empty;
e.Graphics.DrawString("Button1", btn.Font, drawBrush, e.ClipRectangle, sf);
drawBrush.Dispose();
sf.Dispose();
}
要獲得不那么模糊的文本,請改用 TextRenderer 類:
private void Button1_Paint(object sender, PaintEventArgs e)
{
Button btn = (Button)sender;
// make sure Text is not also written on button
btn.Text = string.Empty;
// set flags to center text on button
TextFormatFlags flags = TextFormatFlags.HorizontalCenter | TextFormatFlags.VerticalCenter | TextFormatFlags.WordBreak; // center the text
// render the text onto the button
TextRenderer.DrawText(e.Graphics, "Hello", btn.Font, e.ClipRectangle, btn.ForeColor, flags);
}
以及 Button1_EnabledChanged 方法,如 Harsh 的回答。
在按鈕的 EnableChanged 事件上
private void button1_EnabledChanged(object sender, EventArgs e)
{
if (button1.Enabled == false)
{
button1.ForeColor = Color.DarkGray; //or pick the color you want when not enabled
}
else
{
button1.ForeColor = Color.White; //same here with the color
}
}
我遵循以下方法:- 可以使用自定義變量控制按鈕的 Click() 事件。
private bool btnDisabled;
private void btnClick(object sender, EventArgs e){
if(!btnDisabled) return;}
這樣按鈕甚至不需要被禁用。 該按鈕仍然有點擊的感覺,但不會采取任何行動。 必須使用正確的顏色來傳達按鈕已禁用。
當按鈕部分重繪時,我使用 ClientRectangle 而不是 e.ClipRectangle 來避免剪輯效果:
e.Graphics.Clear(BackColor);
using (var drawBrush = new SolidBrush(ForeColor))
using (var sf = new StringFormat
{
Alignment = StringAlignment.Center,
LineAlignment = StringAlignment.Center
})
{
e.Graphics.DrawString(Text, Font, drawBrush, ClientRectangle, sf);
}
另一種方法是使用 Pre_Render 事件。 該示例使用 Telerik,但標准按鈕也應該可以正常工作。
protected void radButton_PreRender(object sender, EventArgs e)
{
RadButton btn = sender as RadButton;
btn.BackColor = btn.Checked ? Color.LightBlue : Color.White;
}
提出建議永遠不會太晚:
public class BlackButton : Button
{
#region #Private Members
private bool m_BasePaint = false;
#endregion #Private Members
#region #Ctor
public BlackButton() : base()
{
base.ForeColor = Color.White;
base.BackColor = Color.Black;
this.DisabledForeColor = Color.FromArgb(0x6D, 0x6D, 0x6D);
}
#endregion #Ctor
#region #Public Interface
public Color DisabledForeColor
{
get;
set;
}
#endregion #Public Interface
#region #Overrides
public override string Text
{
get
{
if (m_BasePaint)
return "";
return base.Text;
}
set
{
base.Text = value;
}
}
protected override void OnPaint(PaintEventArgs pevent)
{
m_BasePaint = true;
base.OnPaint(pevent);
m_BasePaint = false;
TextFormatFlags flags = TextFormatFlags.HorizontalCenter | TextFormatFlags.VerticalCenter | TextFormatFlags.WordBreak;
TextRenderer.DrawText(pevent.Graphics,
Text,
base.Font,
ClientRectangle,
base.Enabled ? base.ForeColor : this.DisabledForeColor,
flags);
}
#endregion #Overrides
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.