Es war von einem Umsteiger gefragt worden, wie folgende Aufgabe zu lösen sei: Gegeben ist eine Gruppe von N-Comboboxen, die an die gleiche String-Liste mit N-Einträgen gebunden sind. Es soll erreicht werden, daß beim Wechsel des "SelectedIndex" einer Box durch den User, durch geeignete Aktualisierung des "Selectedindex" EINER anderen Box, wieder alle Listen-Einträge in den Boxen sichtbar sind. Beispiel ... Public Class frmCombos ' Gemeinsame Liste Dim lst As New List(Of String)({"A", "B", "C", "D", "E"}) ' Liste der Comboboxen Dim cbs As New List(Of ComboBox) Private Sub frmCombos_Load(sender As System.Object, _ e As System.EventArgs) Handles MyBase.Load CreateCombos() End Sub Private Sub CreateCombos() For i As Integer = 0 To lst.Count - 1 Dim bs As New BindingSource With {.DataSource = lst} cbs.Add(New ComboBox With {.Parent = Me, .DataSource = bs, _ .Top = i * 40, .Name = i.ToString, _ .DropDownStyle = ComboBoxStyle.DropDown, _ .SelectedIndex = i, .Tag = i}) ' Zuordnung der Eventhandler-Routine AddHandler cbs(i).SelectedIndexChanged, AddressOf SelectedIndexChanged Next i End Sub Private Sub SelectedIndexChanged(sender As Object, _ e As System.EventArgs) Dim cbo As ComboBox = DirectCast(sender, ComboBox) ' Der Listen-Index der Box, deren Selectedindex ' vom Benutzer geändert worden ist Dim comboindex As Integer = CInt(cbo.Name) ' In der Tag-Eigenschaft steht noch der bisherige ' Selectedindex Dim oldindex As Integer = CInt(cbo.Tag) For i As Integer = 0 To cbs.Count - 1 If Not i = comboindex AndAlso _ cbo.SelectedIndex = cbs(i).SelectedIndex Then ' Wechsel des SelectedIndex der Box, ' die den neu eingestellten Wert bisher angezeigt hat cbs(i).SelectedIndex = oldindex cbs(i).Tag = oldindex End If Next i cbo.Tag = cbo.SelectedIndex End Sub End Class Dieser Tipp wurde bereits 6.048 mal aufgerufen.
Anzeige
![]() ![]() ![]() (einschl. Beispielprojekt!) Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! - nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten - Symbol-Galerie mit mehr als 3.200 Icons im modernen Look Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m. |
sevWizard für VB5/6 ![]() Professionelle Assistenten im Handumdrehen Erstellen Sie eigene Assistenten (Wizards) im Look & Feel von Windows 2000/XP - mit allem Komfort und zwar in Windeseile :-) Tipp des Monats ![]() Dietrich Herrmann Umbrechen langer Strings mittels Measurement-Methode und speziellen Funktionen Der Tipp befasst sich mit dem Umbrechen von langen Strings bei Anwendung der Funktion DrawString. Es wird eine vorgegebene Breite (evtl. Breite des Ausgaberechtecks) und der anzuwendende Font beachtet. Access-Tools Vol.1 ![]() Über 400 MByte Inhalt Mehr als 250 Access-Beispiele, 25 Add-Ins und ActiveX-Komponenten, 16 VB-Projekt inkl. Source, mehr als 320 Tipps & Tricks für Access und VB |
||||||||||||||||
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein. |