Still celebrating National IT Professionals Day with 3 months of free Premium Membership. Use Code ITDAY17

x
?
Solved

String autocompletion with the PropertyGrid

Posted on 2009-05-19
2
Medium Priority
?
1,340 Views
Last Modified: 2012-05-07
Hi,

I'm desesperately looking for a way to implement the autocompletion (predictive value) in the text box of a PropertyGrid control. I want to type my text and get a the same time a possible value to complete the field.

I know how to set a combobox with a set of possible values but this not what i'm looking for. The value entered by the user (always a string) is not always existing in the list of possible values.

Here is the hack i've found, unfortunatly it sets the autocompletion on all fields in my property grid. I look for the possibility to put a different set of possible values by property.

Thanks for your help!
            Dim stringCollection As AutoCompleteStringCollection = New AutoCompleteStringCollection()
            stringCollection.Add("value1")
            stringCollection.Add("value2")
            stringCollection.Add("value3")
 
            SetPropertyGridAutocompletion( _
                                Me.NodeExtendedDataPropertyGrid, _
                                stringCollection)
 
     Private Sub SetPropertyGridAutocompletion( _
                ByVal propertyGrid As System.Windows.Forms.PropertyGrid, _
                ByVal stringCollection As AutoCompleteStringCollection)
 
        Dim propertyGridView As Control = propertyGrid.Controls(2) 'Get reference to property grid view
        Dim propertyGridViewType As Type = propertyGridView.GetType() 'get the type
        Dim pgType As Type = propertyGridViewType 'set this to a local variable
        Dim info As FieldInfo = pgType.GetField("edit", BindingFlags.Instance Or BindingFlags.NonPublic)
 
        ' Get the fieldInfo,which holds the reference to the textbox
        Dim txtBox As TextBox = CType(info.GetValue(propertyGridView), TextBox) 'Cast it to the textBox
 
        txtBox.AutoCompleteCustomSource = stringCollection
        txtBox.AutoCompleteMode = AutoCompleteMode.SuggestAppend
        txtBox.AutoCompleteSource = AutoCompleteSource.CustomSource
 
    End Sub

Open in new window

0
Comment
Question by:stevenhackars
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
2 Comments
 
LVL 30

Accepted Solution

by:
Alexandre Simões earned 2000 total points
ID: 24429840
You need to implement a new type editor for your property:

http://www.codeproject.com/KB/miscctrl/bending_property.aspx
0

Featured Post

Important Lessons on Recovering from Petya

In their most recent webinar, Skyport Systems explores ways to isolate and protect critical databases to keep the core of your company safe from harm.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Introduction Although it is an old technology, serial ports are still being used by many hardware manufacturers. If you develop applications in C#, Microsoft .NET framework has SerialPort class to communicate with the serial ports.  I needed to…
Summary: Persistence is the capability of an application to store the state of objects and recover it when necessary. This article compares the two common types of serialization in aspects of data access, readability, and runtime cost. A ready-to…
This course is ideal for IT System Administrators working with VMware vSphere and its associated products in their company infrastructure. This course teaches you how to install and maintain this virtualization technology to store data, prevent vuln…
Have you created a query with information for a calendar? ... and then, abra-cadabra, the calendar is done?! I am going to show you how to make that happen. Visualize your data!  ... really see it To use the code to create a calendar from a q…

688 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question