繁体   English   中英

使用情节提要在WPF触发器中平滑ExitAction

[英]Smooth ExitAction in WPF Trigger using Storyboard

我有一个WPF应用程序,在这里我想覆盖难看的默认WPF样式。 我创建了Styles.xaml词典,在这里我几乎完成了样式,但是在动画和不同视觉状态(触发)之间的平滑过渡方面存在一些问题。

我的挑战之一是我不想将任何C#事件处理程序或其他C#代码绑定到样式。

在这里,我在触发器上提供了一些代码:

<MultiTrigger>
    <MultiTrigger.Conditions>
        <Condition Property="IsEnabled" Value="True" />
        <Condition Property="IsMouseOver" Value="True" />
        <Condition Property="IsPressed" Value="False" />
    </MultiTrigger.Conditions>
    <MultiTrigger.EnterActions>
        <BeginStoryboard Name="MouseOverStoryboard">
            <Storyboard Duration="0:0:0.25" SlipBehavior="Grow">
                <ColorAnimation Storyboard.TargetName="InnerBorder" 
                                Storyboard.TargetProperty="Background.(SolidColorBrush.Color)" 
                                To="{StaticResource White}" 
                                BeginTime="0:0:0" Duration="0:0:0.25" />
                <DoubleAnimation Storyboard.TargetName="InnerBorder" 
                                 Storyboard.TargetProperty="Opacity" 
                                 To="0.3" 
                                 BeginTime="0:0:0" Duration="0:0:0.25" />
            </Storyboard>
        </BeginStoryboard>
    </MultiTrigger.EnterActions>
    <MultiTrigger.ExitActions>
        <RemoveStoryboard BeginStoryboardName="MouseOverStoryboard" />
    </MultiTrigger.ExitActions>
</MultiTrigger>

为了使动画更流畅,我添加了EnterAction并将Storyboard与时序一起放置在此处,因此输入动画很流畅且看起来不错。

我的第一个问题是关于执行BeginStoryboard时如何恢复默认颜色,但后来我意识到可以使用RemoveStoryboard。

现在我真的不知道我的想法出了点-如何制作流畅的退出动画? 我不应该使用RemoveStoryboard吗?

请提供建议。 谢谢。

PS我不使用VisualStateManager,因为缺乏状态,我不想为此实现自己的控件。

如何添加一个新的动画对象,该对象在输入动作动画持续时间过去后开始。 或通过添加一个Storyboard来还原您的EnterAction来使用触发器的ExitAction属性。 或者您可以尝试将Fillbehavior属性设置为“停止...”。

另一个选择是使用EventSetter来捕获RoutedEvents例如MouseEnterMouseLeave

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM