WPF中的触发器(Trigger)

    这节来讲一下WPF中的触发器——Trigger。触发器,是指在既定条件或者特殊场景下被触发,从而去执行一个操作。在WPF中,触发器可以分为以下几类:基本触发器(Trigger);事件触发器(EventTrigger);数据触发器(DataTrigger);多条件触发器(MultiTrigger,MultiDataTrigger)。下面我们来通过代码一一了解。

1

基本触发器(Trigger)

    请看如下代码:

a663a4f412f013d690bffc5dedeeb3cd.png

    我为Slider控件的样式设置了一个基本触发器,需要关注的是Trigger的Property和Value,Property设置要根据Slider控件的哪个属性触发,Value设置当属性为何值时触发,在Setter中也有Property和Value,此处则是设置触发时要执行的操作,上述触发器的作用时当Slider的Value为1时,设置其背景为纯绿色:运行效果如下:

1c83b71cd41064581afccc107e9cbc08.png

    设置了两个Slider作对比,当Slider值为1时,触发器被触发,背景色也进行了对应修改。

    当我们想监视多个属性的值来控制触发器的执行,可以使用MultiTrigger,请看如下代码:

062de244c6040f095209465202169374.png

    多属性触发器,需要将多个触发条件写在MultiTrigger.Conditions中,其它用法都是一致的,上述代码中,当Slider的Value为1并且样式为垂直的时候,触发器才会触发,运行结果如下:

793c2cb2582db5420f9c70c3adce70e3.png

2

事件触发器(EventTrigger)

    请先看如下代码:

a1b907abc5aeb363653d6d3d976169f2.png

    事件触发器有些不同的是,它触发执行的是一段动画,并且是通过RoutedEvent来执行要监视的事件,上述代码中,当Button的MouseEnter事件被触发时,其前景色会逐渐变成紫色,请看运行结果:

31990bf24ca2b39eb897ed749d27fd94.png

    关于WPF动画的相关知识,会在下节讲述,请关注后续文章。

3

数据触发器(DataTrigger)

    请看如下代码:

773bccaf0150ae6312f7df614ae0e76a.png

    我们还是以修改Slider背景色为例子,数据触发器使用Binding来设置要监视的对象,其结果跟示例1一致,此处不再展示,除了绑定一个数据,也可以通过MultiDataTrigger来绑定多个数据,当多个数据同时满足条件时才触发:

d4f9b33a3fa3f5033f65d4f030929f3f.png

    多数据触发器,需要将多个触发条件写在MultiDataTrigger.Conditions中,其它用法都是一致的,上述代码中,当Slider的Value为1并且最大值为1的时候,触发器才会触发,运行结果如下:

40f7cc81cce1d1df82de4eb04dd6af6a.png

本节到此结束...

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值