Das nachfolgende Beispiel zeigt, wie sich ein PopUp-Menü realisieren und aufrufen lässt, welches alle auf dem System installierten Schriften anzeigt. Zusätzlich wird im PopUp-Menü die aktuell gewählte Schrift mit einem Häkchen gekennzeichnet. Beim Beenden des Formulars lässt sich die zuletzt eingestellte Schrift speichern und kann so bei Bedarf bei einem erneuten Formular-Aufruf gleich wieder eingestellt werden. Wie funktioniert das? Im Form_Load-Ereignis wird das Schriftarten-Menü zur Laufzeit erzeugt. Im Click-Ereignis des entsprechenden Buttons wird das Menü dann per PopUpMenu-Anweisung an der aktuellen Mausposition angezeigt. Private Sub Form_Load() ' Schriften ermitteln und in Array speichern Dim sFont() As String Dim nCount As Long Dim i As Long Dim F As Integer Dim sOldFont As String ' Bildschirmschriften nCount = Screen.FontCount ReDim Preserve sFont(nCount) For i = 0 To Screen.FontCount - 1 sFont(i + 1) = Screen.Fonts(i) Next i ' Druckerschriften For i = 0 To Printer.FontCount - 1 If Not IsInArray(sFont, Printer.Fonts(i)) Then nCount = nCount + 1 ReDim Preserve sFont(nCount) sFont(nCount) = Printer.Fonts(i) End If Next i ' Schrift-Array alphabetisch sortieren BSort sFont(), 0 ' zuletzte verwendete Schrift ermitteln sOldFont = Text1.Font.Name If Dir$(App.Path & "\font.dat", vbNormal) <> "" Then F = FreeFile Open App.Path & "\font.dat" For Input As #F Line Input #F, sOldFont Close #F ' zuletzt verwendete Schriftart zuweisen Text1.Font.Name = sOldFont End If ' PopUp-Menü erstellen For i = 0 To nCount - 1 ' Ggf. Menu-Element laden If i > 0 Then Load mnuFont(i) ' Caption (Menütext) mnuFont(i).Caption = sFont(i + 1) ' wenn aktueller Schrifteintrag = Standard-Schrift mnuFont(i).Checked = (sFont(i + 1) = sOldFont) Next i End Sub ' PopUp-Menü anzeigen Private Sub cmdFont_Click() ' Schriften-PopUp-Menü anzeigen PopupMenu PopUpFont End Sub ' Neue Schrift ausgewählt Private Sub mnuFont_Click(Index As Integer) Dim i As Integer Dim F As Integer ' Beispiel: TextBox in neuer Schrift anzeigen Text1.Font.Name = mnuFont(Index).Caption ' Neue Schrift als Standard setzen For i = 0 To mnuFont.Ubound mnuFont(i).Checked = (i = Index) Next i ' Gewählte Schrift speichern On Local Error Resume Next F = FreeFile Open App.Path & "\font.dat" For Output As #F Print #F, mnuFont(Index).Caption Close #F End Sub Hilfsroutinen ' Prüft, ob der String bereits im Array-Feld vorhanden Public Function IsInArray(ByRef sArray() As String, _ sString As String) As Boolean Dim i As Integer IsInArray = False For i = LBound(sArray) To UBound(sArray) If sArray(i) = sString Then IsInArray = True Exit For End If Next i End Function ' BubbleSort-Routine Private Sub BSort(SortField As Variant, Modus) Dim i As Long Dim Flag As Boolean Dim z As Variant Do Flag = True For i = 0 To UBound(SortField, 1) - 1 If Modus = 0 Then ' aufsteigende Sortierung If SortField(i) > SortField(i + 1) Then z = SortField(i) SortField(i) = SortField(i + 1) SortField(i + 1) = z Flag = False End If Else ' absteigende Sortierung If SortField(i) < SortField(i + 1) Then z = SortField(i) SortField(i) = SortField(i + 1) SortField(i + 1) = z Flag = False End If End If Next i Loop Until Flag = True End Sub Dieser Tipp wurde bereits 19.138 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 April 2024 Skyfloy Chart von Microsoft und dazu noch gratis Tutorial für Microsoft Chart Controls für Microsoft .NET Framework 3.5 Neu! sevDTA 3.0 Pro SEPA mit Kontonummernprüfung Erstellen von SEPA-Dateien mit integriertem BIC-Verzeichnis und Konto- nummern-Prüfverfahren, so dass ungültige Bankdaten bereits im Vorfeld ermittelt werden können. |
||||||||||||||||
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. |