我创建了一个用户控件:
<UserControl ...>
<Grid DataContext="{Binding UserContrlViewModel>
<Grid Width="200" Height="100" RenderTransformOrigin="0.5,0.5">
<Grid.Resources>
<Storyboard x:Key="zoomIn">
<DoubleAnimation
Storyboard.TargetProperty="ScaleTransform.ScaleX"
From="0"
To="1"
Duration="0:0:1" />
<DoubleAnimation
Storyboard.TargetProperty="ScaleTransform.ScaleY"
From="0"
To="1"
Duration="0:0:1" />
</Storyboard>
</Grid.Resources>
<Grid.RenderTransform>
<ScaleTransform />
</Grid.RenderTransform>
<Grid.Style>
<Style TargetType="Grid">
<Style.Triggers>
<DataTrigger Binding="{Binding Path=IsActive}" Value="True">
<DataTrigger.EnterActions>
<BeginStoryboard>
<StaticResource ResourceKey="zoomIn" />
</BeginStoryboard>
</DataTrigger.EnterActions>
</DataTrigger>
</Style.Triggers>
</Style>
</Grid.Style>
<TextBlock Width="60" Text="Input" />
<TextBox Width="80" Margin="80,0,0,0" />
</Grid>
...
</Grid>
</UserControl>
Run Code Online (Sandbox Code Playgroud)
我想要实现的是,当IsActive用户控件的视图模型类的属性设置为 时true,zoomIn运行动画。这个动画应该放大网格,里面有它的内容。当我触发动画时,我收到以下错误消息:
无法解析属性路径“ScaleTransform.ScaleX”中的所有属性引用。验证适用对象是否支持这些属性。
我的动画有什么问题?我应该如何实现所描述的放大动画?谢谢。
我得到了它:
<ScaleTransform>例如,应该设置<ScaleTransform ScaleX="0.5" ScaleY="0.5" />属性以使缩放从 50% 开始。<DoubleAnimation>的值Storyboard.TargetProperty应从 更改"ScaleTransform.ScaleX"为"RenderTransform.ScaleX"。<DoubleAnimation>的值Storyboard.TargetProperty应从 更改"ScaleTransform.ScaleY"为"RenderTransform.ScaleY"。