• 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

  • 相关阅读:
    AppiumDesktop控制手机和安卓模拟器
    Appium环境搭建超详细教程
    2022 杭电多校第一场
    Springcloud学习笔记48ApplicationRunner、CommandLineRunner接口使用
    java中23种设计模式

    Nacos
    Java常见的8种数据结构
    Java 对象模型(OOPKlass模型)
    nginx对skywalking grpc协议的负载nginx长连接和短连接概念
  • 原文地址:https://www.cnblogs.com/yk250/p/10058925.html
Copyright © 2020-2023  润新知