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触发器的使用的更多相关文章

  1. WPF触发器(Trigger)

    WPF触发器(Trigger.DataTrigger.EventTrigger) WPF中有种叫做触发器的东西(记住不是数据库的trigger哦).它的主要作用是根据trigger的不同条件来自动更改 ...

  2. WPF 触发器例子

    WPF的触发器很强大,这里简单附上触发器的一个小例子,分别用XMAL和CS代码来实现一个功能,鼠标悬停在button上时改变字体颜色 1.XMAL代码如下: <Window x:Class=&q ...

  3. wpf 触发器理解

    (1)属性触发器:其对应的类是Trigger.它在特定关联属性发生变化时被触发.一个属性的更改会在另一个属性中触发即时或动态更改. (2)数据触发器:其对应的类是DataTrigger.它在特定的CL ...

  4. WPF触发器(非数据库中的触发器)

    一.什么是触发器?触发器(Trigger)就是当某种条件满足后即完成相应逻辑功能的一部分程序组成.在当前的WPF中,Trigger一共有三种类型,它们分别是: (1)属性触发器:其对应的类是Trigg ...

  5. WPF触发器(Trigger、DataTrigger、EventTrigger)

    WPF中有种叫做触发器的东西(记住不是数据库的trigger哦).它的主要作用是根据trigger的不同条件来自动更改外观属性,或者执行动画等操作. WPFtrigger的主要类型有:Trigger. ...

  6. WPF 触发器

    属性触发器:数据触发器:事件触发器

  7. WPFの触发器详解

    例子1 简单触发器Triggers——满足简答的条件,触发 <Window x:Class="Styles.SimpleTriggers" xmlns="http: ...

  8. wpf 触发器,属性触发器,事件触发器,事件触发器。

    <EventTrigger RoutedEvent="Mouse.MouseEnter"/> <DataTrigger Binding="{Bindin ...

  9. WPF触发器(Trigger) - DataTrigger

    官方文档中对DataTrigger的介绍 Represents a trigger that applies property values or performs actions when the ...

随机推荐

  1. Unity3D 第一人称控制器 C#脚本

    CharacterMotor.cs using UnityEngine; using System.Collections; /** * @Author : www.xuanyusong.com */ ...

  2. X-Cart 学习笔记 完整目录

    如果有需要,可以直接联系博主,讨论学习 一.了解X-CART. 3 二.PHP环境搭建... 3 三.安装配置X-CART. 4 1.下载X-Cart并配置域名,映射地址... 4 2.配置X-Car ...

  3. PHP Warning: PHP Startup: in Unknown on line 0

    Windows平台启动php后,出现PHP Warning:  PHP Startup:  in Unknown on line 0解决方案:这个问题是由于php.ini中没有开启(去掉注释符号)ph ...

  4. ASP.NET 生命周期 简介

    当我们在浏览器地址栏中输入网址,回车查看页面时,这时会向服务器端(IIS)发送一个request请求,服务器就会判断发送过来的请求页面,  完全识别 HTTP 页面处理程序类后,ASP.NET 运行时 ...

  5. source tree 推送错误解决

    fatal: The remote end hung up unexpectedly 出现这个问题是因为文件过大 解决办法: 打开git bash 输入git config --global http ...

  6. Python-3 语法

    #1 Tab键: 1)控制缩进 2)IDLE智能补全 #2 =等号: 1)=:表示赋值 2)==:表示判断 #3 流程图: print('..........小甲鱼_1..........') tem ...

  7. 使用localResizeIMG微信压缩上传图片安卓报错 weixin://preInjectJSBridge/fail

    微信上传图片是经常使用的功能,首先说一下使用的是:localResizeIMG进行图片压缩上传.感觉还是很好用,基本上功能都能满足. 但是最近在开发这个功能时遇到一个奇怪的问题,就是iphone|ip ...

  8. 启动kafka出现找不到或无法加载主类

    首先确认下环境变量配置是否成功. 如果配置成功<javac,javah>都没有问题,那就有可能是你安装了两个版本的jdk导致的,都卸载了,然后换一个目录按照一个jdk 在配置环境变量试下!

  9. jfinal相关

    1:jfinal工具类 1):密码加密工具 HashKit.md5(String password);2):数据缓存工具类 chacheKit3):获取项目路径工具类: PathKit 4):读取文件 ...

  10. ubuntu软件推荐

    本文推荐的ubuntu工具均为笔者亲用.原则:在精不在多. 0.万能类 笔者崇尚[极简主义],常用的工具如果有网页版的就尽量不用单独的client.如网页版微信. 1.系统类 截图:Deepin-sc ...