博客
关于我
(八十)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/

你可能感兴趣的文章
Opencv中KNN背景分割器
查看>>
OpenCV中基于已知相机方向的透视变形
查看>>
opencv保存图片路径包含中文乱码解决方案
查看>>
opencv图像分割2-GMM
查看>>
OpenCV(1)读写图像
查看>>
OpenCV:概念、历史、应用场景示例、核心模块、安装配置
查看>>
Openlayers图文版实战,vue项目从0到1做基础配置
查看>>
Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
查看>>
Openlayers高级交互(16/20):两个多边形的交集、差集、并集处理
查看>>
Openlayers高级交互(17/20):通过坐标显示多边形,计算出最大幅宽
查看>>
Openlayers高级交互(19/20): 地图上点击某处,列表中显示对应位置
查看>>
openlayers:圆孔相机根据卫星经度、纬度、高度、半径比例推算绘制地面的拍摄的区域
查看>>
OpenMCU(一):STM32F407 FreeRTOS移植
查看>>
OpenMCU(二):GD32E23xx FreeRTOS移植
查看>>
OpenMMLab | S4模型详解:应对长序列建模的有效方法
查看>>
OpenMMLab | 【全网首发】Llama 3 微调项目实践与教程(XTuner 版)
查看>>
OpenMMLab | 面向多样应用需求,书生·浦语2.5开源超轻量、高性能多种参数版本
查看>>
OpenPPL PPQ量化(4):计算图的切分和调度 源码剖析
查看>>
OpenPPL PPQ量化(5):执行引擎 源码剖析
查看>>
Openresty框架入门详解
查看>>