WPF触发器变化相应控件外观

开发 开发工具
WPF触发器的应用可以帮助我们实现控件外观变化的操作。在这篇文章中我们会以一个范例来详细介绍相关操作方法,方便大家理解。

WPF开发工具的主要用途就是实现图形界面的显示功能。在学习的过程中我们有许多需要深入研究的内容。比如,除了定义控件的默认外观外,也许我们想还定义当外界刺激我们的控件时,控件外观做出相应的变化,这是我们需要触发器。参考以下代码: #t#

  1. < Button Content="test btn" 
    Grid.Column="1" Grid.ColumnSpan="1" 
    Grid.Row="1" Grid.RowSpan="1" >   
  2. < Button.Template>   
  3. < ControlTemplate>   
  4. < !--定义视觉树-->   
  5. < Grid>   
  6. < Ellipse Name="faceEllipse" Width="
    {TemplateBinding Button.Width}"
     Height="
    {TemplateBinding Control.Height}"
     
    Fill="{TemplateBinding Button.Background}"/>   
  7. < TextBlock Name="txtBlock" Margin="
    {TemplateBinding Button.Padding}"
     
    VerticalAlignment="Center" Horizontal
    Alignment
    ="Center" Text="{Template
    Binding Button.Content}"
     />   
  8. < /Grid>   
  9. < !--定义视觉树_end-->   
  10. < !--定义触发器-->   
  11. < ControlTemplate.Triggers>   
  12. < Trigger Property="Button.
    IsMouseOver"
     Value="True"> 
  13. < Setter Property="Button.
    Foreground"
     Value="Red" /> 
  14. < /Trigger>   
  15. < /ControlTemplate.Triggers>   
  16. < !--定义触发器_End-->   
  17. < /ControlTemplate>   
  18. < /Button.Template>   
  19. < /Button> 

在上面的WPF触发器代码中注意到< ControlTemplate.Triggers>... < /ControlTemplate.Triggers>之间的部分,我们定义了触发器 < Trigger Property="Button.IsMouseOver" Value="True">,其表示当我们Button的IsMouseIOver属性变成True时,将使用设置器< Setter Property="Button.Foreground" Value="Red" /> 来将Button的Foreground属性设置为Red。这里有一个隐含的意思是:当Button的IsMouseIOver属性变成False时,设置器中设置的属性将回复原值。

你可以粘贴以下代码到XamlPad查看效果:

 

  1. < Window xmlns="http://schemas.
    microsoft.com/winfx/2006/xaml/presentation"
     
    xmlns:x="http://schemas.microsoft.com
    /winfx/2006/xaml"
     Title="ControlTemplateTest" 
    Height="300" Width="300" >   
  2. < Grid ShowGridLines="True">   
  3. < Grid.ColumnDefinitions>   
  4. < ColumnDefinition Width="0.2*"/>   
  5. < ColumnDefinition Width="0.6*"/>   
  6. < ColumnDefinition Width="0.2*"/> 
  7. < /Grid.ColumnDefinitions>   
  8. < Grid.RowDefinitions>   
  9. < RowDefinition Height="0.3*"/>   
  10. < RowDefinition Height="0.3*"/> 
  11. < RowDefinition Height="0.4*"/> 
  12. < /Grid.RowDefinitions>   
  13. < Button Content="test btn" 
    Grid.Column="1" Grid.ColumnSpan="1" 
    Grid.Row="1" Grid.RowSpan="1" >   
  14. < Button.Template>   
  15. < ControlTemplate>   
  16. < !--定义视觉树-->   
  17. < Grid> < Ellipse Name="faceEllipse" Width="
    {TemplateBinding Button.Width}"
     Height="
    {TemplateBinding Control.Height}"
     
    Fill="{TemplateBinding Button.Background}"/>   
  18. < TextBlock Name="txtBlock" Margin=
    "{TemplateBinding Button.Padding}"
     VerticalAlignment="Center" 
    HorizontalAlignment="Center" 
    Text="{TemplateBinding Button.Content}" />   
  19. < /Grid>   
  20. < !--定义视觉树_end-->   
  21. < !--定义触发器--> < ControlTemplate.Triggers>   
  22. < Trigger Property="Button.IsMouseOver" 
    Value="True">   
  23. < Setter Property="Button.Foreground" 
    Value="Red" />   
  24. < /Trigger> < /ControlTemplate.Triggers>   
  25. < !--定义触发器_End--> < /ControlTemplate>   
  26. < /Button.Template>   
  27. < /Button>   
  28. < /Grid>   
  29. < /Window>  

以上就是对WPF触发器的相关应用方法介绍。

责任编辑:曹凯 来源: IT168
相关推荐

2009-12-24 17:30:39

WPF数据触发器

2009-12-24 17:24:21

WPF属性触发器

2009-12-24 17:19:13

WPF触发器

2009-12-24 17:52:05

WPF触发器

2009-12-24 17:38:18

WPF事件触发器

2011-05-20 14:06:25

Oracle触发器

2009-07-10 12:30:12

Swing组件

2011-03-28 10:05:57

sql触发器代码

2009-09-18 14:31:33

CLR触发器

2011-05-19 14:29:49

Oracle触发器语法

2021-07-30 10:33:57

MySQL触发器数据

2011-04-14 13:54:22

Oracle触发器

2009-11-18 13:15:06

Oracle触发器

2010-05-31 18:06:07

MySQL 触发器

2010-10-12 10:04:15

MySQL触发器

2010-05-18 15:58:39

MySQL触发器

2010-10-12 10:24:58

mysql触发器

2011-03-03 09:30:24

downmoonsql登录触发器

2010-04-15 15:32:59

Oracle操作日志

2010-09-13 17:03:34

sql server触
点赞
收藏

51CTO技术栈公众号