Rubrik: Controls · ListBox & ComboBox | VB-Versionen: VB.NET | 26.11.07 |
ListBox mit laufender ToolTip-Anzeige (.NET) Diesmal zeigen wir Ihnen, wie sich in der Standard-ListBox der Eintrag unter dem Mauszeiger bei Bedarf als ToolTip anzeigen lässt. | ||
Autor: Dieter Otter | Bewertung: | Views: 15.734 |
www.tools4vb.de | System: WinNT, Win2k, WinXP, Win7, Win8, Win10, Win11 | Beispielprojekt auf CD |
Heute zeigen wir Ihnen eine Möglichkeit, wie sich in der Standard-ListBox von VB.NET der Eintrag unter dem Mauszeiger bei Bedarf als ToolTip anzeigen lässt, d.h. der ToolTip wird nur dann angezeigt, wenn der Eintrag unter dem Mauszeiger nicht vollständig lesbar ist.
Erstellen Sie hierzu ein neues Projekt, platzieren auf die Form eine ListBox (ListBox1) und fügen nachfolgenden Code in das Codefenster der Form ein:
' ToolTip-Objekt Dim oToolTip As New ToolTip
Private Sub Form1_Load(ByVal sender As System.Object, _ ByVal e As System.EventArgs) Handles MyBase.Load ' ListBox vorbereiten With ListBox1 .Font = New Font("Verdana", 10, FontStyle.Regular) .Width = 150 End With ' ein paar Testeinträge erstellen With ListBox1.Items .Add("Dies ist ein normaler Text") .Add("Dies ist ein etwas längerer Text") .Add("Kurz") .Add("Und noch einmal ein etwas längerer Text") End With End Sub
Private Sub ListBox1_MouseMove(ByVal sender As Object, _ ByVal e As System.Windows.Forms.MouseEventArgs) _ Handles ListBox1.MouseMove Dim sToolTip As String = "" ' ToolTip nur anzeigen, wenn keine Maustaste gedrückt ist If e.Button = Windows.Forms.MouseButtons.None Then With ListBox1 ' ListIndex anhand der Mausposition ermitteln Dim p As Point = .PointToClient(Cursor.Position) Dim index As Integer = .IndexFromPoint(p) If index >= 0 Then ' Text des Eintrags unter dem Mauszeiger Dim sText As String = .Items(index).ToString ' Prüfen, ob Text vollständig angezeigt wird Using g As Graphics = .CreateGraphics ' Breite des vollständigen Textes ermitteln Dim nWidth As Integer = CInt(g.MeasureString( _ sText, .Font, 0, StringFormat.GenericTypographic).Width) ' ermittelte Breite mit Innenbereich der ListBox vergleichen If nWidth > .ClientRectangle.Width Then ' Text als ToolTip anzeigen sToolTip = sText End If End Using End If End With End If ' ToolTip zuweisen If oToolTip.GetToolTip(ListBox1) <> sToolTip Then oToolTip.SetToolTip(ListBox1, sToolTip) End If End Sub
Private Sub ListBox1_MouseLeave(ByVal sender As Object, _ ByVal e As System.EventArgs) Handles ListBox1.MouseLeave ' ToolTip zurücksetzen oToolTip.SetToolTip(ListBox1, "") End Sub