Click here to Skip to main content
15,881,559 members
Articles / Programming Languages / C#
Article

Where's the ImageCombo control?

Rate me:
Please Sign up or sign in to vote.
4.82/5 (43 votes)
18 Jan 20041 min read 284.5K   5.3K   103   54
ImageCombo control for .NET.

Sample Image - ImageCombo.NET

Introduction

When I started programming in .NET, I wondered where the ImageCombo control had gone (I used to program in VB6). The .NET Framework didn't seem to have this functionality built-in, but it's very easy to add it.

Using the code

The code consists of two classes: ImageCombo and ImageComboItem. If you want to use them in C#, just copy them into your project; for other .NET languages, you can add a reference to the library.

The control inherits from ComboBox and introduces one new member: the ImageList property, which doesn't require any further explanation. The control is owner drawn and there is a custom drawing method defined, so don't change its DrawMode property if you want to see the images.

The ImageComboItem class inherits from Object. You can set a customForeColor and it has a Mark property which determines if the item is shown in bold font style (does not work if owner font is already bold).

To add an item to an ImageCombo with text "Icon 0" and image index 0, use the following code:

C#
imageCombo.Items.Add(new ImageComboItem("Icon 0", 0));

Code listing: ImageCombo class

C#
using System;
using System.Drawing;

namespace System.Windows.Forms
{

    public class ImageCombo : ComboBox
    {
        private ImageList imgs = new ImageList();

        // constructor
        public ImageCombo()
        {
            // set draw mode to owner draw
            this.DrawMode = DrawMode.OwnerDrawFixed;    
        }

        // ImageList property
        public ImageList ImageList 
        {
            get 
            {
                return imgs;
            }
            set 
            {
                imgs = value;
            }
        }

        // customized drawing process
        protected override void OnDrawItem(DrawItemEventArgs e)
        {
            // draw background & focus rect
            e.DrawBackground();
            e.DrawFocusRectangle();

            // check if it is an item from the Items collection
            if (e.Index < 0)

                // not an item, draw the text (indented)
                e.Graphics.DrawString(this.Text, e.Font, 
                        new SolidBrush(e.ForeColor), e.Bounds.Left + 
                        imgs.ImageSize.Width, e.Bounds.Top);

            else
            {
                
                // check if item is an ImageComboItem
                if (this.Items[e.Index].GetType() == typeof(ImageComboItem)) 
                {                                                            

                    // get item to draw
                    ImageComboItem item = (ImageComboItem) 
                        this.Items[e.Index];

                    // get forecolor & font
                    Color forecolor = (item.ForeColor != 
                         Color.FromKnownColor(KnownColor.Transparent)) ? 
                         item.ForeColor : e.ForeColor;
                    Font font = item.Mark ? new Font(e.Font, 
                         FontStyle.Bold) : e.Font;

                    // -1: no image
                    if (item.ImageIndex != -1) 
                    {
                        // draw image, then draw text next to it
                        this.ImageList.Draw(e.Graphics, 
                           e.Bounds.Left, e.Bounds.Top, item.ImageIndex);
                        e.Graphics.DrawString(item.Text, font, 
                           new SolidBrush(forecolor), e.Bounds.Left + 
                           imgs.ImageSize.Width, e.Bounds.Top);
                    }
                    else
                        // draw text (indented)
                        e.Graphics.DrawString(item.Text, font, 
                            new SolidBrush(forecolor), e.Bounds.Left + 
                            imgs.ImageSize.Width, e.Bounds.Top);

                }
                else
                
                    // it is not an ImageComboItem, draw it
                    e.Graphics.DrawString(this.Items[e.Index].ToString(), 
                      e.Font, new SolidBrush(e.ForeColor), e.Bounds.Left + 
                      imgs.ImageSize.Width, e.Bounds.Top);
                
            }

            base.OnDrawItem (e);
        }
        
    }

}

Code listing: ImageComboItem class

C#
using System;
using System.Drawing;

namespace System.Windows.Forms
{

    public class ImageComboItem : object
    {
        // forecolor: transparent = inherit
        private Color forecolor = Color.FromKnownColor(
                KnownColor.Transparent);
        private bool mark = false;
        private int imageindex = -1;
        private object tag = null;
        private string text = null;        
        
        // constructors
        public ImageComboItem()
        {
        }

        public ImageComboItem(string Text) 
        {
            text = Text;    
        }

        public ImageComboItem(string Text, int ImageIndex)
        {
            text = Text;
            imageindex = ImageIndex;
        }

        public ImageComboItem(string Text, int ImageIndex, bool Mark)
        {
            text = Text;
            imageindex = ImageIndex;
            mark = Mark;
        }

        public ImageComboItem(string Text, int ImageIndex, 
            bool Mark, Color ForeColor)
        {
            text = Text;
            imageindex = ImageIndex;
            mark = Mark;
            forecolor = ForeColor;
        }

        public ImageComboItem(string Text, int ImageIndex, 
               bool Mark, Color ForeColor, object Tag)
        {
            text = Text;
            imageindex = ImageIndex;
            mark = Mark;
            forecolor = ForeColor;
            tag = Tag;
        }

        // forecolor
        public Color ForeColor 
        {
            get 
            {
                return forecolor;
            }
            set
            {
                forecolor = value;
            }
        }

        // image index
        public int ImageIndex 
        {
            get 
            {
                return imageindex;
            }
            set 
            {
                imageindex = value;
            }
        }

        // mark (bold)
        public bool Mark
        {
            get
            {
                return mark;
            }
            set
            {
                mark = value;
            }
        }

        // tag
        public object Tag
        {
            get
            {
                return tag;
            }
            set
            {
                tag = value;
            }
        }

        // item text
        public string Text 
        {
            get
            {
                return text;
            }
            set
            {
                text = value;
            }
        }
        
        // ToString() should return item text
        public override string ToString() 
        {
            return text;
        }

    }

}

History

  • Original code (01/10/2004)
  • Optimized code for speed & added some functionality (18/10/2004)

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here


Written By
Belgium Belgium
This member has not yet provided a Biography. Assume it's interesting and varied, and probably something to do with programming.

Comments and Discussions

 
GeneralMy vote of 5 Pin
Moin Alvi26-Jul-11 1:10
Moin Alvi26-Jul-11 1:10 
GeneralSupport for Datasource Pin
Brian (BH)17-Jun-10 4:11
Brian (BH)17-Jun-10 4:11 
GeneralLicense Pin
Gilvinit4-Apr-09 9:04
Gilvinit4-Apr-09 9:04 
GeneralRe: License Pin
Niels Penneman4-Apr-09 12:01
Niels Penneman4-Apr-09 12:01 
QuestionAuto Complete missing Pin
Member 31856112-Jan-08 3:42
Member 31856112-Jan-08 3:42 
GeneralIs somethingt liker this available for CheckedListBoxes Pin
cht30005-Nov-07 3:34
cht30005-Nov-07 3:34 
Generalerror message at appending imag file to imagelist:doh: Pin
osaru24-Oct-07 22:28
osaru24-Oct-07 22:28 
GeneralRe: error message at appending imag file to imagelist:doh: Pin
Niels Penneman25-Oct-07 7:09
Niels Penneman25-Oct-07 7:09 
GeneralAwesome! Pin
androjdaz4-Oct-07 9:19
androjdaz4-Oct-07 9:19 
QuestionAny plan to have Vista look for DropDownLists? Pin
Steph17x28-Sep-07 5:42
Steph17x28-Sep-07 5:42 
QuestionInvalidArgument=Value of '0' is not valid for 'index'. Pin
shreekar7-Nov-06 20:16
shreekar7-Nov-06 20:16 
AnswerRe: InvalidArgument=Value of '0' is not valid for 'index'. Pin
shreekar7-Nov-06 20:50
shreekar7-Nov-06 20:50 
GeneralRe: InvalidArgument=Value of '0' is not valid for 'index'. Pin
Niels Penneman8-Nov-06 8:27
Niels Penneman8-Nov-06 8:27 
QuestionRe: InvalidArgument=Value of '0' is not valid for 'index'. Pin
shreekar8-Nov-06 17:49
shreekar8-Nov-06 17:49 
AnswerRe: InvalidArgument=Value of '0' is not valid for 'index'. Pin
Niels Penneman9-Nov-06 9:47
Niels Penneman9-Nov-06 9:47 
GeneralSmall suggestion Pin
Mattman2067-Nov-06 4:08
Mattman2067-Nov-06 4:08 
GeneralBlurred images Pin
C_Vella_CW27-Oct-06 0:49
C_Vella_CW27-Oct-06 0:49 
GeneralThank you Pin
yueue28-Jul-06 2:15
yueue28-Jul-06 2:15 
GeneralGood jbo, Pin
Kony Han8-Mar-06 15:24
Kony Han8-Mar-06 15:24 
GeneralOnPaint not fired Pin
Stefan Frutiger28-Nov-05 1:29
Stefan Frutiger28-Nov-05 1:29 
GeneralRe: OnPaint not fired Pin
Holo91126-Jan-06 9:15
Holo91126-Jan-06 9:15 
GeneralImageCombo not show icon Pin
microlabs25-Oct-05 6:52
microlabs25-Oct-05 6:52 
QuestionBug with tabs? Pin
mrgrieves26-Aug-05 3:56
mrgrieves26-Aug-05 3:56 
AnswerRe: Bug with tabs? Pin
mrgrieves26-Aug-05 6:09
mrgrieves26-Aug-05 6:09 
GeneralRe: Bug with tabs? Pin
mrgrieves214-Aug-05 7:40
mrgrieves214-Aug-05 7:40 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.