C#自定义开关按钮控件--附带第一个私活项目截图

简介: 原文 http://www.cnblogs.com/feiyangqingyun/archive/2013/06/15/3137597.html 进入智能手机时代以来,各种各样的APP大行其道,手机上面的APP有很多流行的元素,开关按钮个人非常喜欢,手机QQ、360卫士、金山毒霸等,都有很...

原文 http://www.cnblogs.com/feiyangqingyun/archive/2013/06/15/3137597.html

进入智能手机时代以来,各种各样的APP大行其道,手机上面的APP有很多流行的元素,开关按钮个人非常喜欢,手机QQ360卫士、金山毒霸等,都有很多开关控制一些操作,在WINFORM项目上,如果将CheckBox也改为开关按钮,估计也会为项目增添不少新鲜感,上个月接了个私活,金额虽然只有3K,与硬件通信方面的,本人在这块做了三年,所以做起来还是比较顺手,前后用下班时间,大概花了3个星期(包含测试一个多星期)搞定,里面就重写了部分控件,以适应项目需要。

沿袭之前的做法,本人还是喜欢直接PS好图片后,用drawimage方法将图片绘制到用户控件上,启用双缓冲和背景透明,有些人说PS一张精美的图片也不是很容易,需要专业的,这里提供一个好方法,让你也可以获取到这些图片,其实大部分的APP都可以用解压软件打开,拓展名改为.zip即可,解压出来一般里面都含有绝大部分的图片,发现绝大部分的APP都喜欢用图片作为背景来展示一些效果,而不是原原本本的用代码一点点绘制。腾讯就是腾讯啊,大公司!人家的美工MM设计的图片那真的没得话说,绝对一流,手机QQ每次升级一个版本,都会下过来将里面的精美图片图标之类的提取出来,以便项目使用,(这不会算是盗版吧!)好了,开始正文吧!

第一步:先准备开关按钮要使用到的背景图片,一般就两张,一张是开的,一张是关的,也可以说是开启和关闭,如下图:

  

然后将这些图片都作为资源文件添加到项目中。

 

第二步:新建用户控件

在构造函数中设置双缓冲和背景透明以及控件大小。 

?
this .SetStyle(ControlStyles.AllPaintingInWmPaint, true );
 
            this .SetStyle(ControlStyles.DoubleBuffer, true );
 
            this .SetStyle(ControlStyles.ResizeRedraw, true );
 
            this .SetStyle(ControlStyles.Selectable, true );
 
            this .SetStyle(ControlStyles.SupportsTransparentBackColor, true );
 
            this .SetStyle(ControlStyles.UserPaint, true );
 
            this .BackColor = Color.Transparent;
 
 
 
            this .Cursor = Cursors.Hand;
 
            this .Size = new Size(87, 27);

第三步:定义一个公共属性,这样的话外部就可以访问当前选中状态,这里也命名为Checked

 

?
bool isCheck = false ;
 
  
 
         /// <summary>
 
         /// 是否选中
 
         /// </summary>
 
         public bool Checked
 
         {
 
             set { isCheck = value; this .Invalidate(); }
 
             get { return isCheck; }
 
         }

 

 

第四步:根据当前是否选中条件分别绘制图片,在onPaint事件中

这里为了增加多种开关样式,还增加了CheckStyleX属性。

 

?
protected override void OnPaint(PaintEventArgs e)
 
         {           
 
             Bitmap bitMapOn = null ;
 
             Bitmap bitMapOff = null ;
 
  
 
             if (checkStyle == CheckStyle.style1)
 
             {
 
                 bitMapOn = global::myAlarmSystem.Properties.Resources.btncheckon1;
 
                 bitMapOff = global::myAlarmSystem.Properties.Resources.btncheckoff1;               
 
             }
 
             else if (checkStyle == CheckStyle.style2)
 
             {
 
                 bitMapOn = global::myAlarmSystem.Properties.Resources.btncheckon2;
 
                 bitMapOff = global::myAlarmSystem.Properties.Resources.btncheckoff2;               
 
             }
 
             else if (checkStyle == CheckStyle.style3)
 
             {
 
                 bitMapOn = global::myAlarmSystem.Properties.Resources.btncheckon3;
 
                 bitMapOff = global::myAlarmSystem.Properties.Resources.btncheckoff3;               
 
             }
 
             else if (checkStyle == CheckStyle.style4)
 
             {
 
                 bitMapOn = global::myAlarmSystem.Properties.Resources.btncheckon4;
 
                 bitMapOff = global::myAlarmSystem.Properties.Resources.btncheckoff4;               
 
             }
 
             else if (checkStyle == CheckStyle.style5)
 
             {
 
                 bitMapOn = global::myAlarmSystem.Properties.Resources.btncheckon5;
 
                 bitMapOff = global::myAlarmSystem.Properties.Resources.btncheckoff5;               
 
             }
 
             else if (checkStyle == CheckStyle.style6)
 
             {
 
                 bitMapOn = global::myAlarmSystem.Properties.Resources.btncheckon6;
 
                 bitMapOff = global::myAlarmSystem.Properties.Resources.btncheckoff6;
 
             }
 
             
 
             Graphics g = e.Graphics;
 
             Rectangle rec = new Rectangle(0, 0, this .Size.Width, this .Size.Height);
 
  
 
             if (isCheck)
 
             {
 
                 g.DrawImage(bitMapOn, rec);
 
             }
 
             else
 
             {
 
                 g.DrawImage(bitMapOff, rec);
 
             }
 
         }

 

 到此是不是完成了呢,其实不是,因为鼠标在控件上面单击的时候,还需要改变当前的背景图片,所以必须在Click事件中写

?
private void myButtonCheck_Click( object sender, EventArgs e)
 
         {
 
             isCheck = !isCheck;
 
             this .Invalidate();
 
         }

 OK,大工告成,上图演示效果。

  

源码下载:http://files.cnblogs.com/feiyangqingyun/myButtonCheckTest.zip

附上项目截图,欢迎提出批评改进建议!谢谢!

 

目录
相关文章
|
2月前
|
SQL 开发框架 .NET
C#一分钟浅谈:数据绑定与数据源控件
在Web开发中,数据绑定和数据源控件是实现动态网页的关键技术。本文从基础概念入手,详细讲解数据绑定的原理及其在ASP.NET中的应用,并介绍常见数据绑定方式:手动绑定和自动绑定。接着,文章重点介绍了ASP.NET中的数据源控件,如`SqlDataSource`、`ObjectDataSource`、`XmlDataSource`和`LinqDataSource`,并通过具体示例演示如何使用`SqlDataSource`和`GridView`进行数据绑定。最后,还列举了一些常见问题及其解决办法,帮助读者更好地理解和应用这些技术。
82 4
|
4月前
|
C#
|
4月前
|
C# 开发者 Windows
在VB.NET项目中使用C#编写的代码
在VB.NET项目中使用C#编写的代码
62 0
|
1月前
|
开发框架 网络协议 .NET
C#/.NET/.NET Core优秀项目和框架2024年10月简报
C#/.NET/.NET Core优秀项目和框架2024年10月简报
|
1月前
|
C# Python
使用wxpython开发跨平台桌面应用,对wxpython控件实现类似C#扩展函数处理的探究
【10月更文挑战第30天】使用 `wxPython` 开发跨平台桌面应用时,可以通过创建辅助类来模拟 C# 扩展函数的功能。具体步骤包括:1. 创建辅助类 `WxWidgetHelpers`;2. 在该类中定义静态方法,如 `set_button_color`;3. 在应用中调用这些方法。这种方法提高了代码的可读性和可维护性,无需修改 `wxPython` 库即可为控件添加自定义功能。但需要注意显式调用方法和避免命名冲突。
|
2月前
|
开发框架 前端开发 API
C#/.NET/.NET Core优秀项目和框架2024年9月简报
C#/.NET/.NET Core优秀项目和框架2024年9月简报
|
2月前
|
边缘计算 开发框架 人工智能
C#/.NET/.NET Core优秀项目和框架2024年8月简报
C#/.NET/.NET Core优秀项目和框架2024年8月简报
|
2月前
|
API C# 开发工具
使用C#实现客厅电灯的开关
使用C#实现客厅电灯的开关
17 0
|
4月前
|
C# Windows
C# 创建 Windows Service 项目
C# 创建 Windows Service 项目
38 1
|
4月前
|
开发框架 .NET 编译器
总结一下 C# 如何自定义特性 Attribute 并进行应用
总结一下 C# 如何自定义特性 Attribute 并进行应用
114 1