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 に答える