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.117 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. |
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. Tipp des Monats März 2024 Dieter Otter UTF-8 Konvertierung von Dateien und Strings VB6 selbst verfügt über keine Funktionen zur UTF-8 Konvertierung von Daten. Mit Hilfe des ADODB.Stream-Objekts lassen sich diese fehlenden Funktionen aber schnell nachrüsten. Access-Tools Vol.1 Über 400 MByte Inhalt Mehr als 250 Access-Beispiele, 25 Add-Ins und ActiveX-Komponenten, 16 VB-Projekt inkl. Source, mehr als 320 Tipps & Tricks für Access und VB |
||||||||||||||||
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. |