ABOUT Visual Basic Programmieren Programmierung Download Downloads Tips & Tricks Tipps & Tricks Know-How Praxis VB VBA Visual Basic for Applications VBS VBScript Scripting Windows ActiveX COM OLE API ComputerPC Microsoft Office Microsoft Office 97 Office 2000 Access Word Winword Excel Outlook Addins ASP Active Server Pages COMAddIns ActiveX-Controls OCX UserControl UserDocument Komponenten DLL EXE
Diese Seite wurde zuletzt aktualisiert am 06.01.2000

Diese Seite wurde zuletzt aktualisiert am 06.01.2000
Aktuell im ABOUT Visual Basic-MagazinGrundlagenwissen und TechnologienKnow How, Tipps und Tricks rund um Visual BasicActiveX-Komponenten, Controls, Klassen und mehr...AddIns für die Visual Basic-IDE und die VBA-IDEVBA-Programmierung in MS-Office und anderen AnwendungenScripting-Praxis für den Windows Scripting Host und das Scripting-ControlTools, Komponenten und Dienstleistungen des MarktesRessourcen für Programmierer (Bücher, Job-Börse)Dies&Das...

Themen und Stichwörter im ABOUT Visual Basic-Magazin
Code, Beispiele, Komponenten, Tools im Überblick, Shareware, Freeware
Ihre Service-Seite, Termine, Job-Börse
Melden Sie sich an, um in den vollen Genuss des ABOUT Visual Basic-Magazins zu kommen!
Informationen zum ABOUT Visual Basic-Magazin, Kontakt und Impressum

Zurück...

Zurück...


Anzeige

(-hg) mailto:hg_showdropdown@aboutvb.de

Das Listenfeld einer ComboBox können Sie auch manuell öffnen oder schließen, indem Sie die Nachricht CB_SHOWDROPDOWN mittels der API-Funktion SendMessage an die ComboBox senden. Verwenden Sie die hier gezeigt Hilfsfunktion DropDown, brauchen Sie dieser lediglich die betreffende ComboBox zu übergeben, um das Listenfeld zu öffnen. Übergeben Sie hingegen zusätzlich im optionalen Parameter ShowHide den Wert False, wird das Listenfeld geschlossen. Sie können die Funktion unbesorgt mehrfach mit dem gleichen Wert für ShowHide aufrufen.

Private Declare Function SendMessage Lib "user32" _
 Alias "SendMessageA" (ByVal hwnd As Long, ByVal wMsg As Long, _
 ByVal wParam As Long, lParam As Any) As Long

Public Sub DropDown(Combo As ComboBox, _
 Optional ByVal ShowHide As Boolean = True)
  Const CB_SHOWDROPDOWN = &H14F
  
  SendMessage Combo.hwnd, CB_SHOWDROPDOWN, ShowHide, 0
End Sub

So kann etwa das Listenfeld automatisch geöffnet werden, wenn die ComboBox den Fokus erhält:

Private Sub Combo1_GotFocus()
  DropDown Combo1
End Sub

Sie können das Listenfeld auch automatisch öffnen, sobald der Anwender Zeichen eingibt. Damit die Escape-Taste jedoch weiterhin ihre Funktion beibehält, das Listenfeld zu schließen, müssen Sie diese jedoch ausnehmen:

Private Sub Combo1_KeyPress(KeyAscii As Integer)
  Select Case KeyAscii
    Case vbKeyEscape
    Case Else
      DropDown Combo1
  End Select
End Sub

Senden Sie die Nachricht CB_GETDROPPEDSTATE an die ComboBox, erhalten Sie die Information, ob das Listenfeld aktuell geöffnet oder geschlossen ist. Das Visual Basic-Ereignis DropDown der ComboBox informiert Sie nämlich nur über das Öffnen des Listenfeldes, nicht aber über das Schließen und auch nicht über den aktuellen Zustand.

Public Function IsDropped(Combo As ComboBox) As Boolean
  Const CB_GETDROPPEDSTATE = &H157
  
  IsDropped = CBool(SendMessage(Combo.hwnd, _
   CB_GETDROPPEDSTATE, 0, 0))
End Function


Modul modShowDropDown (modShowDropDown.bas - ca. 0,8 KB)






Themen - Allgemeines
Themen - Entwicklungsumgebung (VB-IDE)
Themen - Forms
Themen - Steuerelemente (Controls)
Themen - Grafik
Themen - Dateien
Themen - UserControls
Themen - Einsteiger-Tipps
Themen - Wussten Sie...?

Übersicht nach Titeln in alphabetischer Reihenfolge
Übersicht nach Erscheinungsdatum

Schnellsuche



Zum Seitenanfang

Copyright © 1999 - 2017 Harald M. Genauck, ip-pro gmbh  /  Impressum

Zum Seitenanfang

Zurück...

Zurück...

Download Internet Explorer