WPF常用TriggerAction用法 (一)

Microsoft.Expression.Interactivity 常用TriggerAction-> CallMethodAction ChangePropertyAction ControlStoryboardAction GoToStateAction

1,CallMethodAction 用于调用后台和DataContext中公用,无参数,无返回值的方法.这里扩展了一个CallMethodTrigger 可以调用有返回值和参数的方法。xaml中使用方法:

 <Button Background="{StaticResource TabItemSelectedBackground}" Height="40" MinWidth="80" Content="CallMethodFromCode" Padding="10 0">
        <i:Interaction.Triggers>
            <i:EventTrigger EventName="Click">
               <ei:CallMethodAction MethodName="MethodFromCode" TargetObject="{Binding RelativeSource={RelativeSource Mode=FindAncestor,AncestorType=Window}}"/>
               <ei:CallMethodAction MethodName="MethodFromCode" TargetObject="{Binding ElementName=window}"/>
                </i:EventTrigger>
         </i:Interaction.Triggers>
 </Button>

2,ChangePropertyAction 用于更改界面元素的属性和后台代码公开属性。界面元素属性一般要求为依赖属性。(附加属性也可。)xaml中使用方法:

   <ToggleButton Background="Orange" Height="40" MinWidth="80" Content="ChangeElementProperty" Padding="10 0">
       <i:Interaction.Triggers>
         <i:EventTrigger EventName="Checked">
             <ei:ChangePropertyAction TargetName="br" PropertyName="Background" Value="orange"/>
             <ei:ChangePropertyAction TargetName="tb" PropertyName="Text" Value="orange"/>
         </i:EventTrigger>
         <i:EventTrigger EventName="Unchecked">
             <ei:ChangePropertyAction TargetName="br" PropertyName="Background" Value="Red"/>
             <ei:ChangePropertyAction TargetName="tb" PropertyName="Text" Value="Red"/>
       </i:EventTrigger>
      </i:Interaction.Triggers>
</ToggleButton>

3,ControlStoryboardAction用于界面控制可访问动画的播放暂停等操作。xaml中使用方法:

   <Button Background="{StaticResource TabItemSelectedBackground}" Height="40" MinWidth="80" Content="ControlStoryboard Pause" Margin="10 0 0 0"  Padding="10 0">
       <i:Interaction.Triggers>
           <i:EventTrigger EventName="Click">
              <ei:ControlStoryboardAction ControlStoryboardOption="Pause" Storyboard="{StaticResource ChnageWidth1}"></ei:ControlStoryboardAction>
           </i:EventTrigger>
       </i:Interaction.Triggers>
    </Button>

  

4,GoToStateAction 切换可访问的两个VisulState 可视化的状态,一般也通过动画实现。xaml中使用方法:

   <ToggleButton Background="Orange" Margin="0 0 10 0" Height="30" MinWidth="80" Content="GoToState" Padding="10 0">
        <i:Interaction.Triggers>
            <i:EventTrigger EventName="Checked">
                <ei:GoToStateAction StateName="ClickState" UseTransitions="{Binding UseTransitions}"/>
            </i:EventTrigger>
            <i:EventTrigger EventName="Unchecked">
                <ei:GoToStateAction StateName="NormalState" />
            </i:EventTrigger>
       </i:Interaction.Triggers>
   </ToggleButton>

 下载 https://files.cnblogs.com/files/yk250/BlendBehaviorsDemo.rar

原文地址:https://www.cnblogs.com/yk250/p/10058925.html