显示图片的方案就是:自定义一个Photo类,里面有属性Source;View再绑定ViewModel中的Photo集合,再到View中给ListView设置数据模板
关键点:这样做很容易忘记写数据模板
数据模板可以写成下面这样:
XML
<DataTemplate DataType="{x:Type local:Photo}">
<StackPanel>
<Image Source="{Binding Source}"/>
</StackPanel>
</DataTemplate>
-- 将这个数据模板放到Window.Resources中也会起作用的,即使ListBox中绑定的是一个Photo类型的集合。
没有数据模板前
data:image/s3,"s3://crabby-images/36e5e/36e5edfed9a36f8b7898c7c21bb64385ce771e24" alt=""
添加数据模板后:
data:image/s3,"s3://crabby-images/40beb/40bebfe198d542b9df99834519490d166c5e941b" alt=""
如果想要这些图片横向排列,就得设置ItemsPanel
XML
<ListBox.ItemsPanel>
<ItemsPanelTemplate>
<WrapPanel HorizontalAlignment="Center" IsItemsHost="True"/>
</ItemsPanelTemplate>
</ListBox.ItemsPanel>
这个时候的显示效果为:
data:image/s3,"s3://crabby-images/e2fb9/e2fb9e93b2c8189c4cb66108c430041cb4e753da" alt=""