Blue Theme Orange Theme Green Theme Red Theme
 
6 Months Free & No Setup Fees ASP.NET Hosting!
Home | Forums | Videos | Advertise | Certifications | Downloads | Blogs | Interviews | Jobs | Beginners | Training
 | Consulting  
Submit an Article Submit a Blog 
 Jump to
Skip Navigation Links
TechnologyExpand Technology
WebsiteExpand Website
Discover the top 5 tips for understanding .NET Interop
Search :       Advanced Search »
Home » Windows Forms C# » Owner Draw ListBox Control with Images

Owner Draw ListBox Control with Images

In this article we will see how to write owner drawn ListBox control.

Page Views : 39906
Downloads : 1259
Rating :
 Rate it
Level : Beginner
   Print Read/Post comments Post a comment  Similar Articles  
   Email to a friend  Bookmark  Author's other articles  
Download Files:
ODLBoxWImage.zip
 
 
6 Months Free & No Setup Fees ASP.NET Hosting!
Become a Sponsor
Team Foundation Server Hosting
Become a Sponsor
 Tag Cloud
 Latest Jobs
More ... 
 Latest Interview Questions
More ... 


I was just looking around the code submitted by Sanjay Ahuja for the Owner Draw ListBox here: Owner Draw ListBox Control

And I started modifying the code. I found out there was a way to insert an icon in the Listbox control. This part of the code I have taken from Shripad Kulkarni's article Owner Draw Menus (including icons). All you have to do is to just follow the Procedure given by Sanjay Ahuja and start the project.

To make this simpler I have included the procedure here.

Note: Please copy all the bitmaps either to bin/debug or bin/release folder.

We start application by creating a Windows Application. Add a ListBox control to the form and set its DrawMode property to OwnerDrawVariable. Alternatively you can add following line to InitializeComponent() function of your form,

//lstColor is ListBox control
this.lstColor.DrawMode = System.Windows.Forms.DrawMode.OwnerDrawVariable;

Next add following lines after the above line

//tell windows we are interested in drawing items in ListBox on our own
this.lstColor.DrawItem += new DrawItemEventHandler(this.DrawItemHandler);
//tell windows we are interested in providing item size
this.lstColor.MeasureItem += new System.Windows.Forms.MeasureItemEventHandler(this.MeasureItemHandler);

By doing this, windows will send the DrawItem and MeasureItem events for each item added to ListBox.

Next, add handlers for these events

private void DrawItemHandler(object sender, DrawItemEventArgs e)
{
e.DrawBackground();
e.DrawFocusRectangle();
e.Graphics.DrawString(data[e.Index],
new Font(FontFamily.GenericSansSerif, 14, FontStyle.Bold),new SolidBrush(color[e.Index]),e.Bounds);
}

private void MeasureItemHandler(object sender, MeasureItemEventArgs e)
{
e.ItemHeight= 22;
}

In above code, date is an array that holds items to be inserted and color is an array of class Color.

That's it. We are done!!! I think so NO!!!!

Here comes the fun part.

Include this in the Class part.
------------------------------

private string []data;
private string []data2;
private Color []color;
Bitmap img_fileopen , img_exit , img_close ;
Bitmap img_security , img_network , img_about;

Include this in the Constructor
-------------------------------

data= new String[6]{"Open - Red","Close - Azure","Exit - Bisque","Security - BurlyWood","Network - Yellow","About - AntiqueWhite"};
data2=
new String[5]{"First","Second","Third","Forth","Fifth"};
color=
new Color[6]{Color.Red,Color.Azure,Color.Bisque,Color.BurlyWood,Color.Yellow,Color.AntiqueWhite};
listBox1.DataSource = data;
listBox2.DataSource = data2;
img_fileopen =
new Bitmap("FileOpen.bmp");
img_exit =
new Bitmap("exit.bmp");
img_close =
new Bitmap("Close.bmp");
img_about =
new Bitmap("about.bmp");
img_security =
new Bitmap("security.bmp");
img_network =
new Bitmap("network.bmp");

For listBox handlers events. (see the source code for more details)
-------------------------------------------------------------------

Rectangle rc = new Rectangle(e.Bounds.X+1, e.Bounds.Y+1, e.Bounds.Width-5, e.Bounds.Height-3);
e.Graphics.FillRectangle(
new SolidBrush(Color.CornflowerBlue), rc);
string []datas = data;
StringFormat sf =
new StringFormat();
sf.Alignment = StringAlignment.Far;
e.Graphics.DrawString(datas[e.Index],
new Font("Verdana", 10, FontStyle.Bold), new SolidBrush(color[e.Index]), rc, sf);
e.DrawFocusRectangle();
e.Graphics.DrawRectangle(
new Pen(new SolidBrush(Color.White), 2), rc);

To add the images (Please download the images). Add this code.
-------------------------------------------------------------

Image useImage = null ;
if ( datas[e.Index] == "Open - Red" )
{
useImage = img_fileopen;
}
if ( datas[e.Index] == "Close - Azure" )
{
useImage = img_close;
}
if ( datas[e.Index] == "Exit - Bisque" )
{
useImage = img_exit;
}
if ( datas[e.Index] == "Security - BurlyWood" )
{
useImage = img_security;
}
if ( datas[e.Index] == "Network - Yellow" )
{
useImage = img_network;
}
if ( datas[e.Index] == "About - AntiqueWhite" )
{
useImage = img_about;
}
if ( useImage != null )
{
SizeF sz = useImage.PhysicalDimension;
e.Graphics.DrawImage(useImage, e.Bounds.X+5 , ( e.Bounds.Bottom + e.Bounds.Top ) /2 - sz.Height/2);
}

That's it. Have fun!!!!!

Comment Request!
Thank you for reading this post. Please post your feedback, question, or comments about this post Here.
Login to add your contents and source code to this article
 [Top] Rate this article
 
 About the author
 
vasu_0203
Looking for C# Consulting?
C# Consulting is founded in 2002 by the founders of C# Corner. Unlike a traditional consulting company, our consultants are well-known experts in .NET and many of them are MVPs, authors, and trainers. We specialize in Microsoft .NET development and utilize Agile Development and Extreme Programming practices to provide fast pace quick turnaround results. Our software development model is a mix of Agile Development, traditional SDLC, and Waterfall models.
Click here to learn more about C# Consulting.
 
Introducing MaxV - one click. infinite control. Hyper-V Hosting from MaximumASP.
Finally – a virtual platform that delivers next-generation Windows Server 2008 Hyper-V virtualization technology from a managed hosting partner you can truly depend on. Visit www.maximumasp.com/max for a FREE 30 day trial. Hurry offer ends soon. Climb aboard the MaxV platform and take advantage of High Availability, Intelligent Monitoring, Recurrent Backups, and Scalability – with no hassle or hidden fees. As a managed hosting partner focused solely on Microsoft technologies since 2000, MaximumASP is uniquely qualified to provide the superior support that our business is built on. Unparalleled expertise with Microsoft technologies lead to working directly with Microsoft as first to offer IIS 7 and SQL 2008 betas in a hosted environment; partnering in the Go Live Program for Hyper-V; and product co-launches built on WS 2008 with Hyper-V technology.
Dynamic PDF
ceTE software specializes in components for dynamic PDF generation and manipulation. The DynamicPDF™ product line allows you to dynamically generate PDF documents, merge PDF documents and new content to existing PDF documents from within your applications.
Discover the Top 5 .NET Memory Management Fundamentals
To write the best .NET code, you need to know exactly how the .NET framework really manages memory. Ricky Leeks presents the Top 5 fundamental facts of .NET memory management. Learn more.
Nevron Chart for .NET 2010.1 Now Available
The leading .NET charting control now features PDF, Flash and Silverlight export, visualization of large datasets and more. Deliver true charting functionality to your BI, Scorecard, Presentation or Scientific apps. Download evaluation now.
ASP.NET 4 Hosting
Get 2 Months Free of ASP.NET Hosting for Only $4.95/month! Receive FREE MS SQL and MySQL Databases Including ASP.NET 4/3.5, MVC 3.0, Silverlight 4, Windows 2008/IIS 7.0 Plus FREE IIS 7 Modules. Host UNLIMITED ASP.NET Web Sites – Click Here!
 
 Post a Feedback, Comment, or Question about this article
Subject:
Comment:
6 Months Free & No Setup Fees ASP.NET Hosting!
Become a Sponsor
 Comments
ODLBoxWImage.zip by Javier On September 21, 2009
Hi!
Just download the source and it proved


Reply | Email | Modify 

 © 2012  contents copyright of their authors. Rest everything copyright Mindcracker. All rights reserved.