How do add image to System.Windows.Forms.ListBox?

27,461

Solution 1

You can't do that easily in the ListBox. And drawing them using Graphics is not easy at all. I suggest using a DataGridView o ListView control instead.

Result:

enter image description here

DataGridView: There's a ColumnType called DataGridViewImageColumn that you can use to show your status icon.

public void FillDataGridView()
{
    //images
    var greenImg = Resources.green;
    var redImg = Resources.red;
    var yellowImg = Resources.yellow;

    dataGridView1.Rows.Add(new object[] {"Vland", greenImg});
    dataGridView1.Rows.Add(new object[] {"John", yellowImg });
    dataGridView1.Rows.Add(new object[] {"Paul", greenImg});
    dataGridView1.Rows.Add(new object[] {"George", redImg});
    dataGridView1.Rows.Add(new object[] {"Ringo", redImg });
}

How to: Display Images in Cells of the Windows Forms DataGridView Control

ListView: can add items composed by text + image. If you use the ListView, you need to add an imageList component to your form (with your images in it) and call their imageKey value like shown in the example

public void fillListView()
{
    listView1.SmallImageList = imageList1;

    listView1.Items.Add("BombPenguin", "green");
    listView1.Items.Add("Vland", "yellow");
    listView1.Items.Add("John", "red");
    listView1.Items.Add("Paul", "green");
    listView1.Items.Add("Ringo", "red");
}

How to: Display Icons for the Windows Forms ListView Control

Solution 2

It's not directly supported. However, you can draw each item of the list manually using the DrawItem event; this will allow you to include an image for each item, using Graphics.DrawImage.

Share:
27,461
BombPenguin
Author by

BombPenguin

C/C++, C#, PengChat

Updated on December 29, 2020

Comments

  • BombPenguin
    BombPenguin over 3 years

    I'm developing chatting program using C# and I manage nickname list using ListBox. But, client have nickname, and state (online, away)

    So, in order to manage the state, I want to add image (online - green circle, away - red circle) to ListBox (it is my idea)

    How can add image to ListBox? Please help me.

    Thanks.