Для анимации вырезку в UWP, мы можем использовать ObjectAnimationUsingKeyFrames с Grid.Clip
как следующее:
<Storyboard x:Name="Storyboard1">
<ObjectAnimationUsingKeyFrames Storyboard.TargetName="grid" Storyboard.TargetProperty="Grid.Clip">
<DiscreteObjectKeyFrame KeyTime="0:0:0.25">
<DiscreteObjectKeyFrame.Value>
<RectangleGeometry Rect="0,0,55,34" />
</DiscreteObjectKeyFrame.Value>
</DiscreteObjectKeyFrame>
<DiscreteObjectKeyFrame KeyTime="0:0:0.50">
<DiscreteObjectKeyFrame.Value>
<RectangleGeometry Rect="0,0,65,34" />
</DiscreteObjectKeyFrame.Value>
</DiscreteObjectKeyFrame>
<DiscreteObjectKeyFrame KeyTime="0:0:0.75">
<DiscreteObjectKeyFrame.Value>
<RectangleGeometry Rect="0,0,75,34" />
</DiscreteObjectKeyFrame.Value>
</DiscreteObjectKeyFrame>
<DiscreteObjectKeyFrame KeyTime="0:0:1">
<DiscreteObjectKeyFrame.Value>
<RectangleGeometry Rect="0,0,90,34" />
</DiscreteObjectKeyFrame.Value>
</DiscreteObjectKeyFrame>
</ObjectAnimationUsingKeyFrames>
</Storyboard>
...
<Grid x:Name="grid"
Width="90"
Height="34"
Background="Red"
BorderBrush="Black"
BorderThickness="2"
RenderTransformOrigin="0.5,0.5">
<Grid.Clip>
<RectangleGeometry Rect="0,0,45,34" />
</Grid.Clip>
<TextBlock Margin="4" Foreground="White">Hello world</TextBlock>
</Grid>
Однако это ключевой кадр анимации, если вам нужна линейная интерполяция анимации, вы можете попробовать следующие:
<Storyboard x:Name="Storyboard1">
<DoubleAnimation Duration="0:0:1"
Storyboard.TargetName="grid"
Storyboard.TargetProperty="(UIElement.Clip).(Geometry.Transform).(CompositeTransform.TranslateX)"
To="0" />
</Storyboard>
...
<Grid x:Name="grid"
Width="90"
Height="34"
Background="Red"
BorderBrush="Black"
BorderThickness="2"
RenderTransformOrigin="0.5,0.5">
<Grid.Clip>
<RectangleGeometry Rect="0,0,90,34">
<RectangleGeometry.Transform>
<CompositeTransform TranslateX="-45" />
</RectangleGeometry.Transform>
</RectangleGeometry>
</Grid.Clip>
<TextBlock Margin="4" Foreground="White">Hello world</TextBlock>
</Grid>
Спасибо, это действительно все объясняет. Если бы это было возможно, я бы дал вам дополнительный момент для синтаксиса в Storyboard.TargetProperty :-) – PEK