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.120 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! sevPopUp 2.0 Dynamische Kontextmenüs! Erstellen Sie mit nur wenigen Zeilen Code Kontextmenüs dynamisch zur Laufzeit. Vordefinierte Styles (XP, Office, OfficeXP, Vista oder Windows 8) erleichtern die Anpassung an die eigenen Anwendung... 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. |