C#   发布时间:2022-04-03  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了(三)c#Winform自定义控件-有图标的按钮大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

前提

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

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

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

欢迎前来交流探讨: 企鹅群568015492 

(三)c#Winform自定义控件-有图标的按钮

准备工作

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

请移步 (二)c#Winform自定义控件-按钮 查看

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

开始

 添加一个用户控件UCBtnImg 继承UCBtnExt

添加属性

 1 private String _btntext = "自定义按钮";
 2         /// <sumMary>
 3         /// 按钮文字
 4         /// </sumMary>
 5         [Description("按钮文字"),Category("自定义")]
 6         public new String Btntext
 7         {
 8             get { return _btntext; }
 9             set
10             {
11                 _btntext = value;
12                 lbl.Text = "    " + value;
13                 lbl.@R_673_7017@h();
14             }
15         }
16         /// <sumMary>
17         /// 图片
18         /// </sumMary>
19         [Description("图片"),Category("自定义")]
20         public Image Image
21         {
22             get
23             {
24                 return this.imageList1.Images[0];
25             }
26             set
27             {
28                 this.imageList1.Images.Clear();
29                 this.imageList1.Images.Add(value);
30                 this.lbl.ImageIndex = 0;
31             }
32         }

下面看一下完整代码

(三)c#Winform自定义控件-有图标的按钮

 1 // 版权所有  黄正辉  交流群:568015492   QQ:623128629
 2 // 文件名称:UCBtnImg.cs
 3 // 创建日期:2019-08-15 15:58:07
 4 // 功能描述:按钮
 5 // 项目地址:https://gitee.com/kwwwvagaa/net_winform_custom_control
 6 using System;
 7 using System.Collections.Generic;
 8 using System.ComponentModel;
 9 using System.Drawing;
10 using System.Data;
11 using System.Linq;
12 using System.Text;
13 using System.Windows.Forms;
14 
15 namespace HZH_Controls.Controls
16 {
17     /// <sumMary>
18     /// 
19     /// </sumMary>
20     public partial class UCBtnImg : UCBtnExt
21     {
22         private String _btntext = "自定义按钮";
23         /// <sumMary>
24         /// 按钮文字
25         /// </sumMary>
26         [Description("按钮文字"),Category("自定义")]
27         public new String Btntext
28         {
29             get { return _btntext; }
30             set
31             {
32                 _btntext = value;
33                 lbl.Text = "    " + value;
34                 lbl.@R_673_7017@h();
35             }
36         }
37         /// <sumMary>
38         /// 图片
39         /// </sumMary>
40         [Description("图片"),Category("自定义")]
41         public Image Image
42         {
43             get
44             {
45                 return this.imageList1.Images[0];
46             }
47             set
48             {
49                 this.imageList1.Images.Clear();
50                 this.imageList1.Images.Add(value);
51                 this.lbl.ImageIndex = 0;
52             }
53         }
54 
55         public UCBtnImg()
56         {
57             InitializeComponent();
58             base.btnForeColor = ForeColor = System.Drawing.Color.FromArgb(((int)(((byte)(102)))),((int)(((byte)(102)))),((int)(((byte)(102)))));
59             base.btnFont = new System.Drawing.Font("微软雅黑",17F);
60             base.btntext = "    自定义按钮";
61         }
62     }
63 }
View Code

(三)c#Winform自定义控件-有图标的按钮

 1 namespace HZH_Controls.Controls
 2 {
 3     partial class UCBtnImg
 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(UCBtnImg));
33             this.imageList1 = new System.Windows.Forms.ImageList(this.components);
34             this.SuspendLayout();
35             // 
36             // lbl
37             // 
38             //this.lbl.Font = new System.Drawing.Font("微软雅黑",17F);
39             //this.lbl.ForeColor = System.Drawing.Color.FromArgb(((int)(((bytE)(102)))),((int)(((bytE)(102)))),((int)(((bytE)(102)))));
40             this.lbl.ImageIndex = 0;
41             this.lbl.ImageList = this.imageList1;
42             this.lbl.Padding = new System.Windows.Forms.Padding(10,0,0);
43             this.lbl.Text = "    自定义按钮";
44             this.lbl.TextAlign = System.Drawing.ContentAlignment.MiddleLeft;
45             // 
46             // imageList1
47             // 
48             this.imageList1.ImageStream = ((System.Windows.Forms.ImageListStreamer)(resources.GetObject("imageList1.ImageStream")));
49             this.imageList1.TransparentColor = System.Drawing.Color.Transparent;
50             this.imageList1.Images.SetKeyName(0,"BACk.png");
51             // 
52             // BtnBACk
53             // 
54             this.AutoScaleDimensions = new System.Drawing.SizeF(6F,12F);
55             this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.None;
56             this.Name = "BtnBACk";
57             this.ResumeLayout(false);
58 
59         }
60 
61         #endregion
62 
63         private System.Windows.Forms.ImageList imageList1;
64     }
65 }
View Code

用处及效果

用处:按钮需要显示图标时使用

效果

(三)c#Winform自定义控件-有图标的按钮

 

最后的话

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

大佬总结

以上是大佬教程为你收集整理的(三)c#Winform自定义控件-有图标的按钮全部内容,希望文章能够帮你解决(三)c#Winform自定义控件-有图标的按钮所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。