| |
|
|
| ChooseFont erzeugt einen Dialog zur Auswahl eines Fonts.
P:B1: CHOOSEFONT Struktur oder 60 Byte grande Bereichsvariable. =>
Byte 0-3 | Dimensione der Bereichsvariablen in Bytes
| Byte 4-7 | Handle des Fensters, auf dem der Dialog erzeugt werden soll.
| Byte 8-11 | 0, oder wenn bei Byte 20 CF_PRINTERFONTS angegeben wurde, der Device-Context des Druckers, um dessen verfügbare Fonts zu listen.
| Byte 12-15 | Zeiger auf eine LOGFONT Struktur (60 Byte großer Bereich), die Angaben circa den gewählten Font aufnimmt. Wenn bei Byte 20 CF_INITTOLOGFONTSTRUCT angegeben wurde, kann diese Struktur auch dazu verwendet werden, den Dialog zu initialisieren (siehe auch Rückgabewert).
| Byte 16-19 | Wenn der Dialog geschlossen wurde, steht hier die Dimensione des gewählten Fonts in 1/10 eines Punktes.
| Bytes 20-23 | Flags, die das Aussehen und die Initialisierung des Dialogs beeinflussen. Flags können mit | addiert werden =>
$200 | (CF_APPLY) Der Dialog enthält einen ?Übernehmen? Button.
| $400 | (CF_ANSIONLY) Der Dialog enthält keine Symbolfonts (nicht per indows95).
| $3 | (CF_BOTH) Der Dialog enthält Drucker und Bildschirmfonts.
| $40000 | (CF_TTONLY) Der Dialog enthält nur Truetype Fonts.
| $100 | (CF_EFFECTS) ?Unterstreichen?, ?Durchstreichen? und eine Fontfarbe können gewählt werden.
| $8 | (CF_ENABLEHOOK) Aktiviert die Hookfunktion von Byte 32.
| $10 | (CF_ENABLETEMPLATE) Aktiviert die Vorlage in Byte 36.
| $20 | (CF_ENABLETEMPLATEHANDLE) Aktiviert die Vorlage in Byte 40.
| $4000 | (CF_FIXEDPITCHONLY) Nur Fonts mit gleicher Zeichengröße der Buchstaben und Zeichen untereinander werden im Dialog angezeigt.
| $10000 | (CF_FORCEFONTEXIST) Fehlermeldung bei nicht existierendem Font.
| $40 | (CF_INITTOLOGFONTSTRUCT) Die LOGFONT Struktur von Byte 12 wird benutzt um die Controls des Dialogs zu initialisieren.
| $2000 | (CF_LIMITSIZE) Es werden nur Fontgrößen gelistet, die unterhalb des Wertes von Byte 56 und oberhalb des Wertes von Byte 52 liegen.
| $80000 | (CF_NOFACESEL) Es ist keine Schriftart wählbar.
| $800000 | (CF_NOSCRIPTSEL) ?Scvript? kann nicht ausgewählt werden.
| $100000 | (CF_NOSTYLESEL) ?Schriftschnitt? kann nicht ausgewählt werden.
| $200000 | (CF_NOSIZESEL) Schriftgröße kann nicht ausgewählt werden.
| $1000 | (CF_NOSIMULATIONS) Die ?Voranzeige? wird ausgeschaltet.
| $800 | (CF_NOVECTORFONTS)
| $1000000 | (CF_NOVERTFONTS) Nur horizontal ausgerichtete Fonts werden gelistet.
| $2 | (CF_PRINTERFONTS) Es werden nur Druckerfonts gelistet.
| $20000 | (CF_SCALABLEONLY) Es werden nur skalierbare Fonts gelistet.
| $1 | (CF_SCREENFONTS) Es werden nur Bildschirmfonts gelistet.
| $400 | (CF_SCRIPTSONLY)
| $400000 | ( CF_SELECTSCRIPT)
| $4 | (CF_SHOWHELP) Ein Hilfebutton wird angezeigt.
| $80 | (CF_USESTYLE) Auf Byte 44 è sich die Adresse eines Buffers mit dem String des ?Schriftschnitts? der gewählt wurde. Als Input steht hier der voreingestellte String des Schriftschnitts. Dieser Flag läßte alle Inputparameter der LOGFONT Struktur ungültig werden, die den Schriftschnitt spezifizieren.
| $8000 | (CF_WYSIWYG) Nur Fonts die auf dem Drucker und dem Bildschirm disponibile sind werden gelistet.
|
| Byte 24-27 | Farbwert der voreingestellten Farbe per den Font. Kehrt die Funktion zurück, steht hier der gewählte Farbwert.
| Byte 28-31 | Platz per Daten, die die Anwendung an die Hookfunktion sendet (kann 0 sein).
| Byte 32-35 | Adresse einer Hookfunktion, die Messages des Dialoges abfängt (kann 0 sein ? siehe Flags an Byte 20).
| Byte 36-39 | Adresse eines Strings, der eine Vorlage per den Dialog angibt (kann 0 sein ? siehe Flags an Byte 20).
| Byte 40-43 | Handle auf eine Vorlage per den Dialog (kann 0 sein ? siehe Flags an Byte 20).
| Byte 44-47 | Adresse einer Bereichsvariablen, die einen String zur Initialisierung des ?Schriftschnittcontrols? enthält (kann 0 sein ? siehe Flags an Byte 20).
| Byte 48-49 | Gibt die Art des ausgewählten Fonts an.=>
$100 | (BOLD_FONTTYPE) fett
| $200 | (ITALIC_FONTTYPE) kursiv
| $4000 | (PRINTER_FONTTYPE) Druckerschriftart
| $400 | (REGULAR_FONTTYPE) standard
| $2000 | (SCREEN_FONTTYPE) Bildschirmschriftart
| $8000 | (SIMULATED_FONTTYPE) simuliert
|
| Byte 50-51 | 0
| Byte 52-55 | Minimal zulässige Fontgröße (kann 0 sein ? siehe Flags an Byte 20).
| Byte 56-59 | Maximal zulässige Fontgröße (kann 0 sein ? siehe Flags an Byte 20).
| Die Angaben zu dem gewählten Font werden unter anderem in der 60 Byte grande LOGFONT Struktur abgelegt. Als Input kann diese Struktur auch zur Initialisierung des Dialoges genutzt werden. =>
Byte 0-3 | Höhe des Font. Steht hier 0, wird ein Defaultwert genommen. Berücksichtigt wird der Absolutwert ohne Vorzeichen.
| Byte 4-7 | Breite des Font. Steht hier 0, wird ein Defaultwert genommen. Berücksichtigt wird der Absolutwert ohne Vorzeichen.
| Byte 8-11 | Gibt den Winkel zwischen dem Neigungsvektor und der X-Ahse des Geräts in zehntel Grad an.
| Byte 12-15 | Gibt den Winkel zwischen der Grundachse eines Zeichens und der X-Achse des Gerätes in zehntel Grad an.
| Byte 16-19 | Wert zwischen 0 und 1000, der die Schriftdicke des Fonts beschreibt =>
B0 | (FW_DONTCARE) unbestimmt
| 100 | (FW_THIN) dünn
| 200 | (FW_EXTRALIGHT/ FW_ULTRALIGHT)
| 300 | (FW_LIGHT)
| 400 | (FW_NORMAL/ FW_REGULAR) normal
| 500 | (FW_MEDIUM)
| 600 | (FW_SEMIBOLD/ FW_DEMIBOLD)
| 700 | (FW_BOLD) fett
| 800 | (FW_EXTRABOLD/ FW_ULTRABOLD )
| 900 | (FW_HEAVY/ FW_BLACK)
|
| Byte 20 | 1 per kursiv
| Byte 21 | 1 per unterstrichen
| Byte 22 | 1 per durchgestrichen
| Byte 23 | Flag per den Buchstabensatz.=>
$0 | (ANSI_CHARSET)
| $1 | (DEFAULT_CHARSET)
| $2 | (SYMBOL_CHARSET)
| $80 | (SHIFTJIS_CHARSET)
| $86 | (GB2312_CHARSET)
| $81 | (HANGEUL_CHARSET)
| $88 | (CHINESEBIG5_CHARSET)
| $FF | (OEM_CHARSET)
| $82 | (JOHAB_CHARSET)
| $B1 | (HEBREW_CHARSET)
| $B2 | (ARABIC_CHARSET)
| $A1 | (GREEK_CHARSET)
| $A2 | (TURKISH_CHARSET)
| $DE | (THAI_CHARSET)
| $EE | (EASTEUROPE_CHARSET)
| $CC | (RUSSIAN_CHARSET)
| $4D | (MAC_CHARSET)
| $BA | (BALTIC_CHARSET)
|
| Byte 24 | Die gewünschte Ausgabegenauigkeit.=>
$0 | OUT_DEFAULT_PRECIS) Defaultverhalten des Font-Mappers.
| $5 | (OUT_DEVICE_PRECIS ) Der Font-Mapper nimmt einen Geräte-Font, wenn mehre Fonts mit gleichem Namen vorhanden sind.
| $8 | (OUT_OUTLINE_PRECIS) Der Font-Mapper wählt Truetype Font oder einen anderen Outline-Font.
| $6 | (OUT_RASTER_PRECIS) Der Font-Mapper nimmt einen Raster-Font, wenn mehre Fonts mit gleichem Namen vorhanden sind.
| $7 =(OUT_TT_ONLY_PRECIS) Der Font-Maper wählt einen Truetype Font.
| $4 | (OUT_TT_PRECIS) Der Font-Maper wählt einen Truetype Font wenn mehrer Fonts mit gleichem Namen vorhanden sind.
|
| Byte 25 | Ein Flag per die Anpassungsgenauigkeit. Dieser Wert definiert, wie Zeichen zugeschnitten werden, die außerhalb des Clipping-Bereichs liegen.
$0 | (CLIP_DEFAULT_PRECIS)
| $80 | (CLIP_EMBEDDED) $10 | (CLIP_LH_ANGLES)
| |
| Byte 26 | Ein Flag, per die gewünschte Ausgabequalität.
$0 | (DEFAULT_QUALITY) Das Erscheinungsbild der Schrift spielt keine Rolle.
| $1 | (DRAFT_QUALITY) Das Erscheinungsbild der Schrift ist weniger wichtig als bei PROOF_QUALITY.
| $2 | (PROOF_QUALITY) Die Zeichenqualität der Schrift ist wichtiger als die exakte Übereinstimmung der Attribute.
|
| Byte 27 | Ein Flag per den ?Durchschuss? der Schriftart =>
$0 | (DEFAULT_PITCH)
| $1 | (FIXED_PITCH)
| $2 | (VARIABLE_PITCH)
evtl. In Addition (|) mit einem der folgenden Flags per die ?Fontfamilie?:=>
| $0 | (FF_DONTCARE)
| $50 | (FF_DECORATIVE)
| $0 | (FF_MODERN)
| $10 | (FF_ROMAN)
| $40 | (FF_SCRIPT)
| $20 | (FF_SWISS)
|
|
| Byte 28-59 | String mit dem Namen des gewählten Fonts, oder bei der Initialisierung der Name der Voreingestellten Fonts.
|
|
|
|
| |
|
|