记录一次学习过程,参考来源于【朝夕教育Winform开发体验课】,感谢分享!
第一步:建立 WinForm 窗体应用工程,项目名称为“WinformControls”
data:image/s3,"s3://crabby-images/f10ff/f10ff4e85e3f746c859fe12b5a8aa821e0161688" alt=""
data:image/s3,"s3://crabby-images/4edf7/4edf76237f8d5aefa50cbe3a37ba4bca2f965e38" alt=""
第二步:建立项目文件夹“UControls”
data:image/s3,"s3://crabby-images/bdea3/bdea3dd0458a15d0d0d2856725605e920c6a872c" alt=""
data:image/s3,"s3://crabby-images/63ab8/63ab8689f6285109f41c27bf25ca2147d7ede385" alt=""
第三步:建立用户控件(Windows窗体)“USwitch”
data:image/s3,"s3://crabby-images/c0e9f/c0e9f1cc67041acac32d0d29d75913a48d072106" alt=""
data:image/s3,"s3://crabby-images/9b42c/9b42c327c3bd9ae17c104efa264d5993cc23f853" alt=""
拖动或到属性设置控件默认大小
data:image/s3,"s3://crabby-images/bb67e/bb67e32c73e46e6607883b49b8a6b140cd733f89" alt=""
第四步:右键或“F7”进入查看代码进行代码的编写
data:image/s3,"s3://crabby-images/069e9/069e9e20937a4f39a720babd5046fed060cf97d7" alt=""
第五步:控件样式标志设置
#region 控件样式标志设置
SetStyle(ControlStyles.AllPaintingInWmPaint,true);//如果为true,则控件忽略窗口消息WM_ERASEBKGND以减少闪烁
SetStyle(ControlStyles.OptimizedDoubleBuffer,true);//如果为true,则控件首先绘制到缓冲区而不是直接绘制到屏幕,这样可以减少闪烁
SetStyle(ControlStyles.ResizeRedraw,true);//如果为true,则控件在调整大小时进行重绘
SetStyle(ControlStyles.UserPaint,true);//如果为true,则会由控件而不是由操作系统来绘制控件自身
SetStyle(ControlStyles.Selectable,true);//如果为true,则控件可以接收焦点
SetStyle(ControlStyles.SupportsTransparentBackColor,true);//如果为true,则控件接受alpha组建数小于255个的Control.BlackColor来模拟透明度
#endregion
第六步:设置默认控件大小
#region 设置默认控件大小
this.Size = new Size(150,50);
#endregion
第七部:建立开关控件打开/关闭属性
//propfull 属性和支持字段的代码片段,注意两次tab插入“propfull”片段
#region 建立开关控件打开/关闭属性
////// 开关是否打开
/// private bool mChecked;
public bool Checked
{
get { return mChecked; }
set
{
mChecked = value;
Invalidate();//使控件的整个图面无效并导致重绘控件
}
}
////// 开关为true时的背景颜色
/// private Color trueColor = Color.Blue;
public Color TrueColor
{
get { return trueColor; }
set
{
trueColor = value;
Invalidate();//使控件的整个图面无效并导致重绘控件
}
}
////// 开关为false时的背景颜色
/// private Color falseColor = Color.Gray;
public Color FalseColor
{
get { return falseColor; }
set
{
falseColor = value;
Invalidate();//使控件的整个图面无效并导致重绘控件
}
}
#endregion
第八步:利用GDI+绘制控件外观
#region 利用GDI+绘制控件外观
////// 利用GDI+绘制控件外观
/// ///protected override void OnPaint(PaintEventArgs e)
{
Graphics g = e.Graphics;//封装一个GDI+绘图图面
g.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.AntiAlias;//获取或设置此 Graphics 的呈现质量
Color fillcolor = mChecked? trueColor : falseColor;//填充颜色
GraphicsPath path1 = new GraphicsPath();//绘图路径
int radius = 16;//设置圆弧半径 默认16
path1.AddArc(0, 0, radius, radius, 180f, 90f);//左上角圆弧
path1.AddArc(Width - radius - 1, 0, radius, radius, 270f, 90f);//右上角圆弧
path1.AddArc(Width - radius - 1, Height - radius - 1, radius, radius, 0, 90f);//右下角圆弧
path1.AddArc(0, Height - radius - 1, radius, radius, 90f, 90f);//左下角圆弧
g.FillPath(new SolidBrush(fillcolor), path1);//初始化新 SolidBrush 指定颜色的对象,对矩形进行填充
if (mChecked)
{
//右边画圆角正方形
GraphicsPath path2 = new GraphicsPath();
path2.AddArc(Width - Height - 1 + 2, 2, radius, radius, 180f, 90f);//左上角圆弧
path2.AddArc(Width - 1 - 2 - radius, 2, radius, radius, 270f, 90f);//右上角圆弧
path2.AddArc(Width - 1 - 2 - radius, Height -2 - radius -1, radius, radius, 0f, 90f);//右下角圆弧
path2.AddArc(Width - Height - 1 + 2, Height - 2 - radius - 1, radius, radius, 90f, 90f);//左下角圆弧
g.FillPath(Brushes.White, path2);//利用标准颜色画笔填充小正方形
g.DrawEllipse(new Pen(trueColor,2), new Rectangle(Width - Height + (Height - 4) / 4, (Height - 4) / 4, (Height - 4) / 2, (Height - 4) / 2));//画圆形
}
else
{
//左边画圆角正方形
GraphicsPath path2 = new GraphicsPath();
path2.AddArc(2, 2, radius, radius, 180f, 90f);//左上角圆弧
path2.AddArc(Height - 2 - radius, 2, radius, radius, 270f, 90f);//右上角圆弧
path2.AddArc(Height - 2 - radius, Height - 2 - radius - 1, radius, radius, 0f, 90f);//右下角圆弧
path2.AddArc(2, Height - 2 - radius - 1, radius, radius, 90f, 90f);//左下角圆弧
g.FillPath(Brushes.White, path2);//利用标准颜色画笔填充小正方形
g.DrawEllipse(new Pen(falseColor, 2), new Rectangle((Height - 4) / 4, (Height - 4) / 4, (Height - 4) / 2, (Height - 4) / 2));//画圆形
}
}
#endregion
这里摘抄一段https://learn.microsoft.com/GraphicsPath.AddArc 方法
GraphicsPath.AddArc 方法
AddArc(Int32, Int32, Int32, Int32, Single, Single)向当前图形追加一段椭圆弧。
C#复制
publicvoidAddArc (int x, int y, int width, int height, float startAngle, float sweepAngle);
参数x
Int32
矩形区域左上角的 X 坐标,该区域定义将要从中绘制弧线的椭圆。
y
Int32
矩形区域左上角的 Y 坐标,该区域定义将要从中绘制弧线的椭圆。
width
Int32
矩形区域的宽度,该区域定义将要从中绘制弧线的椭圆。
height
Int32
矩形区域的高度,该区域定义将要从中绘制弧线的椭圆。
startAngle
Single
弧线的起始角度,以度为单位从 X 轴顺时针测量。
sweepAngle
Single
startAngle 和弧线末尾之间的角度。
示例有关示例,请参见 AddArc(Rectangle, Single, Single)。
注解如果图中有上一条线或曲线,则会添加一条线,用于将上一段的端点连接到弧线的开头。
弧沿由指定矩形绑定的椭圆的外围进行跟踪。 弧的起始点是通过从椭圆的 x 轴 (以 0 度角度) 开始角度测量顺时针确定的。 终结点通过按扫描角度的度数从起点按顺时针测量来相似。 如果扫描角度大于 360 度或小于 -360 度,则弧线将分别被 360 度或 -360 度横扫。
**难点:利用GDI+绘制图形要理解清楚坐标的位置,理解清楚后思路就清晰了!!!
第九步:在form1绘制USwitch开关,并建立Click事件
data:image/s3,"s3://crabby-images/c565d/c565d9cf39e697595af21464ce774570a2b1f2c4" alt=""
data:image/s3,"s3://crabby-images/b65fb/b65fbbe16d53199bc42627e649771cef0b87c836" alt=""
private void uSwitch1_Click(object sender, EventArgs e)
{
uSwitch1.Checked = !uSwitch1.Checked;
}
展示:
data:image/s3,"s3://crabby-images/b4640/b464069b6741ce529ea0a2d5f37ce7b3626f679e" alt=""
data:image/s3,"s3://crabby-images/0a5b4/0a5b4c849aaffd3175af3ee5b380f31ede2f427a" alt=""
记录一次学习过程,参考来源于【朝夕教育Winform开发体验课】,感谢分享!
你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧
当前题目:记录[WinForm]自定义开关控件制作学习过程-创新互联
网址分享:http://scpingwu.com/article/ehpdh.html