vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
Blitzschnelles Erstellen von grafischen Diagrammen!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2024
 
zurück
Rubrik: Controls · ListBox & ComboBox   |   VB-Versionen: VB2008 - VB201519.04.16
Eine Gruppe von ComboBoxen steuern

Gegenseitiges Steuern einer Gruppe von N-ComboBoxen, die an die gleiche String-Liste mit N-Einträgen gebunden sind

Autor:   Manfred BohnBewertung:     [ Jetzt bewerten ]Views:  5.596 
ohne HomepageSystem:  Win7, Win8, Win10, Win11 Beispielprojekt auf CD 

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