2017-03-02 63 views
1

我想在listview中添加我的项目。这是我的课程;如何在wpf应用程序的listview中添加项目?

FindFace.Show.Response response = await _api.Show_Face(lb_GalleryList.SelectedItem.ToString());   
    if (response.results.Count != 0) 
    { 
     List<FaceImages> faceImages = new List<FaceImages>(); 
     for (int i = 0; i < response.results.Count; i++) 
     { 
     faceImages.Add(new FaceImages() { Face_id = response.results[i].person_id.ToString(), Face_thumbnail = LoadImage(response.results[i].thumbnail) }); 
     } 
     lv_Photos.ItemsSource = faceImages;      
    } 

在faceImages中,这是它的样子; enter image description here

而且这里是我的xaml文件的样子;

<ListView x:Name="lv_Photos" HorizontalAlignment="Stretch" VerticalAlignment="Top"> 
       <ItemsControl.ItemsPanel> 
        <ItemsPanelTemplate> 
         <UniformGrid Columns="5" HorizontalAlignment="Stretch" /> 
        </ItemsPanelTemplate> 
       </ItemsControl.ItemsPanel> 
       <DataTemplate> 
        <StackPanel Orientation="Vertical" VerticalAlignment="Stretch" HorizontalAlignment="Stretch"> 
         <Image Source="{Binding Face_thumbnail}" HorizontalAlignment="Stretch" VerticalAlignment="Top" Stretch="UniformToFill" /> 
         <TextBlock Text="{Binding Face_id}" HorizontalAlignment="Stretch" VerticalAlignment="Bottom" /> 
        </StackPanel> 
       </DataTemplate> 
      </ListView> 

但是,当我试图把faceImages放在ItemsSource这里;

lv_Photos.ItemsSource = faceImages; 

应用程序使

An exception of type 'System.InvalidOperationException' occurred in PresentationFramework.dll but was not handled in user code 

Additional information: Items collection must be empty before using ItemsSource. 

我不明白我怎么能传递faceImages类我的列表视图元素。

+0

你必须ListView.Items东西(所以例如,你手动添加一些项目在XAML ListView控件或以某种方式加入代码之前的东西项目集合),所以你不能使用的ItemsSource,因为Items和ItemsSource是互斥的。 – Evk

+0

@Evk我想为这种情况找到一些解决方案,如有必要,我可以重写所有内容。 – goGud

+0

也应该使用ObservableCollection而不是列表作为itemSource或绑定不会更新 – MikeT

回答

2

您不小心将DataTemplate作为子项添加到ListView本身中。这就是为什么Items收集不是空的,ItemsSource不能使用,因为它们是互斥的。相反,使用ListView.ItemTemplate

<ListView x:Name="lv_Photos" 
      HorizontalAlignment="Stretch" 
      VerticalAlignment="Top"> 
    <ItemsControl.ItemsPanel> 
     <ItemsPanelTemplate> 
      <UniformGrid Columns="5" 
         HorizontalAlignment="Stretch" /> 
     </ItemsPanelTemplate> 
    </ItemsControl.ItemsPanel> 
    <ListView.ItemTemplate> 
     <DataTemplate> 
      <StackPanel Orientation="Vertical" 
         VerticalAlignment="Stretch" 
         HorizontalAlignment="Stretch"> 
       <Image Source="{Binding Face_thumbnail}" 
         HorizontalAlignment="Stretch" 
         VerticalAlignment="Top" 
         Stretch="UniformToFill" /> 
       <TextBlock Text="{Binding Face_id}" 
          HorizontalAlignment="Stretch" 
          VerticalAlignment="Bottom" /> 
      </StackPanel> 
     </DataTemplate> 
    </ListView.ItemTemplate> 
</ListView> 
+0

你真棒..我不知道我是如何错过它的。谢谢.. – goGud

+0

@Evk抱歉,在错误的地方发表评论 – MikeT

相关问题