Solved

VB.net Binding DataGridViewComboBoxCell to Enumeration

Posted on 2010-08-21
3
2,095 Views
Last Modified: 2012-05-10
I have the following code to define and set up my enumeration which I want to bind to a datagridviewcomboboxcell

<System.SerializableAttribute(), _
 System.Xml.Serialization.XmlTypeAttribute([Namespace]:="")> _
Partial Public Class WorkingDaysOfWeek
    Private iDay As iWeekDay
    <System.Xml.Serialization.XmlElementAttribute(Form:=System.Xml.Schema.XmlSchemaForm.Unqualified)> _
    Public Property HELDINACCT() As iWeekDay
        Get
            Return Me.iDay
        End Get
        Set(ByVal value As iWeekDay)
            Me.iDay = value
        End Set
    End Property

    <System.SerializableAttribute(), _
 System.Xml.Serialization.XmlTypeAttribute([Namespace]:="")> _
    Enum iWeekDay
        Monday
        Tuesday
        Wednesday
        Thursday
        Friday
    End Enum

End Class

Open in new window


I then use this routine to bind the enumeration to the datagridviewcomboboxcolumn

        Dim iSa As New DataGridViewComboBoxColumn
        With iSA
            .DataSource = System.Enum.GetValues(GetType(WorkingDaysOfWeek.iWeekDay))
            .Name = "Days"
            .FlatStyle = FlatStyle.Flat
        End With

Open in new window


My question is:

I am using VB 2010 Express edition and whenever I select a value from any cell in the combo column, the DISPLAYED value always returns to Monday (notwithstanding that I may have chosen another day).

Is this because of the way I have defined my class and enumeration, or is there some setting I have to make in the datagridview itself?

PS. I use the class above as part of a bigger class that serializes to XML. Incidentally, all enumerations in that class (sisters of the above) behave in the same way when bound to a DataGridviewComboboxCell / Column.
0
Comment
Question by:nepaluz
  • 2
3 Comments
 
LVL 18

Accepted Solution

by:
John (Yiannis) Toutountzoglou earned 500 total points
ID: 33494262
try this
Public Shared Function BindEnumeration(ByVal _enum As Type) As ArrayList

        'get the names from the enumeration

        Dim enumNames() As String = System.Enum.GetNames(_enum)

        'get the values from the enumeration

        Dim enumValues() As Integer = System.Enum.GetValues(_enum)

        'turn it into a hash table

        Dim aList As New ArrayList()

        For i As Integer = 0 To enumNames.Length - 1

            aList.Insert(enumValues(i), enumNames(i))

        Next

        Return aList

    End Function

    Enum iWeekDay

        Monday

        Tuesday

        Wednesday

        Thursday

        Friday

    End Enum

DatsGridViewComboBox.DataSource = BindEnumeration(GetType(iWeekDay))

Open in new window

0
 
LVL 17

Author Comment

by:nepaluz
ID: 33494339
jtoutou - thanks for the response.

Your code (should) work, however, it does not take into consideration of the "duo" purpose of my code request and question.

1. In the first place, the class serialize to XML (your suggested solution does not cater for that).

2. The second purpose is to have a working comboboxcell. My code above DOES produce a combocell bound to the enumeration (again as illustrated), however, there seems to be an issue with the displyed value (after selecting from the combo), which was my request for help (NOT INDEPENDENT OF THE SERIALIZATION!).
I may be missing something from your code, but may I request a more complete code sample with serialization included?

0
 
LVL 17

Author Closing Comment

by:nepaluz
ID: 33540586
It should have been obvious (having tested the code) that this was the solution, and it indeed is the solution.

jtoutou - could you be a bit more verbose next time PSE!???
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

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

Microsoft Reports are based on a report definition, which is an XML file that describes data and layout for the report, with a different extension. You can create a client-side report definition language (*.rdlc) file with Visual Studio, and build g…
The ECB site provides FX rates for major currencies since its inception in 1999 in the form of an XML feed. The files have the following format (reducted for brevity) (CODE) There are three files available HERE (http://www.ecb.europa.eu/stats/exch…
Windows 10 is mostly good. However the one thing that annoys me is how many clicks you have to do to dial a VPN connection. You have to go to settings from the start menu, (2 clicks), Network and Internet (1 click), Click VPN (another click) then fi…
With the power of JIRA, there's an unlimited number of ways you can customize it, use it and benefit from it. With that in mind, there's bound to be things that I wasn't able to cover in this course. With this summary we'll look at some places to go…

861 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

Need Help in Real-Time?

Connect with top rated Experts

25 Experts available now in Live!

Get 1:1 Help Now