Click here to Skip to main content
Click here to Skip to main content
Go to top

Editable History ComboBox

, 11 Feb 2004
Rate this:
Please Sign up or sign in to vote.
Demonstrates how to easily simulate an editable combobox that can persist previous entries (Like Internet Explorer).

Sample Image - historycombo.jpg

Introduction

The Compact Framework does not provide the option for an editable combobox, but there is an easy way to work around this limitation. The following article will explain how to create an editable combobox that remembers up to 10 previous entries (Like the address bar in Internet Explorer).

Using the code

To make a combobox editable, you simply overlay a text box on a combobox.  To make the textbox and combobox fit together seamlessly you can just add code to each combobox like so:

int dropDownButtonWidth = 14;
txtTest1.Bounds = cboTest1.Bounds;
txtTest1.Width -= dropDownButtonWidth;
            

Now, to complete the behavior of the editable combobox, you just need to make sure the textbox gets updated with the currently selected item from the combobox.  Refer to the code below:

private void cboTest1_SelectedIndexChanged(object sender, System.EventArgs e)
{
    txtTest1.Text = cboTest1.Text;
}
        

This is all you need to do to get the behavior of an editable combobox.  If you would like to create a history combobox, you will need an XML file to persist the combobox entries. The code to load the past entries is pretty straightforward.

// Load the combobox entries from the XML file.
xdoc.Load(@"\Path to comboboxes.xml");
XmlElement root = xdoc.DocumentElement;
XmlNodeList nodeList = root.ChildNodes;
ComboBox cboHistory;

for(int j=0; j<nodeList.Item(i).ChildNodes.Count; ++j)
{
    cboHistory.Items.Add(nodeList.Item(i).ChildNodes.Item(j).InnerText);    
}
        
The code to save new entries is a little more involved but not too bad.
int maxEntriesToStore = 10;
XmlTextWriter tw = new XmlTextWriter(@"\Path to comboboxes.xml", 
                                     System.Text.Encoding.UTF8);
tw.WriteStartDocument();
tw.WriteStartElement("comboboxes");
tw.WriteStartElement("combobox");
tw.WriteStartAttribute("name", string.Empty);
tw.WriteString("cboTest1");
tw.WriteEndAttribute();

// Write the item from the text box first.
if(txtTest1.Text.Length != 0)
{
    tw.WriteStartElement("entry");
    tw.WriteString(txtTest1.Text);
    tw.WriteEndElement();
    maxEntriesToStore -= 1;
}

// Write the rest of the entries (up to 10).
for(int i=0; i < cboTest1.Items.Count && i < maxEntriesToStore; ++i)
{
    if(txtTest1.Text != cboTest1.Items[i].ToString())
    {
        tw.WriteStartElement("entry");
        tw.WriteString(cboTest1.Items[i].ToString());
        tw.WriteEndElement();
    }
}

tw.WriteEndElement();
tw.WriteEndElement();
tw.Flush();
tw.Close();
        
The demo project contains code to handle 3 comboboxes and is arranged a little differently than the sample code above. Enjoy! Smile | :)

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

Share

About the Author

pbrooks
Software Developer (Senior)
United States United States
Check out my blog! http://www.pagebrooks.com

Comments and Discussions

 
GeneralMy vote of 5 Pinmembermanoj kumar choubey27-Mar-12 23:48 
GeneralSample ComboBox code for .net CF PinmemberKalzon13-Feb-05 14:31 
GeneralNice Article Pinmemberjadeboy12-Feb-04 16:55 
GeneralRe: Nice Article Pinmemberpbrooks12-Feb-04 17:09 

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

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

| Advertise | Privacy | Mobile
Web01 | 2.8.140926.1 | Last Updated 12 Feb 2004
Article Copyright 2004 by pbrooks
Everything else Copyright © CodeProject, 1999-2014
Terms of Service
Layout: fixed | fluid