AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Delphi 11 Standard Schriftgrad

Ein Thema von Michael II · begonnen am 23. Okt 2021 · letzter Beitrag vom 24. Okt 2021
 
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.629 Beiträge
 
Delphi 12 Athens
 
#8

AW: Delphi 11 Standard Schriftgrad

  Alt 24. Okt 2021, 13:48
Vielleicht muss man mal genauer auf das DPI-Handling der VCL und das Verhalten bei den unterschiedlichen DPI-Einstellungen des Designers schauen. Das ganze natürlich nur, wenn die IDE DPI-aware gestartet wird.

Bei einem Font gibt es ja zwei Properties, mit denen man die Größe einstellen kann:
  • Height (in Pixeln)
  • Size (in Punkt, wobei 1 Pt = 72 PPI)
Size und Height haben immer entgegengesetzte Vorzeichen.

Die Umrechnung erfolgt mit dem Font-Property PixelsPerInch, das mit ScreenLogPixels vorbelegt wird. ScreenLogPixels wiederum wird mit GetDeviceCaps(DC, LOGPIXELSY) für den primären Monitor initialisiert.

Die neue Standardschrift ist Segoe UI 9pt, was bei einem primären Monitor mit 175% Scaling zu einem PixelsPerInch von 168 (96*1,75) und einer Height von 21 (9*168/72) führt.

Läuft die IDE also auf dem primären Monitor und die Designer High-DPI Einstellung ist Automatisch (Bildschirm-PPI) und man erzeugt eine neue VCL-Anwendung, dann hat das Form eine Font.Size von 9 und eine Font.Height von -21.

Stellt man den High-DPI Mode auf Low DPI (96 PPI), wird das Form runterskaliert als liefe es mit einem 100% Scaling auf 96 PPI. Dabei bleibt aber der PixelsPerInch-Wert des Fonts gleich und aus der Height -21 eine -12, was nach Umrechnung in Punkt (21*72/168) eine gerundete 5 ergibt.

Diese Fixierung des PixelsPerInch Wertes von TFont auf den anfänglichen Skalierungswertes des primären Monitors passt m.E. nicht zu dem Handling von PixelsPerInch der Controls. Das führt schon zu Merkwürdigkeiten beim Verschieben eins Forms auf einen Monitor mit anderem Scaling (oder auch Ändern des Scalings beim primären Monitor). In dem Fall passt das Form zwar seinen PixelsPerInch Wert an, aber der Font ändert lediglich die Height und damit indirekt auch die Size.

Es hat schon mehrere Diskussionen gegeben, in so einem Fall einfach den PixelsPerInch Wert anzupassen und den Size Wert beizubehalten anstatt nur den Height Wert zu skalieren. Dann wäre Size eine DPI-invariante Größe und PixelsPerInch entspräche immer dem des Ziel-Devices. Die Meinungen sind da sehr vielfältig und häufig von Ängsten vor Inkompatibilität der eigenen Software begleitet. Mal sehen wie sich das entwickelt.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
 


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 00:24 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz