WPF触发器的使用
-
WPF中定义了五个触发器类:Trigger、MultiTrigger、DataTrigger、multiDataTrigger、EventTrigger。下面我来介绍一下怎么使用这几个触发器的使用方法。
Trriger(单一条件的触发器):
<Page x:Class="StyleTest.Trigger"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
mc:Ignorable="d"
d:DesignHeight="300" d:DesignWidth="300"
Title="Trigger">
<Page.Resources>
<Style x:Key="smallText">
<Setter Property="Control.Foreground" Value="blue"/>
<Setter Property="Control.FontSize" Value="20"/>
<Setter Property="Control.FontFamily" Value="Times new Roman"/>
<Setter Property="Control.FontWeight" Value="Bold"/>
<Style.Triggers> <!--这里使用了触发器,当鼠标移过控件的时候,控件的风格发生改变-->
<Trigger Property="Control.IsMouseOver" Value="True">
<Setter Property="Control.Foreground" Value="red"/>
<Setter Property="Control.FontSize" Value="24"/>
</Trigger>
</Style.Triggers>
</Style>
</Page.Resources>
<StackPanel>
<TextBlock Style="{StaticResource smallText}">旅望因高尽</TextBlock>
<TextBlock Style="{StaticResource smallText}">乡心遇物悲</TextBlock>
<TextBlock Style="{StaticResource smallText}">故林归宿处</TextBlock>
<TextBlock Style="{StaticResource smallText}">一叶下梧桐</TextBlock>
<Button Style="{StaticResource smallText}">旅思</Button>
</StackPanel>
</Page>MultiTrigger(多条件的触发器):
<Page x:Class="StyleTest.Multitrigger"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
mc:Ignorable="d"
d:DesignHeight="300" d:DesignWidth="300"
Title="Multitrigger">
<Page.Resources>
<Style x:Key="smallText">
<Setter Property="Control.Foreground" Value="blue"/>
<Setter Property="Control.FontSize" Value="20"/>
<Setter Property="Control.FontFamily" Value="Times New Roman"/>
<Setter Property="Control.FontWeight" Value="Bold"/>
<Style.Triggers>
<Trigger Property="Control.IsMouseOver" Value="True">
<Setter Property="Control.Foreground" Value="red"/>
</Trigger>
<MultiTrigger> <!--定义触发器-->
<MultiTrigger.Conditions>
<Condition Property="Control.IsMouseOver" Value="True"/> <!--通过Condition定义触发条件-->
<Condition Property="Button.IsPressed" Value="True"/> <!--通过Condition定义触发条件-->
</MultiTrigger.Conditions>
<Setter Property="Control.Foreground" Value="gray"/>
<Setter Property="Control.FontStyle" Value="Italic"/>
</MultiTrigger>
</Style.Triggers>
</Style>
</Page.Resources>
<StackPanel>
<Button Style="{StaticResource smallText}">床前明月光</Button>
<Button Style="{StaticResource smallText}">疑是地上霜</Button>
<Button Style="{StaticResource smallText}">举头望明月</Button>
<Button Style="{StaticResource smallText}">低头思故乡</Button>
</StackPanel>
</Page>DataTrigger(数据触发器):DataTrigger和MultiDataTriffer这一对触发器和Trigger和MultiTrigger非常类似。但是DataTrigger多了一个Binding属性,其语法如下:
<DataTrigger Binding="{Binding ElementName=控件名,path=空间中的相应属性}" value="相关属性的值">
如:
<Page x:Class="StyleTest.DataTrigger"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
mc:Ignorable="d"
d:DesignHeight="300" d:DesignWidth="300"
Title="DataTrigger">
<Page.Resources>
<Style x:Key="smallText">
<Setter Property="Control.Foreground" Value="Black"/>
<Setter Property="Control.FontSize" Value="24"/>
<Setter Property=" Control.FontFamily" Value="Times New Roman"/>
<Setter Property="Control.FontWeight" Value="Regular"/>
<Style.Triggers>
<DataTrigger Binding="{Binding ElementName=italicFont, Path=IsChecked}" Value="True"> <!--这里绑定控件的名称,及控件属性-->
<Setter Property=" Control.FontStyle" Value="Italic"/> <!--当该控件触发该事件的时候,则所有控件的字体样式变为斜体-->
</DataTrigger>
<DataTrigger Binding="{Binding ElementName=boldFont, Path=IsChecked}" Value="True">
<Setter Property="Control.FontStyle" Value="Normal"/>
</DataTrigger>
<DataTrigger Binding="{Binding ElementName=redFont, Path=IsChecked}" Value="True">
<Setter Property=" Control.Foreground" Value="Red"/>
</DataTrigger>
<DataTrigger Binding="{Binding ElementName=blueFont, Path=IsChecked}" Value="True">
<Setter Property="Control.Foreground" Value="Blue"/>
</DataTrigger>
<DataTrigger Binding="{Binding ElementName=btnBold, Path=IsPressed}" Value=" True">
<Setter Property="Control.FontSize" Value="12"/>
</DataTrigger>
</Style.Triggers>
</Style>
</Page.Resources>
<StackPanel>
<GroupBox>
<Grid>
<Grid.RowDefinitions>
<RowDefinition />
<RowDefinition />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition />
<ColumnDefinition />
</Grid.ColumnDefinitions>
<RadioButton Name="italicFont" Grid.Row="0" Grid.Column="0">斜体</RadioButton>
<RadioButton Name="boldFont" Grid.Row="0" Grid.Column="1">正常</RadioButton>
<RadioButton Name="redFont" Grid.Row="1" Grid.Column="0">红色</RadioButton>
<RadioButton Name="blueFont" Grid.Row="1" Grid.Column="1">蓝色</RadioButton>
</Grid>
</GroupBox>
<TextBlock Style="{StaticResource smallText}">床前明月光</TextBlock>
<TextBlock Style="{StaticResource smallText}">疑是地上霜</TextBlock>
<TextBlock Style="{StaticResource smallText}">举头望明月</TextBlock>
<TextBlock Style="{StaticResource smallText}">低头思故乡</TextBlock>
<Button x:Name="btnBold" Style="{StaticResource smallText}">粗体</Button>
</StackPanel>
</Page>
版权声明:本文为博主原创文章,未经博主允许不得转载。
WPF触发器的使用的更多相关文章
- WPF触发器(Trigger)
WPF触发器(Trigger.DataTrigger.EventTrigger) WPF中有种叫做触发器的东西(记住不是数据库的trigger哦).它的主要作用是根据trigger的不同条件来自动更改 ...
- WPF 触发器例子
WPF的触发器很强大,这里简单附上触发器的一个小例子,分别用XMAL和CS代码来实现一个功能,鼠标悬停在button上时改变字体颜色 1.XMAL代码如下: <Window x:Class=&q ...
- wpf 触发器理解
(1)属性触发器:其对应的类是Trigger.它在特定关联属性发生变化时被触发.一个属性的更改会在另一个属性中触发即时或动态更改. (2)数据触发器:其对应的类是DataTrigger.它在特定的CL ...
- WPF触发器(非数据库中的触发器)
一.什么是触发器?触发器(Trigger)就是当某种条件满足后即完成相应逻辑功能的一部分程序组成.在当前的WPF中,Trigger一共有三种类型,它们分别是: (1)属性触发器:其对应的类是Trigg ...
- WPF触发器(Trigger、DataTrigger、EventTrigger)
WPF中有种叫做触发器的东西(记住不是数据库的trigger哦).它的主要作用是根据trigger的不同条件来自动更改外观属性,或者执行动画等操作. WPFtrigger的主要类型有:Trigger. ...
- WPF 触发器
属性触发器:数据触发器:事件触发器
- WPFの触发器详解
例子1 简单触发器Triggers——满足简答的条件,触发 <Window x:Class="Styles.SimpleTriggers" xmlns="http: ...
- wpf 触发器,属性触发器,事件触发器,事件触发器。
<EventTrigger RoutedEvent="Mouse.MouseEnter"/> <DataTrigger Binding="{Bindin ...
- WPF触发器(Trigger) - DataTrigger
官方文档中对DataTrigger的介绍 Represents a trigger that applies property values or performs actions when the ...
随机推荐
- Python 之 threading
创建多线程常用的三种方法: 创建Thread的实例,传给它一个函数 创建Thread的实例,传给它一个可调用的类实例(不推荐) 派生Thread的子类,并创建子类的实例(推荐) 创建Thread的实例 ...
- 定位form光标行
In AX2009 if you call the research() method on a form passing true, the cursor position within a gri ...
- mysql下将分隔字符串转换为数组
MySQL存储过程可以用于分割字符串,下面就为您详细介绍这种MySQL存储过程的用法,供您参考学习之用. 现有一段字符串,如apple,banana,orange,pears,grape,要把它按照逗 ...
- [转载] COM 套间
http://www.vckbase.com/index.php/wv/1315 简序 大学毕业前的最后一学期,在一家公司实习,当时的工作需要用到一些操作系统提供的组件.那时候只知道COM这个名词,并 ...
- c++学习--继承与派生
继承和派生 1 含有对象成员(子对象)的派生类的构造函数,定义派生类对象成员时,构造函数的执行顺序如下: 1 调用基类的构造函数,对基类数据成员初始化: 2 调用对象成员的构造函数,对对象成员的数据成 ...
- AX7: CREATE NEW PACKAGE\MODEL
To create a new package\model on AX first you should understand the concept of Packages and Models o ...
- gulp和grunt的区别
1. Grunt -> Gulp 早些年提到构建工具,难免会让人联想到历史比较悠久的Make,Ant,以及后来为了更方便的构建结构类似的Java项目而出现的Maven.Node催生了一批自动化工 ...
- HttpClient Get/Post方式调用Http接口
本节摘要:本节主要分别介绍如何用get方式.post方式向http接口发送数据. preparation 1. 项目环境如下: myeclipse6.5 .tomcat5.0.system:xp.JD ...
- ue4标签测试与总结(UPROPERTY)
学习UE4框架中的标签,本篇是总结成员变量标签UPROPERTY. 引擎版本:4.12.5 前期准备: 1.新建项目,C++空模板,新建C++类,继承AActor,名称MyActor. 使用TestA ...
- javascript模式之模块模式
使用模式来组织代码有很多优点:使代码的结构更清晰,逻辑性更强,更容易维护.还可以避免很多错误. 首先,在javascript主要分为两大类: 编程模式-- 一些专门为javascript语言开发出的最 ...