我有一个非常简单的 RenderTargetBitmap.RenderAsync 重载破坏 WebView 缩放的重现案例。我在 MainPage 上只有一个 WebView 和一个按钮:
<Grid Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">
<WebView Source="http://bing.com"></WebView>
<Button Content="Render me"
HorizontalAlignment="Right"
VerticalAlignment="Bottom"
Click="ButtonBase_OnClick" />
</Grid>
在后面的代码中只有一个简单的事件处理程序
private async void ButtonBase_OnClick(object sender, RoutedEventArgs e)
{
RenderTargetBitmap rtb = new RenderTargetBitmap();
await rtb.RenderAsync(this, 1280, 720);
}
这是调用 RenderAsync 之前页面的样子:
这就是通话后发生的事情:
知道为什么以及如何防止这种情况吗?请注意,只有当我打电话时才会发生这种情况
await rtb.RenderAsync(this, 1280, 720);
但如果我在没有缩放的情况下调用重载
await rtb.RenderAsync(this);
编辑:由于我收到的第一个答案,我想澄清为什么纵横比不是这里的问题,而只是为了证明确实存在问题。考虑以下场景 - 非常高的 DPI 屏幕,只需要较低分辨率的屏幕截图 - 即使您使用 RIGHT 比例缩小它,它仍然会弄乱 WebView。此外,对于我的场景,事后手动调整屏幕截图的大小不是一种选择 - 具有缩放尺寸的 RenderAsync 重载要快得多,我真的更喜欢使用该方法。