Rubrik: Controls · DataGrid & DataGridView | VB-Versionen: VB2005, VB2008 | 21.06.10 |
DatagridViewComboboxColumn mit Tooltip je Item Der Tipp veranschaulicht eine Methode, eine DatagridViewComboboxColumn mit einem eigenen Tooltip zu versehen. | ||
Autor: Dietrich Herrmann | Bewertung: | Views: 11.411 |
ohne Homepage | System: Win2k, WinXP, Win7, Win8, Win10, Win11 | kein Beispielprojekt |
Vor kurzem stieß ich auf diese Problematik beim Programmieren einer Kundenanwendung. Da habe ich eine SQL-Datenbank mit bspw. einer Kundentabelle und einer Ländertabelle. In der Kundentabelle befindet sich ein Feld, dass das Land aus dem der Kunde stammt, kennzeichnet. Das Feld beinhaltet immer nur den Primärschlüssel der Datensätze der Länderdatei. Diese wiederum beinhaltet verschiedene Daten zu einem Land wie z.B. Land (deutscher Name), EnglischName, ISO-Kennzeichen, Vorwahl usw.
Die Kundendatei zeige ich in einem Datagridview an, wobei die Spalte „Land" vom Typ einer DatagridViewComboboxColumn ist, die an die Ländertabelle gebunden ist mit Datamember Primärschlüssel der Länderdatei und Displaymember ISO-Kennzeichen (D, A, CH,...). Mein Tipp realisiert, wie ich den Tooltip je ComboboxItem zeige, und zwar mit dem Tooltip-Text Name des Landes passend zum Kennzeichen.
Vereinbarungen:
(Zusätzlich zu den Imports für SQL-Arbeit)
Imports System.Drawing.Drawing2D Imports System.Drawing.Text
' der eigene Tooltip Dim tip As New System.Windows.Forms.ToolTip() ' die anzeigende Combobox Dim cmb As ComboBox ' ein Flag, ob der Tooltip gezeigt werden soll oder nicht Dim showFlag As Boolean = False ' Feldname des Textes, der im Tooltip zu sehen sein soll Dim itName As String = "Land"
Im folgenden Datagridview-Ereignis wird die Konstruktion und Anzeige des Tooltips vorgenommen:
Private Sub Datagridview_EditingControlShowing( _ ByVal sender As Object, _ ByVal e As DataGridViewEditingControlShowingEventArgs) _ Handles Datagridview.EditingControlShowing Dim dgv As DataGridView = CType(sender, DataGridView) Dim c As DataGridViewCell = dgv.CurrentCell showFlag = False If TypeOf e.Control Is ComboBox AndAlso c.OwningColumn.Name = itName Then cmb = TryCast(e.Control, ComboBox) With cmb .DrawMode = DrawMode.OwnerDrawFixed AddHandler .DrawItem, AddressOf cmb_DrawItem AddHandler .DropDownClosed, AddressOf cmb_DropDownClosed End With showFlag = True End If End Sub
Diese Prozedur zeichnet die Combobox-Items und zeigt den Tooltip für den entsprechenden Item:
Private Sub cmb_DrawItem(ByVal sender As Object, ByVal e As DrawItemEventArgs) With e Dim text As String = cmb.GetItemText(cmb.Items(e.Index)) Dim sz As SizeF = .Graphics.MeasureString(text, cmb.Font) .Graphics.SmoothingMode = SmoothingMode.HighQuality .Graphics.TextRenderingHint = TextRenderingHint.ClearTypeGridFit .DrawBackground() Using br As New SolidBrush(.ForeColor) .Graphics.DrawString(text, .Font, br, .Bounds) End Using If (.State And DrawItemState.Selected) = DrawItemState.Selected And showFlag Then Dim dr As DataRowView = cmb.SelectedItem tip.Show(dr.Item(itName), cmb, .Bounds.X + .Bounds.Width, _ .Bounds.Y + sz.Height * 3 / 2, 5000) Else tip.Hide(cmb) End If .DrawFocusRectangle() End With End Sub
Diese Prozedur blendet den Tooltip aus:
Private Sub cmb_DropDownClosed(ByVal sender As Object, ByVal e As System.EventArgs) tip.Hide(cmb) showFlag = False End Sub
Ich hoffe, der Tipp ist hilfreich und sicher auch anwendbar für andere Fälle.