在系统开发中,经常用到系统颜色,来修饰自己的控件。
在没有美工帮助的时候,靠自己的审美观点以所见即所得的方式选到合适的系统颜色。
下面我们用一段代码来实现。
首先,定义一个窗体,不妨叫做FrmColors,在Text中我们可以输入Enum Colors。然后在FORM中添加一个FlowLayoutPanel控件。
这个控件的作用是自动将生成的控件以列表的方式显示。
我个人比较喜欢在窗体的构造函数中增加InitThisForm方法,来初始化窗体控件。当然,微软官方并不建议这样做的,随个人习惯而已。
枚举系统颜色要用到以下几个方面:
1、使用typeof运算符;
2、使用KnownColor枚举;
3、动态生成控件。
下面贴出该工具的主要代码:
1 private void InitThisForm()
2 {
3 // Get all the values from the KnownColor enumeration.
4 System.Array colorsArray = Enum.GetValues(typeof(KnownColor));
5 KnownColor[] allColors = new KnownColor[colorsArray.Length];
6
7 for (int i = 0; i < colorsArray.Length; i++)
8 {
9 string colorName = colorsArray.GetValue(i).ToString();
10 // KnownColor kc = colorsArray.GetValue(i) as KnownColor;
11 Color color = Color.FromName(colorName);
12
13 string controlName = "lbl_" + i.ToString();
14 Label lbl = new Label();
15 lbl.Name = controlName;
16
17 lbl.BackColor = color;
18 lbl.Text = colorName;
19
20 lbl.ForeColor = color.R < 128 || color.G < 128 || color.B < 128 ? Color.White : Color.Black;
21 lbl.Click += new EventHandler(lb_Click);
22 lbl.MouseHover += new EventHandler(lb_MouseHover);
23 lbl.MouseLeave += new EventHandler(lb_MouseLeave);
24 lbl.MouseEnter += new EventHandler(lbl_MouseEnter);
25 this.flowLayoutPanel1.Controls.Add(lbl);
26
27 Label lbsplit = new Label();
28 lbsplit.AutoSize = false;
29 lbsplit.Height = 1;
30 this.flowLayoutPanel1.Controls.Add(lbsplit);
31 }
现在,就可以将系统颜色用通过程序创建的Label的BackColor来显示出来了,并且,在TEXT中显示ColorName。
大家注意到我还在Label创建的时候增加了Click事件,这是为了在点击Label时,将Color的名字显示在txtColorName中。
代码如下:
1 void lb_Click(object sender, EventArgs e)
2 {
3 this.lblSelectColor.BackColor = ((Label)sender).BackColor;
4 this.txtColorName.Text = ((Label)sender).BackColor.Name;
5 this.txtColorName.SelectAll();
6 }
在MouseEnter和MouseLeave事件中,我分别改变了Label的BorderStyle属性,是为了显示丐来更突出。
1 void lbl_MouseEnter(object sender, EventArgs e)
2 {
3 Label lb = (Label)sender;
4 lb.BorderStyle = BorderStyle.FixedSingle;
5 }
6
7 void lb_MouseLeave(object sender, EventArgs e)
8 {
9 Label lb = (Label)sender;
10 lb.BorderStyle = BorderStyle.None;
11 }
另外,由于在Click事件代码中增加了一句this.txtColorName.SelectAll();则在点击一个理想的颜色时,直接使用Ctrl+C就可以把颜色
名称复制到剪切板了。
效果图如下:
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架