(二)c#Winform自定义控件-按钮

(二)c#Winform自定义控件-按钮

前提

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

GitHub:https://github.com/kwwwvagaa/NetWinformControl

码云:https://gitee.com/kwwwvagaa/net_winform_custom_control.git

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

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

目录

https://blog.csdn.net/kwwwvagaa/article/details/100586547

用处及效果

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

效果:

准备工作

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

请移步 (一)c#Winform自定义控件-基类控件  查看

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

开始

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

先来看看我们按钮需要支持的属性吧

#region 字段属性
        [Description("是否显示角标"), Category("自定义")]
        public bool IsShowTips
        {
            get
            {
                return this.lblTips.Visible;
            }
            set
            {
                this.lblTips.Visible = value;
            }
        }

        [Description("角标文字"), Category("自定义")]
        public string TipsText
        {
            get
            {
                return this.lblTips.Text;
            }
            set
            {
                this.lblTips.Text = value;
            }
        }

        private Color _btnBackColor = Color.White;
        [Description("按钮背景色"), Category("自定义")]
        public Color BtnBackColor
        {
            get { return _btnBackColor; }
            set
            {
                _btnBackColor = value;
                this.BackColor = value;
            }
        }

        private Color _btnForeColor = Color.Black;
        /// <summary>
        /// 按钮字体颜色
        /// </summary>
        [Description("按钮字体颜色"), Category("自定义")]
        public Color BtnForeColor
        {
            get { return _btnForeColor; }
            set
            {
                _btnForeColor = value;
                this.lbl.ForeColor = value;
            }
        }

        private Font _btnFont = new System.Drawing.Font("微软雅黑", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134)));
        /// <summary>
        /// 按钮字体
        /// </summary>
        [Description("按钮字体"), Category("自定义")]
        public Font BtnFont
        {
            get { return _btnFont; }
            set
            {
                _btnFont = value;
                this.lbl.Font = value;
            }
        }

        /// <summary>
        /// 按钮点击事件
        /// </summary>
        [Description("按钮点击事件"), Category("自定义")]
        public event EventHandler BtnClick;

        private string _btnText;
        /// <summary>
        /// 按钮文字
        /// </summary>
        [Description("按钮文字"), Category("自定义")]
        public string BtnText
        {
            get { return _btnText; }
            set
            {
                _btnText = value;
                lbl.Text = value;
            }
        }
        #endregion

有了属性是不是就更明了呢

还有最后关键的一点东西,就是按钮的点击事件

 private void lbl_MouseDown(object sender, MouseEventArgs e)
{
    if (this.BtnClick != null)
         BtnClick(this, e);
}

至此基本上就完工了,下面列出了完整的代码

// 版权所有  黄正辉  交流群:568015492   QQ:623128629
// 文件名称:UCBtnExt.cs
// 创建日期:2019-08-15 15:57:36
// 功能描述:按钮
// 项目地址:https://gitee.com/kwwwvagaa/net_winform_custom_control

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Drawing;
using System.Data;
using System.Linq;
using System.Text;
using System.Windows.Forms;

namespace HZH_Controls.Controls
{
    [DefaultEvent("BtnClick")]
    public partial class UCBtnExt : UCControlBase
    {
        #region 字段属性
        [Description("是否显示角标"), Category("自定义")]
        public bool IsShowTips
        {
            get
            {
                return this.lblTips.Visible;
            }
            set
            {
                this.lblTips.Visible = value;
            }
        }

        [Description("角标文字"), Category("自定义")]
        public string TipsText
        {
            get
            {
                return this.lblTips.Text;
            }
            set
            {
                this.lblTips.Text = value;
            }
        }

        private Color _btnBackColor = Color.White;
        [Description("按钮背景色"), Category("自定义")]
        public Color BtnBackColor
        {
            get { return _btnBackColor; }
            set
            {
                _btnBackColor = value;
                this.BackColor = value;
            }
        }

        private Color _btnForeColor = Color.Black;
        /// <summary>
        /// 按钮字体颜色
        /// </summary>
        [Description("按钮字体颜色"), Category("自定义")]
        public Color BtnForeColor
        {
            get { return _btnForeColor; }
            set
            {
                _btnForeColor = value;
                this.lbl.ForeColor = value;
            }
        }

        private Font _btnFont = new System.Drawing.Font("微软雅黑", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134)));
        /// <summary>
        /// 按钮字体
        /// </summary>
        [Description("按钮字体"), Category("自定义")]
        public Font BtnFont
        {
            get { return _btnFont; }
            set
            {
                _btnFont = value;
                this.lbl.Font = value;
            }
        }

        /// <summary>
        /// 按钮点击事件
        /// </summary>
        [Description("按钮点击事件"), Category("自定义")]
        public event EventHandler BtnClick;

        private string _btnText;
        /// <summary>
        /// 按钮文字
        /// </summary>
        [Description("按钮文字"), Category("自定义")]
        public string BtnText
        {
            get { return _btnText; }
            set
            {
                _btnText = value;
                lbl.Text = value;
            }
        }
        #endregion
        public UCBtnExt()
        {
            InitializeComponent();
            this.TabStop = false;
        }

        private void lbl_MouseDown(object sender, MouseEventArgs e)
        {
            if (this.BtnClick != null)
                BtnClick(this, e);
        }
    }
}
namespace HZH_Controls.Controls
{
    public partial class UCBtnExt
    {
        /// <summary> 
        /// 必需的设计器变量。
        /// </summary>
        private System.ComponentModel.IContainer components = null;

        /// <summary> 
        /// 清理所有正在使用的资源。
        /// </summary>
        /// <param name="disposing">如果应释放托管资源,为 true;否则为 false。</param>
        protected override void Dispose(bool disposing)
        {
            if (disposing && (components != null))
            {
                components.Dispose();
            }
            base.Dispose(disposing);
        }

        #region 组件设计器生成的代码

        /// <summary> 
        /// 设计器支持所需的方法 - 不要
        /// 使用代码编辑器修改此方法的内容。
        /// </summary>
        private void InitializeComponent()
        {
            this.components = new System.ComponentModel.Container();
            System.ComponentModel.ComponentResourceManager resources = new System.ComponentModel.ComponentResourceManager(typeof(UCBtnExt));
            this.lbl = new System.Windows.Forms.Label();
            this.lblTips = new System.Windows.Forms.Label();
            this.imageList1 = new System.Windows.Forms.ImageList(this.components);
            this.SuspendLayout();
            // 
            // lbl
            // 
            this.lbl.BackColor = System.Drawing.Color.Transparent;
            this.lbl.Dock = System.Windows.Forms.DockStyle.Fill;
            this.lbl.Font = new System.Drawing.Font("微软雅黑", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134)));
            this.lbl.ImageAlign = System.Drawing.ContentAlignment.MiddleLeft;
            this.lbl.Location = new System.Drawing.Point(0, 0);
            this.lbl.Name = "lbl";
            this.lbl.Size = new System.Drawing.Size(184, 60);
            this.lbl.TabIndex = 0;
            this.lbl.Text = "自定义按钮";
            this.lbl.TextAlign = System.Drawing.ContentAlignment.MiddleCenter;
            this.lbl.MouseDown += new System.Windows.Forms.MouseEventHandler(this.lbl_MouseDown);
            // 
            // lblTips
            // 
            this.lblTips.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Right)));
            this.lblTips.BackColor = System.Drawing.Color.Transparent;
            this.lblTips.Font = new System.Drawing.Font("Arial Unicode MS", 12F, System.Drawing.FontStyle.Regular, System.Drawing.GraphicsUnit.Point, ((byte)(134)));
            this.lblTips.ForeColor = System.Drawing.Color.White;
            this.lblTips.ImageIndex = 0;
            this.lblTips.ImageList = this.imageList1;
            this.lblTips.Location = new System.Drawing.Point(158, 0);
            this.lblTips.Name = "lblTips";
            this.lblTips.Size = new System.Drawing.Size(24, 24);
            this.lblTips.TabIndex = 1;
            this.lblTips.TextAlign = System.Drawing.ContentAlignment.MiddleCenter;
            this.lblTips.Visible = false;
            // 
            // imageList1
            // 
            this.imageList1.ImageStream = ((System.Windows.Forms.ImageListStreamer)(resources.GetObject("imageList1.ImageStream")));
            this.imageList1.TransparentColor = System.Drawing.Color.Transparent;
            this.imageList1.Images.SetKeyName(0, "tips.png");
            // 
            // UCBtnExt
            // 
            this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.None;
            this.BackColor = System.Drawing.Color.Transparent;
            this.ConerRadius = 5;
            this.Controls.Add(this.lblTips);
            this.Controls.Add(this.lbl);
            this.Cursor = System.Windows.Forms.Cursors.Hand;
            this.FillColor = System.Drawing.Color.FromArgb(((int)(((byte)(247)))), ((int)(((byte)(247)))), ((int)(((byte)(247)))));
            this.IsShowRect = true;
            this.IsRadius = true;
            this.Margin = new System.Windows.Forms.Padding(0);
            this.Name = "UCBtnExt";
            this.RectColor = System.Drawing.Color.FromArgb(((int)(((byte)(247)))), ((int)(((byte)(247)))), ((int)(((byte)(247)))));
            this.Size = new System.Drawing.Size(184, 60);
            this.ResumeLayout(false);

        }

        #endregion

        public System.Windows.Forms.Label lbl;
        private System.Windows.Forms.Label lblTips;
        private System.Windows.Forms.ImageList imageList1;


    }
}

最后的话

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

  • 7
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: WinForm是微软的一个桌面应用程序开发框架,其中包含了MessageBox控件,用于弹出消息框显示信息。但是默认的MessageBox只能显示固定的按钮和图标,无法满足个性化的需求。因此,我们可以自定义一个MessageBox,满足我们特定的需求。 为了实现自定义MessageBox,我们可以创建一个新的窗体,命名为CustomMessageBox。在该窗体中,我们可以自定义布局、样式和交互方式。 首先,我们需要定义一个静态的方法,例如Show方法,用于显示自定义MessageBox,并且该方法可以接受不同的参数以满足不同的需求。 在Show方法中,我们可以设置CustomMessageBox窗体的标题、文本、图标和按钮等属性。我们还可以根据需要自定义布局,例如添加更多的文本框、复选框或者其他控件。 另外,我们可以为CustomMessageBox窗体定义一些事件,例如按钮的点击事件,以便用户点击按钮后执行相应的操作。可以根据按钮的不同使用不同的事件响应,例如确认按钮可以执行特定的操作,取消按钮可以关闭CustomMessageBox窗口。 最后,在应用程序的代码中,可以通过调用CustomMessageBox的Show方法来显示自定义的消息框,传入相应的参数,使其满足我们的需求。 总的来说,通过自定义WinForm的MessageBox,我们可以更加灵活和个性化地显示消息框,满足不同的需求。这样用户在使用我们的应用程序时,将会有更好的用户体验。 ### 回答2: WinForm是一种用户界面开发工具,在.NET平台上使用C#编写窗体应用程序的工具。WinForm中提供了MessageBox控件,用于显示提示消息、询问消息及警告消息。但是我们也可以通过自定义MessageBox类来实现个性化的消息框。 要自定义MessageBox,我们可以创建一个继承自Form类的新窗体,然后在该窗体中添加各种控件,来实现我们想要的消息框效果。可以自定义消息文字、标题、图标、按钮等。 首先,我们可以设置窗体的样式,例如调整窗体的大小、位置、样式、背景色等。接着,我们可以添加一个Label控件来显示消息内容,并根据需要设置其字体、颜色、对齐方式等属性。 然后,我们可以添加一个PictureBox控件来显示图标,可以是默认的信息图标,也可以是自定义图标。可以根据消息类型来选择不同的图标,例如,信息类型可以使用Info图标,警告类型可以使用Warning图标,错误类型可以使用Error图标等。 接下来,我们可以添加多个按钮,并根据需要设置其样式、文本、事件等属性。例如,我们可以添加一个确定按钮,点击后关闭消息框,并返回一个确定结果给调用者;我们也可以添加一个取消按钮,点击后关闭消息框,并返回一个取消结果给调用者。 最后,在自定义MessageBox类中添加必要的属性和方法,例如,用于设置消息内容、图标类型、按钮样式等属性的方法,用于获取点击按钮结果的方法等。 总之,通过自定义MessageBox类,我们可以更加灵活地定制化消息框,使其符合我们的设计需求,并提供更好的用户体验。 ### 回答3: WinForm自定义MessageBox可以通过继承MessageBox类,并重写其相应方法来实现。以下是一种实现方式: 首先,新建一个名为CustomMessageBox的类,并继承自MessageBox类。 然后,在CustomMessageBox类中重写Show方法,该方法用于显示自定义的消息框。 在重写的Show方法中,可以通过创建一个自定义的窗体,来代替系统默认的MessageBox窗体。 在自定义的窗体中,可以添加自定义控件,例如Label用于显示消息内容,Button用于表示确定或取消等按钮。 可以通过修改窗体的样式、大小、位置等属性,使其与自己的需求相匹配。 添加事件处理方法,处理按钮的点击事件,以响应用户的操作。 最后,根据用户的操作结果,返回相应的DialogResult,以便调用方可以根据返回值进行相应的处理。 这样,我们就可以调用自定义的Show方法来显示我们定义的消息框了,例如: CustomMessageBox.Show("这是一个自定义的消息框。"); 通过以上步骤,我们可以实现一个自定义WinForm消息框,以满足我们特定的需求,如更改消息框的样式、增加额外的功能等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值