1

到目前为止,我一直在使用listview没有任何问题。我已经能够传递多个列并用图像、文本等填充它们。我决定对列表框做同样的事情,但那里的事情变得复杂了。在列表视图中,我执行以下操作:

<DataTemplate x:Key="ImageTemplate" >
    <Image x:Name="FavoriteImageList"  Tag="{Binding tagger}" Width="12" Height="12" Source="{Binding ImageSource}" MouseLeftButtonDown="FavoriteImageList_MouseLeftButtonDown"/>
</DataTemplate>

<ListView x:Name="Citys">
    <ListView.View>
        <GridView ColumnHeaderContainerStyle="{StaticResource myHeaderStyle}">
            <GridViewColumn Width="90" Header="Image" CellTemplate="{StaticResource ImageTemplate}"/>
            <GridViewColumn Width="178" Header="Name" DisplayMemberBinding="{Binding Name}" />
            <GridViewColumn Width="178" Header="City" DisplayMemberBinding="{Binding City}"/>
            <GridViewColumn Width="140" Header="Author" DisplayMemberBinding="{Binding Author}"/>
        </GridView>
    </ListView.View>
</ListView>

我填充这样的列:

foreach(var fav in Favorites)
{
    Citys = new List<ACity>() 
    {
        new ACity() {tagger = Name ,ImageSource = ImageSource ,Name= Name, Author= Author, City = City}
    };
    ListBox.Items.Add(Citys);
}

如果我在列表框中执行此操作,它将填充(集合)。有没有办法在列表框中执行此操作,在列表框行中传递图像按钮字符串?

4

1 回答 1

2

请参阅 MSDN ItemsControl.ItemTemplate中的示例

<ListBox Width="400" Margin="10"
         ItemsSource="{Binding Source={StaticResource myTodoList}}">
   <ListBox.ItemTemplate>
     <DataTemplate>
       <StackPanel>
         <TextBlock Text="{Binding Path=TaskName}" />
         <TextBlock Text="{Binding Path=Description}"/>
         <TextBlock Text="{Binding Path=Priority}"/>
       </StackPanel>
     </DataTemplate>
   </ListBox.ItemTemplate>
 </ListBox>

与您的示例相匹配应该非常简单。

于 2013-07-09T12:15:50.017 回答