这是情况......在顶层,我有一个TabControl.TabControl中的每个页面都包含一个ListBox:
sub item 1
sub item 2
sub item 3
sub item 1
sub item 2
ListBoxes有一个水平方向的StackPanel作为它们的ListTemplate:
您会注意到我在堆栈面板上有一些事件处理程序.这些是为堆栈面板中的项目设置动画,因此它们会依次淡入视图.事件处理程序实现为:
void onStackPanelLoaded(object sender, RoutedEventArgs e)
{
StackPanel panel = sender as StackPanel;
applySubItemAnimations(panel);
}
void onStackPanelVisibilityChange(object sender, DependencyPropertyChangedEventArgs e)
{
StackPanel panel = sender as StackPanel;
if (panel.IsVisible)
{
applySubItemAnimations(panel);
}
}
private void applySubItemAnimations(StackPanel panel)
{
DoubleAnimation fadeIn = new DoubleAnimation();
fadeIn.DecelerationRatio = 0.1;
fadeIn.Duration = new Duration(new TimeSpan(0, 0, 0, 0, 500));
fadeIn.From = 0.0;
fadeIn.To = 1.0;
for (int i = 0; i < panel.Children.Count; i++)
{
panel.Children[i].Opacity = 0.0;
fadeIn.BeginTime = new TimeSpan(0, 0, 0, 0, 200 * i + 50);
panel.Children[i].BeginAnimation(UIElement.OpacityProperty, fadeIn);
}
}
在大多数情况下,这很有效.首次单击(或加载)选项卡时,堆栈面板中的子项将逐个淡入视图.问题是,当您单击回到之前已经显示过一次的选项卡(即,您处于"VisibleChanged"事件处理程序而不是"已加载"处理程序)时,所有项目都已显示并且它们按顺序闪烁,而不是开始为隐藏和被显示在顺序.
这是丑陋的地方.这一行:
panel.Children[i].Opacity = 0.0;
... 什么也没做.如果我单步执行调试器中的代码并将注意放在"panel.Children [i] .Opacity"上,它将保持在1.0.没有例外或任何事情.它只是...不起作用.
有任何想法吗?
我猜测可能发生的事情:WPF在完成后不会移除动画,因此当您的代码applySubItemsAnimations
第二次运行该方法时,之前的动画仍然存在.因此,您可以尝试通过将null作为第二个参数传递给删除这些动画
panel.Children[i].BeginAnimation(UIElement.OpacityProperty, null);
之后,您可以应用新动画,因此整个for
-loop看起来像这样:
for (int i = 0; i < panel.Children.Count; i++) { panel.Children[i].Opacity = 0.0; fadeIn.BeginTime = new TimeSpan(0, 0, 0, 0, 200 * i + 50); panel.Children[i].BeginAnimation(UIElement.OpacityProperty, null); panel.Children[i].BeginAnimation(UIElement.OpacityProperty, fadeIn); }