博客
关于我
(八十)c#Winform自定义控件-分割线标签-HZHControls
阅读量:410 次
发布时间:2019-03-06

本文共 2861 字,大约阅读时间需要 9 分钟。

NuGet包发布指南:自定义控件系列

作为一名开发者,经历了7年多的编程历程,我一直想打造一套独特而漂亮的自定义控件系列。于是,这一系列文章就诞生了。接下来,我将分享如何通过NuGet包轻松分发这些自定义控件的过程。


NuGet安装

安装该控件非常简单,只需执行以下命令即可:

Install-Package HZH_Controls

目录

  • 用处及效果
  • 准备工作
  • 开始
  • 代码实现
  • 最后的话

准备工作

对于Label控件的扩展,所需工作相对简单。主要任务是重绘划线即可。


开始

为了实现Split Label功能,我们首先创建一个继承自Label的类 UCSplitLabel

代码实现步骤如下:

using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Windows.Forms;using System.Drawing;using System.ComponentModel;namespace HZH_Controls.Controls{    public class UCSplitLabel : Label    {        private Color lineColor = LineColors.Light;        public Color LineColor        {            get { return lineColor; }            set            {                lineColor = value;                Invalidate();            }        }        private void ResetMaxSize()        {            using (var g = this.CreateGraphics())            {                var _width = Width;                var size = g.MeasureString(string.IsNullOrEmpty(Text) ? "A" : Text, Font);                if (MinimumSize.Height != (int)size.Height)                    MinimumSize = new Size(base.MinimumSize.Width, (int)size.Height);                if (MaximumSize.Height != (int)size.Height)                    MaximumSize = new Size(base.MaximumSize.Width, (int)size.Height);                this.Width = _width;            }        }        public UCSplitLabel()        {            if (ControlHelper.IsDesignMode())            {                Text = "分割线";                Font = new Font("微软雅黑", 8f);            }            this.AutoSize = false;            Padding = new Padding(20, 0, 0, 0);            MinimumSize = new System.Drawing.Size(150, 10);            PaddingChanged += UCSplitLabel_PaddingChanged;            this.Width = 200;        }        private void UCSplitLabel_PaddingChanged(object sender, EventArgs e)        {            if (Padding.Left < 20)            {                Padding = new Padding(20, Padding.Top, Padding.Right, Padding.Bottom);            }        }        protected override void OnPaint(PaintEventArgs e)        {            base.OnPaint(e);            var g = e.Graphics;            g.SetGDIHigh();            var size = g.MeasureString(Text, Font);            g.DrawLine(new Pen(new SolidBrush(lineColor)),                 new PointF(1, Padding.Top + (this.Height - Padding.Top - Padding.Bottom) / 2),                new PointF(Padding.Left - 2, Padding.Top + (this.Height - Padding.Top - Padding.Bottom) / 2));            g.DrawLine(new Pen(new SolidBrush(lineColor)),                 new PointF(Padding.Left + size.Width + 1, Padding.Top + (this.Height - Padding.Top - Padding.Bottom) / 2),                new PointF(Width - Padding.Right, Padding.Top + (this.Height - Padding.Top - Padding.Bottom) / 2));        }    }}

最后的话

如果你觉得这篇文章有价值,请支持一下,点击右上角的星号!欢迎在企鹅群 568015492 中来交流探讨。


希望这篇文章能为你的开发之路带来灵感!

转载地址:http://mdvkz.baihongyu.com/

你可能感兴趣的文章
ny540 奇怪的排序 简单题
查看>>
NYOJ -216 A problem is easy
查看>>
NYOJ 1066 CO-PRIME(数论)
查看>>
NYOJ 737:石子合并(一)(区间dp)
查看>>
nyoj 91 阶乘之和(贪心)
查看>>
nyoj------203三国志
查看>>
NYOJ-525 一道水题
查看>>
NYOJ127星际之门(一)
查看>>
nyoj58 最少步数
查看>>
N皇后问题
查看>>
N皇后问题
查看>>
n种方式教你用python读写excel等数据文件
查看>>
OAuth 2.0 MAC Tokens
查看>>
OAuth 及 移动端鉴权调研
查看>>
OAuth2 + Gateway统一认证一步步实现(公司项目能直接使用),密码模式&授权码模式
查看>>
OAuth2 Provider 项目常见问题解决方案
查看>>
OAuth2 vs JWT,到底怎么选?
查看>>
Vue.js 学习总结(14)—— Vue3 为什么推荐使用 ref 而不是 reactive
查看>>
oauth2-shiro 添加 redis 实现版本
查看>>
OAuth2.0_JWT令牌-生成令牌和校验令牌_Spring Security OAuth2.0认证授权---springcloud工作笔记148
查看>>