ItemsControl
通过将a包装起来,我能够创建(我认为)您所追求的效果Canvas
:
<Canvas x:Name="ClippingContainer" Background="Aquamarine" HorizontalAlignment="Center" VerticalAlignment="Center" ClipToBounds="True">
<ItemsControl x:Name="ICont" ItemsSource="{Binding}" SizeChanged="ItemsControl_SizeChanged"/>
</Canvas>
然后通过对 parent 的和属性进行ItemsControl.SizeChanged
动画处理来响应事件。Height
Width
Canvas
private void ItemsControl_SizeChanged(object sender, SizeChangedEventArgs e)
if (double.IsNaN(ClippingContainer.Height))
{
ClippingContainer.Height = e.NewSize.Height;
}
else
{
ClippingContainer.BeginAnimation(FrameworkElement.HeightProperty, new DoubleAnimation(e.NewSize.Height, new Duration(TimeSpan.FromSeconds(1))));
}
if (double.IsNaN(ClippingContainer.Width))
{
ClippingContainer.Width = e.NewSize.Width;
}
else
{
ClippingContainer.BeginAnimation(FrameworkElement.WidthProperty, new DoubleAnimation(e.NewSize.Width, new Duration(TimeSpan.FromSeconds(1))));
}
}
注意:这可以很容易地转换成它自己的UserControl
. 在这样做时,您可以覆盖并强制布局传递以重绘动画所属MeasureOverride
的任何父布局容器。ItemsControl
我希望你觉得这有帮助。