c# - UWP GridView 图像拉伸(stretch)错误

标签 c# image gridview uwp stretch

我有一个 GridView 控件绑定(bind)到具有 BitmapImage 属性的对象集合。 GridView 项模板的 Image 控件具有固定大小,而实际图片的大小可能会有所不同,可以小于或大于 Image。所以我对大图片使用 Stretch=Uniform,对小图片使用 Stretch=None。我在 Image_Loaded 事件上设置了 Stretch 属性:

    private void img_ImageOpened(object sender, RoutedEventArgs e)
    {
        var img = sender as Image;
        if (img.Width > (img.Source as BitmapImage).PixelWidth)
        {
            img.Stretch = Stretch.None;
        }
        else
        {
            img.Stretch = Stretch.Uniform;
        }
    }

所以照片很合身:

enter image description here

但是如果我清除绑定(bind)的集合并再次填充它,事情就会变得非常困惑:

enter image description here

我花了很多时间试图解决这个问题。 Image_Loaded 没有被第二次调用,所以我认为它与项目缓存有关。我试图将 CacheMode 设置为 null,但这没有帮助。尝试处理各种事件,但也没有成功。

请帮忙!

谢谢

Download my project - 我删除了与问题无关的所有内容,只有 90 行代码。

PS 我找到了正确的订阅事件,它是 Image_DataContextChanges。似乎 GridView 项目被重用,并且在更新对象和特定网格项目时可能会混淆。 Image_Loaded 未被调用,因此对象进入具有任意拉伸(stretch)的随机网格项。 DataContextChanges 每次都会触发,因此它可用于动态更改拉伸(stretch)方法。

虽然它有效,但我认为下面的 Clemens 解决方案更好。下次还会用。

最佳答案

您可以将 Image 控件放在一个 Viewbox 中,而不是在代码后面调整 Image 的 Stretch 属性,它除了 Stretch 之外还有一个 StretchDirection 属性。如果您将其设置为 DownOnly,图像只会被拉伸(stretch)到更小的尺寸。

<DataTemplate x:DataType="local:Thing">
    <Border BorderBrush="Black" BorderThickness="1" Background="Black">
        <Viewbox Width="48" Height="48" Stretch="Uniform" StretchDirection="DownOnly">
            <Image Stretch="None" Source="{x:Bind Image}" />
        </Viewbox>
    </Border>
</DataTemplate>

关于c# - UWP GridView 图像拉伸(stretch)错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37674566/

相关文章:

c# - 在不同的方法中使用数组

C# 写入 HKCU 中的注册表项不起作用

c# - 更新 MySQL 会返回受影响的行,但实际上不会更新数据库

php - 一个输入的多图像上传 PHP 表单

c# - 如何使用 C# 确定进程是否已在运行?

html - 如何使图像上的文本 block 响应?

javascript - 将背景图像缩放到用户的浏览器大小

c# - 清除sqldatasource过滤器表达式

c# - 如何在asp.net webform Gridview中显示复选框

c# - 从 Gridview 获取动态创建的复选框值 |网站