I have a few images with some text, I need to show the image with the relevant text in a listbox.
Browsing google I came across this sample class,
public class Customer
{
public string Fname;
public string Lname;
public Customer(string firstName, string lastName)
{
Fname = firstName;
Lname = lastName;
}
public override string ToString()
{
return Fname + " " + Lname;
}
}
lstCustomers.Items.Add(new Customer("Foo","Bar"));
The above code works fine as it only returns string, how do I return an image and a string together so that it gets added to the listbox?
Best Regards
@nand
Just use a DataTemplate
to display your objects in the ListBox
.
Create a data object that contains string properties and an Image property:
public class Img
{
public Img(string value, Image img) { Str = value; Image = img; }
public string Str { get; set; }
public Image Image { get; set; }
}
Create a DataTemplate
to display this:
<ListBox x:Name="lstBox">
<ListBox.ItemTemplate>
<DataTemplate DataType="{x:Type local:Img}">
<StackPanel>
<TextBlock Margin="3" Text="{Binding Str}"/>
<ContentControl Margin="3" Content="{Binding Image}"/>
</StackPanel>
</DataTemplate>
</ListBox.ItemTemplate>
</ListBox>
Now add the Img
items (or your data objects) to the ListBox
like so:
lstBox.Items.Add(new Img("Value", myImage));
You can't (without hacking around) put images in ListBoxes.
You can put them in ListViews.
You need to put your image(s) in an ImageList component, then attach the ImageList to your listview. Of course, you can encapsulate your image in your class by adding an Image property and adding that to the ImageList.Items collection.
Then for each ListViewItem in the List, set the ImageIndex property to the index of the image in the listview.
All this can be done using the designer.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With