Rubrik: Controls · DataGrid & DataGridView | VB-Versionen: VB2005, VB2008 | 28.02.11 |
Tooltip mit Feldinhalt aus einer Datentabelle Der Tipp zeigt, wie man bspw. über der Zelle eines DatagridView mit speziellem Inhalt einen Tooltip erzeugen kann, dessen Inhalt selbst wiederum aus dem Feld einer Datentabelle gelesen wird. | ||
Autor: Dietrich Herrmann | Bewertung: | Views: 10.700 |
ohne Homepage | System: Win2k, WinXP, Win7, Win8, Win10, Win11 | kein Beispielprojekt |
Öfter hatte ich in einem datengebundenen DatagridView den Fall, dass in einer Spalte eine Abkürzung gezeigt wird. Bei der Erläuterung des Tipps gehe ich mal von diesem Beispiel aus:
Die DGV-Spalte beinhaltet das ISO-Kürzel der europäischen Währungen. Der Tooltip zu dieser Spalte soll aber immer den zu diesem Kürzel deutschen Währungstext (also die dt. Bezeichnung) zeigen. Da gibt es also eine Datentabelle, die beides enthält- sowohl ISO-Kürzel
als auch dt. Währungstext. Zu der Datentabelle gibt es noch eine entsprechende Bindingsource.
Dann erreicht man den "Zweck" mit folgender Vorgehensweise:
Private Sub DatagridView1_CellMouseEnter(ByVal sender As Object, _ ByVal e As DataGridViewCellEventArgs) _ Handles DatagridView1.CellMouseEnter Dim dgv As DataGridView = CType(sender, DataGridView) If e.RowIndex <= 0 Then Exit Sub If e.ColumnIndex < 0 OrElse e.ColumnIndex > getDGVColsVisible(DatagridView1) Then Exit Sub Dim n As String = dgv.Columns(e.ColumnIndex).Name If n <> "Waehrungssymbol" Then Exit Sub Dim c As DataGridViewCell = dgv.Rows(e.RowIndex).Cells(e.ColumnIndex) With c If Not IsDBNull(.Value) Then Dim cVal As String = .Value bsWaehr.Position = bsWaehr.Find("ISOKz", cVal) Dim dd As DataRowView = bsWaehr.Current .ToolTipText = dd("dtWaehrungstext") End If End With End Sub
Es wird geprüft, über welcher Spalte des DGV sich die Maus befindet und ob die DGV-Spalte, zu der der Tooltip erzeugt werden soll, u.a. auch zu den sichtbaren gehört (dazu gibt es die Hilfsfunktion getDGVColsVisible, siehe unten).
Im Beispiel enthält die Spalte "Waehrungssymbol" das ISO-Kürzel, das wiederum in der Datentabelle unter Feld "ISOKz" gespeichert ist. Der Text, der als Tooltip gezeigt werden soll, ist in Feld "dtWaehrungstext" gespeichert.
Mittels der Bindingsource "bsWaehr" wird der jeweilige Datensatz gesucht, der das Kürzel in der aktuellen Zelle des DGV enthält. Dann wird einfach nur aus dem entsprechenden Datensatz der Wert für den deutschen Währungstext gelesen und dem Tooltip zugeordnet.
That's it.
Hier noch die Hilfsfunktion:
''' <summary> ''' Ermitteln der Anzahl der sichtbaren Spalten eines DatagridView ''' </summary> ''' <param name="dgv">das Datagridview</param> Public Function getDGVColsVisible(ByVal theDGV As DataGridView) As Integer Dim VisColCount As Integer = 0 For Each col As DataGridViewColumn In theDGV.Columns If col.Visible = True Then VisColCount += 1 Next Return VisColCount End Function