In manchen Situationen ist es wichtig zu wissen, wieviele Zeilen sichtbar in einem ListBox-Control angezeigt werden. Beispielsweise dann, wenn man den Standard-Scrollbalken durch einen eigenen ersetzen will. Mit der universellen API-Funktion "SendMessage" bekommt man die Anzahl der sichtbaren Einträge sehr schnell heraus. Option Explicit ' Benötigte API-Deklarationen Private Declare Function SendMessage Lib "user32" _ Alias "SendMessageA" ( _ ByVal hwnd As Long, _ ByVal wMsg As Long, _ ByVal wParam As Long, _ ByVal lParam As Long) As Long Private Const LB_GETITEMHEIGHT = &H1A1 ' Anzahl der sichtbaren Einträge eines ListBox-Control ermitteln Public Function LB_ScreenRows(ListBox As Object) As Long Dim nItemHeight As Long Dim nCount As Long With ListBox ' Ermitteln der Item-Zeichenhöhe nItemHeight = SendMessage(.hwnd, LB_GETITEMHEIGHT, 0, 0) ' Anzahl sichtbarer Einträge On Error Resume Next nHeight = .Parent.ScaleY(.Height, .Container.ScaleMode, vbPixels) - 4 If Err.Number <> 0 Then nHeight = .Parent.ScaleY(.Height, .Parent.ScaleMode, vbPixels) - 4 End If nCount = Int(nHeight / nItemHeight) On Error GoTo 0 If nHeight Mod nItemHeight <> 0 Then nCount = nCount + 1 End With LB_ScreenRows = nCount End Function Beispiel für den Aufruf: Dim nRows As Long nRows = LB_ScreenRows(List1) Dieser Tipp wurde bereits 16.928 mal aufgerufen. Voriger Tipp | Zufälliger Tipp | Nächster Tipp
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv Vol.6 (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. |
vb@rchiv CD Vol.6 Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! Online-Update-Funktion Entwickler-Vollversionen u.v.m. Tipp des Monats Juni 2024 Microsys Kramer Mausrad im Formular abschalten (Access) Deaktiviert das Mausrad in Access-Formularen. Neu! sevCommand 4.0 Professionelle Schaltflächen im modernen Design! Mit nur wenigen Mausklicks statten auch Sie Ihre Anwendungen ab sofort mit grafischen Schaltflächen im modernen Look & Feel aus (WinXP, Office, Vista oder auch Windows 8), inkl. große Symbolbibliothek. |
||||||||||||||||
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. |