上一篇文章中谈到了BulletDecorator控件,就是为自定义CheckBox控件的模板做准备,因为CheckBox需要比较严格的布局,正好,BulletDecorator控件就合适了,该控件的布局是有项目列表,排列起来好办很多了。
 
第一步,先建立一项资源,就是控件的聚焦样式,即当你在窗体中不断按Tab键使控件获取焦点时的样式,后面要用到。
  1. <!--当控件获得键盘焦点时的样式-->
  2. <Style x:Key="FocusStyle">
  3. <Setter Property="Control.Template">
  4. <Setter.Value>
  5. <ControlTemplate>
  6. <Rectangle Stroke="Red" StrokeThickness="1"/>
  7. </ControlTemplate>
  8. </Setter.Value>
  9. </Setter>
  10. </Style>
 

第二步,写好CheckBox的样式。

  1. <!--
  2. CheckBox的样式
  3. -->
  4. <Style TargetType="{x:Type CheckBox}">
  5. <Setter Property="OverridesDefaultStyle" Value="True"/>
  6. <Setter Property="FocusVisualStyle" Value="{StaticResource FocusStyle}"/>
  7. <Setter Property="SnapsToDevicePixels" Value="True"/>
  8. <Setter Property="Foreground" Value="White"/>
  9. <Setter Property="FontSize" Value="16"/>
  10. <Setter Property="Template">
  11. <Setter.Value>
  12. <ControlTemplate TargetType="{x:Type CheckBox}">
  13. <BulletDecorator FlowDirection="LeftToRight" VerticalAlignment="Center">
  14. <BulletDecorator.Bullet>
  15. <Border x:Name="bd"
  16. BorderThickness="1"
  17. BorderBrush="Red"
  18. MinHeight="15"
  19. MinWidth="15"
  20. VerticalAlignment="Center">
  21. <Border.Background>
  22. <LinearGradientBrush StartPoint="0,0"
  23. EndPoint="1,1">
  24. <GradientStop Color="LightGray" Offset="0.2"/>
  25. <GradientStop Color="White" Offset="1"/>
  26. </LinearGradientBrush>
  27. </Border.Background>
  28. <Path x:Name="cp" Width="12" Height="12"
  29. Stroke="Blue"
  30. StrokeThickness="3"/>
  31. </Border>
  32. </BulletDecorator.Bullet>
  33. <ContentPresenter Margin="2,0"/>
  34. </BulletDecorator>
  35. <!--
  36. 控件触发器
  37. -->
  38. <ControlTemplate.Triggers>
  39. <Trigger Property="IsChecked" Value="True">
  40. <!-- 画上一个勾 -->
  41. <Setter TargetName="cp" Property="Data"
  42. Value="M 0,6 L 6,12 12,0"/>
  43. <Setter Property="Foreground" Value="LightGreen"/>
  44. </Trigger>
  45. <Trigger Property="IsMouseOver" Value="True">
  46. <Setter TargetName="bd" Property="Background">
  47. <Setter.Value>
  48. <LinearGradientBrush StartPoint="0,0" EndPoint="1,1">
  49. <GradientStop Color="Orange" Offset="0.12"/>
  50. <GradientStop Color="Yellow" Offset="0.92"/>
  51. </LinearGradientBrush>
  52. </Setter.Value>
  53. </Setter>
  54. </Trigger>
  55. </ControlTemplate.Triggers>
  56. </ControlTemplate>
  57. </Setter.Value>
  58. </Setter>
  59. </Style>
第三步,把窗体默认的Grid控件去掉,为了更好地布局,应使用StatcPanel控件。
  1. <StackPanel Orientation="Vertical" Margin="20,20,20,20">
  2. <CheckBox Content="苹果"/>
  3. <CheckBox Content="鸡蛋"/>
  4. <CheckBox Content="白菜"/>
  5. <CheckBox Content="萝卜"/>
  6. <CheckBox Content="豆浆"/>
  7. <CheckBox Content="咸菜"/>
  8. <CheckBox Content="炒饭"/>
  9. <CheckBox Content="烧鸭饭"/>
  10. <CheckBox Content="叉烧饭"/>
  11. </StackPanel>
好,完事,现在来看看效果吧。

当项目被选中后,字体自动变为绿色,请参照上面的XAML代码。

怎么样,漂亮不?

继续聊WPF——自定义CheckBox控件外观的更多相关文章

  1. WPF自定义分页控件,样式自定义,简单易用

    WPF自定义分页控件 做了许久伸手党,终于有机会贡献一波,搜索一下WPF分页控件,还是多,但是不太通用,主要就是样式问题,这个WPF很好解决,还有一个就是分页控件嘛,只关心几个数字的变动就行了,把页码 ...

  2. 浅尝辄止WPF自定义用户控件(实现颜色调制器)

    主要利用用户控件实现一个自定义的颜色调制控件,实现一个小小的功能,具体实现界面如下. 首先自己新建一个wpf的用户控件类,我就放在我的wpf项目的一个文件夹下面,因为是一个很小的东西,所以就没有用mv ...

  3. WPF 自定义Button控件及样式

    这次通过最近做的小例子说明一下自定义Button控件和样式. 实现的效果为:

  4. IOS开发自定义CheckBox控件

    IOS本身没有系统的CheckBox组件,但是实际开发中会经常用到,所以专门写了一个CheckBox控件,直接上代码 效果图: UICheckBoxButton.h文件如下: #import #imp ...

  5. WPF 自定义UI控件学习

    最近项目中运用到了WPF处理三维软件,在C/S结构中WPF做UI还是有很多优越性,简单的学了一点WPF知识,成功的完成项目目标.项目过度阶段对于WPF的一些基本特点有了进一步了解 .至此花费一点时间研 ...

  6. wpf 自定义RadioButton控件样式

    实现的效果为: 我感觉来自定义RadioButton样式和定义button空间的样式差不多,只是类型不同而已. 接下来分析一下样式代码: <!--自定义单选按钮样式-->        & ...

  7. WPF 自定义TabControl控件样式

    一.前言 程序中经常会用到TabControl控件,默认的控件样式很普通.而且样式或功能不一定符合我们的要求.比如:我们需要TabControl的标题能够居中.或平均分布:或者我们希望TabContr ...

  8. WPF自定义用户控件不显示

    1,Themes\Generic.xaml最好不要更名 "Generic.xaml"这个名称并非偶然通过上面的叙述,你可能会有冲动将Generic.xaml中的Style代码剪切出 ...

  9. WPF自定义动画控件 风机

      一:创建WPF项目 二:在项目下添加文件Themes,在此文件下添加新项 ”资源词典“取名为 Generic.xaml  注意大小写,之前遇到因为大小写不对应,导致出错的情况Generic.xam ...

随机推荐

  1. JavaScript的代码库

    JavaScript的代码库 本文主要是汇集了一些JavaScript中一些经常使用代码.方便以后查找和复用. javascript框架: <script language="java ...

  2. hdu 1010 Tempter of the Bone (奇偶性剪枝)

    题意:有一副二维地图'S'为起点,'D'为终点,'.'是可以行走的,'X'是不能行走的.问能否只走T步从S走到D? 题解:最容易想到的就是DFS暴力搜索,,但是会超时...=_=... 所以,,要有其 ...

  3. double型转换成string型

    double型转换成string型 题目描写叙述: 如有一个函数.其可接受一个long double參数,并将參数转换为字符串.结果字符串应保留两位小数,比如,浮点值123.45678应该生成&quo ...

  4. ASP.NET MVC 客户端验证失败后表单仍然提交问题

    客户端验证失败后表单仍然提交问题!导致页面刷新,辛辛苦苦输入的内容荡然无存. 多么奇怪的问题.按道理,验证失败,就应该显示各种错误信息,不会提交表单才对.而现在,错误信息正常显示,但页面却刷新了一遍. ...

  5. C++_homework_StackSort

    顾名思义(?)类似于单调栈?维护一个单调递减的栈.一旦准备入栈的元素大于栈顶元素,栈一直弹出直到准备入栈的元素小于等于栈顶元素,弹出的元素压入另一个tmp栈中. #include <iostre ...

  6. iOS地图集成示例:百度地图POI检索

    一.集成百度地图(傻瓜教程,以网站说明文档为准,此处罗列几项主要步骤) 1.登录  http://lbsyun.baidu.com  百度地图开发者平台,获取SDK和集成文档. 2.百度地图可以提供的 ...

  7. 利用存储过程插入50W+数据

    转自:https://www.aliyun.com/jiaocheng/1396184.html 首先,建立部门表和员工表: 部门表:   create table dept(   id int un ...

  8. 84. ExtJS下页面显示中文乱码问题

    转自:https://blog.csdn.net/wenminhao/article/details/51198981 最近在学校extjs是,使用js脚本显示中文在html页面中时,中午出现了乱码的 ...

  9. 原生JS---8

    原生js学习笔记8——Ajax基础   什么是Ajax 不刷新页面的情况下从服务器获取.提交数据的一种数据交互方式. Ajax使用步骤 1.创建Ajax对象 var httpRequest = new ...

  10. [Apple开发者帐户帮助]二、管理你的团队(5)转移帐户持有人角色

    组织团队的帐户持有人可以将帐户持有人角色转移给团队中的其他人.如果您是个人注册并需要将您的会员资格转移给其他人,请与我们联系. 所需角色:帐户持有人. 转移Apple Developer Progra ...