最近工作需要,需要重绘RaidButton控件,具体想要达成的的效果是这样的:

当点击按钮任意一个地方的时候,按钮的背景改变。

于是我是这样对控件模板进行修改的:

<Style x:Key="raidstyle" TargetType="RadioButton">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="RadioButton">
<Grid>
<Border x:Name="bord1"
Width="320"
Height="138"
BorderBrush="#6B778D"
BorderThickness="1"
CornerRadius="8" />
<Border x:Name="bord"
<Grid>
<StackPanel Margin="0,33,0,0">
<Grid
Margin="0,-10,0,10"
HorizontalAlignment="Center"
VerticalAlignment="Center">
<Ellipse x:Name="ell1"
Width="33"
Height="33"
StrokeThickness="3"
Stroke="White" />
<Ellipse x:Name="ell2"
Width="13"
Height="13"
StrokeThickness="1"
Stroke="#2196F3"
Fill="#2196F3"
Visibility="Collapsed" />
</Grid>
<ContentPresenter
Content="{TemplateBinding Content}"
HorizontalAlignment="{TemplateBinding HorizontalAlignment}"
VerticalAlignment="{TemplateBinding VerticalAlignment}" />
</StackPanel>
</Grid>
</Border>
</Grid> <ControlTemplate.Triggers>
<Trigger Property="IsChecked" Value="True">
<Setter TargetName="bord1" Property="Background" Value="#FF919191" />
<Setter TargetName="bord1" Property="Opacity" Value="0.1" />
<Setter TargetName="ell1" Property="Stroke" Value="#2196F3" />
<Setter TargetName="ell2" Property="Visibility" Value="Visible" />
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>

但是这样就出现了问题,实际出来的作用并不是点击按钮任何一个地方就能够改变背景颜色

而是只能点击 字 所在的区域才能够出发这个触发器

于是对其他人进行了请教后,发现

需要将按钮的 “Border”  的“Background” ,"BorderBrush",“BorderThickness”

三个属性绑定到对应的按钮上的模板本身上才可以

于是对代码进行了修改

<Style x:Key="raidstyle" TargetType="RadioButton">
<Setter Property="HorizontalAlignment" Value="Center" />
<Setter Property="VerticalAlignment" Value="Center" />
<Setter Property="Background" Value="Transparent" />
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="RadioButton">
<Grid>
<Border x:Name="bord1"
Width="320"
Height="138"
BorderBrush="#6B778D"
BorderThickness="1"
CornerRadius="8" />
<Border x:Name="bord"
Background="{TemplateBinding Background}"
BorderBrush="{TemplateBinding BorderBrush}"
BorderThickness="{TemplateBinding BorderThickness}"> <Grid>
<StackPanel Margin="0,33,0,0">
<Grid
Margin="0,-10,0,10"
HorizontalAlignment="Center"
VerticalAlignment="Center">
<Ellipse x:Name="ell1"
Width="33"
Height="33"
StrokeThickness="3"
Stroke="White" />
<Ellipse x:Name="ell2"
Width="13"
Height="13"
StrokeThickness="1"
Stroke="#2196F3"
Fill="#2196F3"
Visibility="Collapsed" />
</Grid>
<ContentPresenter
Content="{TemplateBinding Content}"
HorizontalAlignment="{TemplateBinding HorizontalAlignment}"
VerticalAlignment="{TemplateBinding VerticalAlignment}" />
</StackPanel>
</Grid>
</Border>
</Grid> <ControlTemplate.Triggers>
<Trigger Property="IsChecked" Value="True">
<Setter TargetName="bord1" Property="Background" Value="#FF919191" />
<Setter TargetName="bord1" Property="Opacity" Value="0.1" />
<Setter TargetName="ell1" Property="Stroke" Value="#2196F3" />
<Setter TargetName="ell2" Property="Visibility" Value="Visible" />
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>

以上重新修改后就能够达到我所需要的要求:

点击按钮任何一个区域 ,就能够出发按钮的事件

从这次的例子可以知道,自己还是有许多东西需要学习和总结的。

加油!

干杯!*~( ̄▽ ̄)~[] []~( ̄▽ ̄)~*

【WPF】 问题总结-RaidButton修改样式模板后作用区域的变化的更多相关文章

  1. wpf slider进度条的样式模板,带有进度颜色显示

    效果图: 仅仅需在前台加上这段代码就可以: <UserControl.Resources> <!--笔刷--> <LinearGradientBrush x:Key=&q ...

  2. arcgis server10.7修改打印模板后前台调用不生效

    在10.5.1及之前的版本中,如果更改打印地图模板,如字体设置,那么直接修改[ArcGIS for Server 安装目录]/Templates/ExportWebMapTemplates下的mxd的 ...

  3. WPF自定义控件(二)の重写原生控件样式模板

    话外篇: 要写一个圆形控件,用Clip,重写模板,去除样式引用圆形图片可以有这三种方式. 开发过程中,我们有时候用WPF原生的控件就能实现自己的需求,但是样式.风格并不能满足我们的需求,那么我们该怎么 ...

  4. 【WPF】MVVM动态修改Bingding的另一种思路——用Style样式

    问题场景: 界面上有个ListBox控件,它的内容Item绑定了一个列表,即 ItemsSource =”{Binding StudentList}”.这个StudentList列表在该界面View对 ...

  5. dede修改templets模板文件夹后,出现“无法在这个位置找到: ”错误的解决办法

    修改templets模板文件夹的方法: 首先找到系统配置文件common.inc.php,此文件存放在Include目录下,打开common.inc.php来修改默认模板目录templets, 查找: ...

  6. WPF XAML 资源样式模板属性存放位置

    WPF的XAML 资源申明 类似HTML. 整体来说分3种1.行类资源样式属性 1.1 行内属性 <Button Content="按钮" Foreground=" ...

  7. vue加scoped后无法修改样式(无法修改element UI 样式)

    有的时候element提供的默认的样式不能满足项目的需要,就需要我们队标签的样式进行修改,但是发现修改的样式不起作用 第一种方法 原因:scoped 解决方法:去掉scoped 注意:此时该样式会污染 ...

  8. [zz] 基于国家标准的 EndNote 输出样式模板

    基于国家标准的 EndNote 输出样式模板 https://cnzhx.net/blog/endnote-output-style-cnzhx/ 发表于 2013-05-26 作者 Haoxian ...

  9. [转]基于国家标准的 EndNote 输出样式模板 ----直接用endnote导入到word,不用自己一个个改参考文献了

    EndNote 相当于一个数据库,将添加/导入的文献存档.需要引用文献的时候就从中选择一个插入到文档中,EndNote 会自动给你编号.在文档末尾建立相应的参考文献列表.但是各种杂志.单位要求的文献著 ...

随机推荐

  1. charles功能(五)屏蔽web网页的抓包信息(proxy)

    应用场景:屏蔽web网页的抓包信息 proxy-->windows proxy(前面没有对勾,就不会抓到 PC浏览器的包) proxy-->macOS proxy(mac电脑) 最终效果

  2. 后端程序员必备的 Linux 基础知识

    1. 从认识操作系统开始 正式开始 Linux 之前,简单花一点点篇幅科普一下操作系统相关的内容. 1.1. 操作系统简介 我通过以下四点介绍什么是操作系统: 操作系统(Operating Syste ...

  3. Python爬虫学习遇到的问题

    老猿在学习Python中爬虫知识时遇到了如下问题: 爬取网页内容后写入文件报错UnicodeEncodeError: 'gbk' codec can't encode的问题解决方案 urllib.re ...

  4. HTML基础之标签

    HTML初识 HTML(Hpyer Text Markup Language的缩写)译为"超文本标签语言",用来描述网页的一种语言.所谓超文本,因为它可以加入图片.声音.动画.多媒 ...

  5. go学习第四天

    昨天通宵加班,暂停了一天学习,今天再偷懒下,学习半个小时

  6. EF 查询外键对应的实例

    EF 查询外键对应的实例   1. 查询时易遇到的情况: 能查询到外键值,但对应的外键实例为null. 解决方法: (1) 使用EF的include // 我的应用如下 // SampleResult ...

  7. 单次期望 O(1) 的RMQ

    膜万弘,太强了!!! 刚刚变态的zjjws想要将一个需要 \(RMQ\) 问题的时间和空间都卡成 \(O(n)\) ,就在可怜的蒟蒻 Point_King 一筹莫展之时万弘他出现了,给予了本蒟蒻光明和 ...

  8. NOI Online #1 入门组 魔法

    全网都是矩阵快速幂,我只会倍增DP 其实这题与 AcWing 345. 牛站 还是比较像的,那题可以矩阵快速幂 / 倍增,这题也行. 先 \(Floyd\) 预处理两点之间不用魔法最短距离 \(d_{ ...

  9. 转:什么是Shingling算法

    shingling算法用于计算两个文档的相似度,例如,用于网页去重.维基百科对w-shingling的定义如下: In natural language processing a w-shinglin ...

  10. MySQL技术内幕InnoDB存储引擎(七)——事务

    什么是数据库的事务? 事务是访问并更新数据库中各种数据的一个程序执行单元.事务也是数据库区别于文件系统的一个重要特性. 事务需要满足的特性 1.原子性 原子性就是指数据库中的一个完整的事务是不可分割的 ...