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

进入智能手机时代以来,各种各样的APP大行其道,手机上面的APP有很多流行的元素,开关按钮个人非常喜欢,手机QQ、360卫士、金山毒霸等,都有很多开关控制一些操作,在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

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

[转]C#自定义开关按钮控件--附带第一个私活项目截图的更多相关文章

  1. WINFORM 自定义开关按钮控件-

    本文章转载:http://www.cnblogs.com/feiyangqingyun/archive/2013/06/15/3137597.html OK,大工告成,上图演示效果. 源码下载:htt ...

  2. (八)ASP.NET自定义用户控件(1)

    http://blog.csdn.net/laodao1/article/details/5897366 ASP.NET自定义控件组件开发 第一章:从一个简单的控件谈起 起始开发ASP.NET自定义控 ...

  3. Android自定义控件之自定义组合控件

    前言: 前两篇介绍了自定义控件的基础原理Android自定义控件之基本原理(一).自定义属性Android自定义控件之自定义属性(二).今天重点介绍一下如何通过自定义组合控件来提高布局的复用,降低开发 ...

  4. C# DataGridView自定义分页控件

    好些日子不仔细写C#代码了,现在主要是Java项目,C#.Net相关项目不多了,有点手生了,以下代码不足之处望各位提出建议和批评. 近日闲来无事想研究一下自定义控件,虽然之前也看过,那也仅限于皮毛,粗 ...

  5. 自定义圆形控件RoundImageView并认识一下attr.xml

    今天我们来讲一下有关自定义控件的问题,今天讲的这篇是从布局自定义开始的,难度不大,一看就明白,估计有的同学或者开发者看了说,这种方式多此一举,但是小编我不这么认为,多一种解决方式,就多一种举一反三的学 ...

  6. DuiLib 自定义识别控件

    遇到一个断点无法识别自定义的控件,运气比较好,一搜就搜出来了: 参考地址:http://www.bkjia.com/ASPjc/992050.html 主要是这个函数: CControlUI* CDi ...

  7. (九)ASP.NET自定义用户控件(2)

    http://www.cnblogs.com/SkySoot/archive/2012/09/04/2670678.html 用户控件 在 .NET 里,可以通过两种方式把自己的控件插入到 Web 窗 ...

  8. C# 自定义用户控件

    上篇:控件制作 本例是制作一个简单的自定义控件,然后用一个简单的测试程序,对于初学者来说,本例子比较简单,只能起到抛石引玉的效果.我也是在学习当中,今后会将自己所学的逐步写出来和大家交流共享. 第一步 ...

  9. 自定义圆形控件RoundImageView并认识一下attr

    昨天我们学习了自定义带图片和文字的ImageTextButton,非常简单,我承诺给大家要讲一下用自定义属性的方式学习真正的实现自定义控件,在布局文件中使用属性的方式就需要用到attr.xml这个文件 ...

随机推荐

  1. A Very Easy Triangle Counting Game

    题意:在圆上取n个点,相邻两个点之间连线,(注意,n和1相邻),然后所有点对(i ,i+2)相连,问能形成的不同的三角形有多少个? 思路:找规律 n=3,cnt=1; n=4,cnt=8; n=5 c ...

  2. linux c正则

    c 正则 --------------------------------------------------    标准的C和C++都不支持正则表达式,但有一些函数库可以辅助C/C++程序员完成这一 ...

  3. spring异常记录-----java.lang.NoClassDefFoundError: org/apache/commons/lang3/StringUtils

    今天在练习怎样SSH中进行单元測试的时候出现下列异常: SEVERE: Exception starting filter Struts2 java.lang.NoClassDefFoundError ...

  4. django url调度

    Django的url配置相同遵循着DRY(dont repeat yourself)的规则.下面都是官方文档的样例: 首先介绍的是Django怎样处理http的请求: 1.在setting里定义ROO ...

  5. NET Core 中的依赖注入

    NET Core 中的依赖注入 [共7篇] 一.控制反转(IoC) ASP.NET Core在启动以及后续针对每个请求的处理过程中的各个环节都需要相应的组件提供相应的服务,为了方便对这些组件进行定制, ...

  6. Free Mind » Blog Archive » Yakuake + dtach vs Screen + urxvt

    Free Mind » Blog Archive » Yakuake + dtach vs Screen + urxvt Yakuake + dtach vs Screen + urxvt

  7. BI中事实表和维度表的定义

    一个典型的样例是,把逻辑业务比作一个立方体,产品维.时间维.地点维分别作为不同的坐标轴,而坐标轴的交点就是一个详细的事实.也就是说事实表是多个维度表的一个交点.而维度表是分析事实的一个窗体. 首先介绍 ...

  8. syslog-ng 3.4.3 发布,强烈建议升级 - 开源中国社区

    syslog-ng 3.4.3 发布,强烈建议升级 - 开源中国社区 syslog-ng 3.4.3 发布,强烈建议升级    oschina 发布于: 2013年08月16日 (2评)    分享到 ...

  9. POJ 3340 &amp; HDU 2410 Barbara Bennett&#39;s Wild Numbers(数学)

    题目链接: PKU:http://poj.org/problem?id=3340 HDU:http://acm.hdu.edu.cn/showproblem.php?pid=2410 Descript ...

  10. RGB與CIELAB色彩空間轉換

    原地址:http://cg2010studio.wordpress.com/2012/10/02/rgb與cielab色彩空間轉換/ 之前有研究CIE L*a*b*色彩空間,現在想更進一步探討RGB色 ...