前提

入行已经7,8年了,一直想做一套漂亮点的自定义控件,于是就有了本系列文章。

开源地址:https://gitee.com/kwwwvagaa/net_winform_custom_control
<https://gitee.com/kwwwvagaa/net_winform_custom_control>

如果觉得写的还行,请点个 star 支持一下吧

欢迎前来交流探讨: 企鹅群568015492 
<https://shang.qq.com/wpa/qunwpa?idkey=6e08741ef16fe53bf0314c1c9e336c4f626047943a8b76bac062361bab6b4f8d>

目录

https://www.cnblogs.com/bfyx/p/11364884.html
<https://www.cnblogs.com/bfyx/p/11364884.html>

准备工作

该控件将继承基类控件UCControlBase,如果你还对UCControlBase不了解的下,

请移步 (一)c#Winform自定义控件-基类控件 <https://www.cnblogs.com/bfyx/p/11361809.html>  查看

首先我们了解下要做的是什么,我们需要做一个可以自定义填充颜色,有圆角边框,有角标的按钮

开始

添加一个用户控件,命名为UCBtnExt ,继承 UCControlBase

先来看看我们按钮需要支持的属性吧
1 #region 字段属性 2 [Description("是否显示角标"), Category("自定义")] 3 public bool
IsShowTips 4 { 5 get 6 { 7 return this.lblTips.Visible; 8 } 9 set 10 {
11 this.lblTips.Visible = value; 12 } 13 } 14 15 [Description("角标文字"),
Category("自定义")] 16 public string TipsText 17 { 18 get 19 { 20 return this
.lblTips.Text;21 } 22 set 23 { 24 this.lblTips.Text = value; 25 } 26 } 27 28
private Color _btnBackColor = Color.White; 29 [Description("按钮背景色"), Category("
自定义")] 30 public Color BtnBackColor 31 { 32 get { return _btnBackColor; } 33
set 34 { 35 _btnBackColor = value; 36 this.BackColor = value; 37 } 38 } 39 40
private Color _btnForeColor = Color.Black; 41 /// <summary> 42 /// 按钮字体颜色 43 ///
</summary> 44 [Description("按钮字体颜色"), Category("自定义")] 45 public Color
BtnForeColor46 { 47 get { return _btnForeColor; } 48 set 49 { 50
_btnForeColor = value; 51 this.lbl.ForeColor = value; 52 } 53 } 54 55 private
Font _btnFont =new System.Drawing.Font("微软雅黑", 12F,
System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134
)));56 /// <summary> 57 /// 按钮字体 58 /// </summary> 59 [Description("按钮字体"),
Category("自定义")] 60 public Font BtnFont 61 { 62 get { return _btnFont; } 63 set
64 { 65 _btnFont = value; 66 this.lbl.Font = value; 67 } 68 } 69 70 ///
<summary> 71 /// 按钮点击事件 72 /// </summary> 73 [Description("按钮点击事件"), Category("
自定义")] 74 public event EventHandler BtnClick; 75 76 private string _btnText; 77
/// <summary> 78 /// 按钮文字 79 /// </summary> 80 [Description("按钮文字"), Category("
自定义")] 81 public string BtnText 82 { 83 get { return _btnText; } 84 set 85 {
86 _btnText = value; 87 lbl.Text = value; 88 } 89 } 90 #endregion
有了属性是不是就更明了呢

还有最后关键的一点东西,就是按钮的点击事件
1 private void lbl_MouseDown(object sender, MouseEventArgs e) 2 { 3 if (this
.BtnClick !=null) 4 BtnClick(this, e); 5 }
至此基本上就完工了,下面列出了完整的代码
1 // 版权所有 黄正辉 交流群:568015492 QQ:623128629 2 // 文件名称:UCBtnExt.cs 3 //
创建日期:2019-08-15 15:57:36 4 // 功能描述:按钮 5 // 项目地址:
https://gitee.com/kwwwvagaa/net_winform_custom_control 6 7 using System; 8
using System.Collections.Generic; 9 using System.ComponentModel; 10 using
System.Drawing; 11 using System.Data; 12 using System.Linq; 13 using
System.Text; 14 using System.Windows.Forms; 15 16 namespace
HZH_Controls.Controls 17 { 18 [DefaultEvent("BtnClick")] 19 public partial
class UCBtnExt : UCControlBase 20 { 21 #region 字段属性 22 [Description("是否显示角标"
), Category("自定义")] 23 public bool IsShowTips 24 { 25 get 26 { 27 return
this.lblTips.Visible; 28 } 29 set 30 { 31 this.lblTips.Visible = value;
32 } 33 } 34 35 [Description("角标文字"), Category("自定义")] 36 public string
TipsText 37 { 38 get 39 { 40 return this.lblTips.Text; 41 } 42 set 43
{ 44 this.lblTips.Text = value; 45 } 46 } 47 48 private Color
_btnBackColor = Color.White; 49 [Description("按钮背景色"), Category("自定义")] 50
public Color BtnBackColor 51 { 52 get { return _btnBackColor; } 53 set 54
{ 55 _btnBackColor = value; 56 this.BackColor = value; 57 } 58 } 59 60
private Color _btnForeColor = Color.Black; 61 /// <summary> 62 /// 按钮字体颜色 63
/// </summary> 64 [Description("按钮字体颜色"), Category("自定义")] 65 public Color
BtnForeColor 66 { 67 get { return _btnForeColor; } 68 set 69 { 70
_btnForeColor = value; 71 this.lbl.ForeColor = value; 72 } 73 } 74 75
private Font _btnFont = new System.Drawing.Font("微软雅黑", 12F,
System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134
))); 76 /// <summary> 77 /// 按钮字体 78 /// </summary> 79 [Description("按钮字体"),
Category("自定义")] 80 public Font BtnFont 81 { 82 get { return _btnFont; } 83
set 84 { 85 _btnFont = value; 86 this.lbl.Font = value; 87 } 88 } 89
90 /// <summary> 91 /// 按钮点击事件 92 /// </summary> 93 [Description("按钮点击事件"),
Category("自定义")] 94 public event EventHandler BtnClick; 95 96 private string
_btnText; 97 /// <summary> 98 /// 按钮文字 99 /// </summary> 100 [Description("
按钮文字"), Category("自定义")] 101 public string BtnText 102 { 103 get { return
_btnText; }104 set 105 { 106 _btnText = value; 107 lbl.Text = value; 108 } 109
}110 #endregion 111 public UCBtnExt() 112 { 113 InitializeComponent(); 114
this.TabStop = false; 115 } 116 117 private void lbl_MouseDown(object sender,
MouseEventArgs e)118 { 119 if (this.BtnClick != null) 120 BtnClick(this, e);
121 } 122 } 123 } View Code 1 namespace HZH_Controls.Controls 2 { 3 public
partial class UCBtnExt 4 { 5 /// <summary> 6 /// 必需的设计器变量。 7 /// </summary>
8 private System.ComponentModel.IContainer components = null; 9 10 ///
<summary> 11 /// 清理所有正在使用的资源。 12 /// </summary> 13 /// <param
name="disposing">如果应释放托管资源,为 true;否则为 false。</param> 14 protected override void
Dispose(bool disposing) 15 { 16 if (disposing && (components != null)) 17
{ 18 components.Dispose(); 19 } 20 base.Dispose(disposing); 21 } 22 23
#region 组件设计器生成的代码 24 25 /// <summary> 26 /// 设计器支持所需的方法 - 不要 27 ///
使用代码编辑器修改此方法的内容。 28 /// </summary> 29 private void InitializeComponent() 30 {
31 this.components = new System.ComponentModel.Container(); 32
System.ComponentModel.ComponentResourceManager resources =new
System.ComponentModel.ComponentResourceManager(typeof(UCBtnExt)); 33 this.lbl =
new System.Windows.Forms.Label(); 34 this.lblTips = new
System.Windows.Forms.Label(); 35 this.imageList1 = new
System.Windows.Forms.ImageList(this.components); 36 this.SuspendLayout(); 37
// 38 // lbl 39 // 40 this.lbl.BackColor = System.Drawing.Color.Transparent;
41 this.lbl.Dock = System.Windows.Forms.DockStyle.Fill; 42 this.lbl.Font = new
System.Drawing.Font("微软雅黑", 12F, System.Drawing.FontStyle.Regular,
System.Drawing.GraphicsUnit.Point, ((byte)(134))); 43 this.lbl.ImageAlign =
System.Drawing.ContentAlignment.MiddleLeft; 44 this.lbl.Location = new
System.Drawing.Point(0, 0); 45 this.lbl.Name = "lbl"; 46 this.lbl.Size = new
System.Drawing.Size(184, 60); 47 this.lbl.TabIndex = 0; 48 this.lbl.Text = "
自定义按钮"; 49 this.lbl.TextAlign = System.Drawing.ContentAlignment.MiddleCenter;
50 this.lbl.MouseDown += new System.Windows.Forms.MouseEventHandler(this
.lbl_MouseDown); 51 // 52 // lblTips 53 // 54 this.lblTips.Anchor =
((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top |
System.Windows.Forms.AnchorStyles.Right))); 55 this.lblTips.BackColor =
System.Drawing.Color.Transparent; 56 this.lblTips.Font = new
System.Drawing.Font("Arial Unicode MS", 12F, System.Drawing.FontStyle.Regular,
System.Drawing.GraphicsUnit.Point, ((byte)(134))); 57 this.lblTips.ForeColor =
System.Drawing.Color.White; 58 this.lblTips.ImageIndex = 0; 59 this
.lblTips.ImageList =this.imageList1; 60 this.lblTips.Location = new
System.Drawing.Point(158, 0); 61 this.lblTips.Name = "lblTips"; 62 this
.lblTips.Size =new System.Drawing.Size(24, 24); 63 this.lblTips.TabIndex = 1;
64 this.lblTips.TextAlign = System.Drawing.ContentAlignment.MiddleCenter; 65
this.lblTips.Visible = false; 66 // 67 // imageList1 68 // 69 this
.imageList1.ImageStream =
((System.Windows.Forms.ImageListStreamer)(resources.GetObject("
imageList1.ImageStream"))); 70 this.imageList1.TransparentColor =
System.Drawing.Color.Transparent; 71 this.imageList1.Images.SetKeyName(0, "
tips.png"); 72 // 73 // UCBtnExt 74 // 75 this.AutoScaleMode =
System.Windows.Forms.AutoScaleMode.None; 76 this.BackColor =
System.Drawing.Color.Transparent; 77 this.ConerRadius = 5; 78 this
.Controls.Add(this.lblTips); 79 this.Controls.Add(this.lbl); 80 this.Cursor =
System.Windows.Forms.Cursors.Hand; 81 this.FillColor =
System.Drawing.Color.FromArgb(((int)(((byte)(247)))), ((int)(((byte)(247)))), ((
int)(((byte)(247))))); 82 this.IsShowRect = true; 83 this.IsRadius = true; 84
this.Margin = new System.Windows.Forms.Padding(0); 85 this.Name = "UCBtnExt";
86 this.RectColor = System.Drawing.Color.FromArgb(((int)(((byte)(247)))), ((int
)(((byte)(247)))), ((int)(((byte)(247))))); 87 this.Size = new
System.Drawing.Size(184, 60); 88 this.ResumeLayout(false); 89 90 } 91 92
#endregion 93 94 public System.Windows.Forms.Label lbl; 95 private
System.Windows.Forms.Label lblTips; 96 private System.Windows.Forms.ImageList
imageList1; 97 98 99 } 100 } View Code
用处及效果

用处:按钮有什么用,我想我不用解释了吧

效果:



 

最后的话

如果你喜欢的话,请到 https://gitee.com/kwwwvagaa/net_winform_custom_control
<https://gitee.com/kwwwvagaa/net_winform_custom_control> 点个星星吧

友情链接
KaDraw流程图
API参考文档
OK工具箱
云服务器优惠
阿里云优惠券
腾讯云优惠券
华为云优惠券
站点信息
问题反馈
邮箱:[email protected]
QQ群:637538335
关注微信