Manchmal kommt man nicht darum herum, Schriftarten mit gleicherBuchstabenbreite zu verwenden. Sei es, weil etwas auf einem Drucker in Spaltenordentlich untereinander ausgedruckt haben möchte, oder dass man in einemControl, das Tabulatoren nicht unterstützt, etwas entsprechend anzeigen will. Die einzige Schriftart die diese Kriterien erfüllt, die fast jeder auswendigkennt, ist die Courier. Und genau die möchte man nicht verwenden. Also - wasgibt es noch? Hierzu muss man den schmalsten Buchstaben mit dem breitesten Buchstaben derSchriften vergleichen, d. h. man vergleicht i mit m. Um dasauszuprobieren benötigen Sie ein neues Projekt mit einer ListBox (List1) undeinem CommandButton (Command1). Dann noch folgenden Code: Option Explicit Private Declare Function SendMessage Lib "user32" _ Alias "SendMessageA" ( _ ByVal hwnd As Long, _ ByVal wMsg As Long, _ ByVal wParam As Long, _ ByVal lParam As String) As Long Private Const LB_FINDSTRINGEXACT = &H1A2 Private Sub Command1_Click() ' Propotionale Schriften ermitteln Dim i As Integer Dim sFont As String ' ursprüngliche Schrift merken sFont = Me.Font.Name ' Bildschirmschriften For i = 0 To Screen.FontCount - 1 Me.Font.Name = Screen.Fonts(i) If TextWidth("i") = TextWidth("m") Then List1.AddItem Screen.Fonts(i) End If Next i ' jetzt noch die Druckerschriften For i = 0 To Printer.FontCount - 1 Me.Font.Name = Printer.Fonts(I) If SendMessage(List1.hwnd, LB_FINDSTRINGEXACT, -1, Printer.Fonts(i)) Then If TextWidth("i") = TextWidth("m") Then List1.AddItem Printer.Fonts(i) End If End If Next i ' ursprüngliche Schrift wiederherstellen Me.Font.Name = sFont End Sub Wenn Sie jetzt ihr Projekt starten und auf den CommandButton klicken, werdenIhnen sämtliche auf dem Computer verfügbaren Schriften mit gleicherBuchstabenbreite aufgelistet. Diese Seite wurde bereits 10.427 mal aufgerufen. |
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... Buchempfehlung Tipp des Monats Mai 2024 Hermann Röttger Wochentage eines Datumsbereichs ermitteln Wochentage eines Datumsbereichs ermitteln, optional mit Feiertagsberechnung TOP Entwickler-Paket TOP-Preis!! Mit der Developer CD erhalten Sie insgesamt 24 Entwickler- komponenten und Windows-DLLs. Die Einzelkomponenten haben einen Gesamtwert von 1605.50 EUR... |
||||||||||
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. |