Vor kurzem hatten wir Ihnen ein Tipp vorgestellt, mit dem sich ein Bildsymbol im Eingabefeld einer ComboBox anzeigen lässt. Das Grundgerüst dieses Tipps machen wir uns heute zu Nutzen, um anstelle eines Bildsymbols eine CheckBox in der ComboBox anzuzeigen. Die CheckBox verwenden wir dann, um die Auswahl eines Eintrags aus der ComboBox durch den User zu aktivieren bzw. zu sperren. D.h.: ist die CheckBox markiert, darf der Anwender einen Eintrag aus der ComboBox auswählen. Andernfalls soll die Auswahl gesperrt werden. Erstellen Sie ein neues Projekt und platzieren auf die Form ein ComboBox-Control (ComboBox1), sowie ein CheckBox-Control (CheckBox1). Fügen Sie anschließend nachfolgenden Code ein: Public Class Form1 ' benötigte API-Deklarationen Private Declare Function SendMessage Lib "user32" _ Alias "SendMessageA" ( _ ByVal hwnd As IntPtr, _ ByVal wMsg As Integer, _ ByVal wParam As Integer, _ ByVal lParam As Integer) As Integer Private Declare Function FindWindowEx Lib "user32" _ Alias "FindWindowExA" ( _ ByVal hwndParent As IntPtr, _ ByVal hwndChildAfter As IntPtr, _ ByVal lpszClass As String, _ ByVal lpszWindow As String) As Integer Private Const EC_LEFTMARGIN = &H1 Private Const EM_SETMARGINS = &HD3 ' CheckBox im Eingabefeld einer ComboBox anzeigen Public Sub ComboBox_AddCheckBox(ByVal oForm As Form, _ ByVal oComboBox As ComboBox, _ ByVal oCheckBox As CheckBox) Dim nHWnd As IntPtr Dim nLeft As Integer ' Handle des Eingabefeldes der Combo-TextBox ermitteln With oComboBox nHWnd = FindWindowEx(.Handle.ToInt32, 0, "EDIT", vbNullString) If (nHWnd <> 0) Then ' CheckBox-Eigenschaften festlegen With oCheckBox .Text = "" .BackColor = .BackColor .TabStop = False .AutoSize = False .Size = New Size(13, 13) End With ' CheckBox in das Eingabefeld platzieren oCheckBox.Location = New Point(.Left + 4, .Top + 4) oCheckBox.BringToFront() ' linken Rand des Eingabefeldes der ComboBox neu festlegen nLeft = oCheckBox.Width + 3 Call SendMessage(nHWnd, EM_SETMARGINS, EC_LEFTMARGIN, nLeft) End If End With End Sub Private Sub Form1_Load(ByVal sender As System.Object, _ ByVal e As System.EventArgs) Handles MyBase.Load ' CheckBox in die ComboBox platzieren ComboBox_AddCheckBox(Me, ComboBox1, CheckBox1) CheckBox1.Checked = True ' ein paar Testeinträge For i As Integer = 1 To 10 ComboBox1.Items.Add("Eintrag " & CStr(i)) Next End Sub Private Sub CheckBox1_CheckedChanged(ByVal sender As System.Object, _ ByVal e As System.EventArgs) ' ComboBox aktivieren/deaktivieren ComboBox1.Enabled = (CheckBox1.Checked) End Sub End Class Dieser Tipp wurde bereits 15.646 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. |
sevISDN 1.0 Überwachung aller eingehender Anrufe! Die DLL erkennt alle über die CAPI-Schnittstelle eingehenden Anrufe und teilt Ihnen sogar mit, aus welchem Ortsbereich der Anruf stammt. Weitere Highlights: Online-Rufident, Erkennung der Anrufbehandlung u.v.m. Tipp des Monats Juni 2024 Microsys Kramer Mausrad im Formular abschalten (Access) Deaktiviert das Mausrad in Access-Formularen. sevZIP40 Pro DLL Zippen und Unzippen wie die Profis! Mit nur wenigen Zeilen Code statten Sie Ihre Anwendungen ab sofort mit schnellen Zip- und Unzip-Funktionen aus. Hierbei lassen sich entweder einzelnen Dateien oder auch gesamte Ordner zippen bzw. entpacken. |
||||||||||||||||
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. |