Rubrik: Controls · ComboBox | VB-Versionen: VB4, VB5, VB6 | 17.12.01 |
![]() Mit einer einzigen API-Funktion lässt sich die Aufklapphöhe einer ComboBox (fast) individuell einstellen. | ||
Autor: ![]() | Bewertung: ![]() ![]() ![]() ![]() ![]() | Views: 22.890 |
https://www.tools4vb.com | System: Win9x, WinNT, Win2k, WinXP, Win7, Win8, Win10, Win11 | ![]() |
Stört es Sie, dass die Aufklapphöhe eines Kombinations-Listenfeldes (ComboBox) immer automatisch vom System vorgegeben wird? Da hat man gerade mal 10 Einträge in der Liste stehen, verwendet zudem noch eine große Bildschirm-Auflösung - und was passiert, wenn man die ComboBox mit den 10 Einträgen öffnet? Es werden nur 7 oder 8 Einträge angezeigt. Scrollen ist angesagt, wenn man eine von den letzten Einträgen auswählen möchte
Abhilfe muss her
Mit einer einzigen API-Funktion lässt sich die Aufklapphöhe der ComboBox (fast) individuell festlegen. Zuständig hierfür ist die MoveWindow-Funktion. Die Funktion erwartet 6 Parameter:
- hWnd: Handle des Fensters, dessen Größe geändert werden soll
- x, y: Neue Position für die linke obere Ecke (in Pixel)
- nWidth, nHeight: Neue Breite bzw. Höhe (in Pixel)
- bRepaint: autom. Neuzeichnen ja/nein
' Deklaration der Funktion Private Declare Function MoveWindow Lib "user32" ( _ ByVal hwnd As Long, _ ByVal x As Long, _ ByVal Y As Long, _ ByVal nWidth As Long, _ ByVal nHeight As Long, _ ByVal bRepaint As Long) As Long
Der nachfolgende Code übernimmt dann die Größen-Änderung - genauer gesagt, wird über die Prozedur Combo_SetDropDrownHeight die neue Aufklapphöhe (in Pixel) festgelegt.
' Aufklapphöhe einer ComboBox neu festlegen ' (Angabe in Pixel) Public Sub Combo_SetDropDownHeight(F As Form, _ Combo As ComboBox, ByVal nHeight As Long) With Combo MoveWindow .hwnd, _ F.ScaleX(.Left, .Parent.ScaleMode, vbPixels), _ F.ScaleY(.Top, .Parent.ScaleMode, vbPixels), _ F.ScaleX(.Width, .Parent.ScaleMode, vbPixels), _ nHeight, 1 End With End Sub
Die Umrechnungen der aktuell für das Formular eingestellten Masseinheit in Pixel (API-Funktionen erwarten solche Angaben fast immer in der Einheit Pixel) übernehmen die Funktionen ScaleX und ScaleY. Aus diesem Grund muss auch zusätzlich die Form als Parameter angegeben werden.
Und so wird obige Prozedur innerhalb des Projekt aufgerufen:
Private Sub Form_Load() ' Kombinationsfeld mit Daten füllen With Combo1 .AddItem "Eintrag 1" .AddItem "Eintrag 2" .AddItem "Eintrag 3" .AddItem "Eintrag 4" .AddItem "Eintrag 5" .AddItem "Eintrag 6" .AddItem "Eintrag 7" .AddItem "Eintrag 8" .AddItem "Eintrag 9" .AddItem "Eintrag 10" End With ' Aufklapphöhe neu festlegen Combo_SetDropDownHeight Me, Combo1, 300 End Sub
Eine Sache wäre noch anzumerken. Eingangs war von ...(fast) individuell... die Rede. Ganz individuell geht es leider nicht (warum auch immer) - denn der Versuch die Standard-Aufklapphöhe zu verringern, schlägt fehl.
Sollten Sie auch hierfür eine Lösung kennen oder "sich erarbeitet haben", so würden wir uns freuen, wenn Sie und den Code für diesen Tipp zur Verfügung stellen.