我有一个Canvas元素,包含在ScrollViewer中,我正在使用ScaleTransform进行缩放。然而,我希望能够在缩放操作完成后保持查看器的滚动位置集中在画布的同一部分。当前,当我缩放画布时,查看器的滚动位置保持不变,用户正在查看的位置会丢失。
我仍在学习WPF,并且在这方面来回摆动了一段时间,但我无法找出一种漂亮的基于XAML实现我想要的方式。
这是我正在使用的代码的样例...
<Grid>
<ScrollViewer Name="TrackScrollViewer" HorizontalScrollBarVisibility="Auto" VerticalScrollBarVisibility="Auto">
<Canvas Width="2560" Height="2560" Name="TrackCanvas">
<Canvas.LayoutTransform>
<ScaleTransform ScaleX="{Binding ElementName=ZoomSlider, Path=Value}"
ScaleY="{Binding ElementName=ZoomSlider, Path=Value}"/>
</Canvas.LayoutTransform>
<!-- Some complex geometry describing a motor racing circuit -->
</Canvas>
</ScrollViewer>
<StackPanel Orientation="Horizontal" Margin="8" VerticalAlignment="Top" HorizontalAlignment="Left">
<Slider Name="ZoomSlider" Width="80" Minimum="0.1" Maximum="10" Value="1"/>
<TextBlock Margin="4,0,0,0" VerticalAlignment="Center" Text="{Binding ElementName=ZoomSlider, Path=Value, StringFormat=F1}"/>
</StackPanel>
</Grid>