AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Multimedia Delphi font.size - font.height - Negative Werte - Schlechte Doku
Thema durchsuchen
Ansicht
Themen-Optionen

font.size - font.height - Negative Werte - Schlechte Doku

Ein Thema von bernau · begonnen am 6. Dez 2022 · letzter Beitrag vom 7. Dez 2022
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von bernau
bernau

Registriert seit: 1. Dez 2004
Ort: Köln
1.295 Beiträge
 
Delphi 12 Athens
 
#1

font.size - font.height - Negative Werte - Schlechte Doku

  Alt 6. Dez 2022, 13:16
Da ich mich grade mit Fonts beschäftige, fällt mir eine schon lange vergessene Frage wieder ein.

Font.size hat in der Regel einen Positiven Wert. Entsprechend hat font.height einen negativen Wert. In der Doku steht folgendes.

Zitat:
Mit Size legen Sie die Punktgröße der Schrift fest. Bei einem negativen Wert wird der interne Abstand über den einzelnen Textzeilen berücksichtigt. Bei einem positiven Wert ist Size die Schrifthöhe ohne den internen Abstand.
Definiere für mich jemand mal den "internen Abstand" über der Textzeile.

Auch wenn ich die Bedeutung von "internen Abstand" nicht verstehe, ist es für mich nur logisch, dass es zwei unterschiedliche Texthöhen geben muss. Wahrscheinlich einmal der "schöne" Abstand zwischen zwei Zeilen. Zwei Zeilen untereinander brauchen immer einen kleinen Abstand um gut lesbar zu sein. Zum anderen würde ich die tatsächliche Höhe, also die Oberkante von dem höchsten Buchstaben.

Ganz unlogisch ist aber bei Angabe eines negativen Wertes für Size, dass der Text kleiner gezeichnet wird. Eigentlich erwarte ich, egal ob Size 13 oder -13 ist, der gezeichnete Text entspricht 13pt, nur der "Rahmen" um den Text sollte sich verändern.

Hier mal ein kleines Testprogramm. (Paintbox auf eine Form und den Code zufügen. Im Anhang ist der Screenshot zum Programm)

Delphi-Quellcode:
procedure TFormFontTest1.PaintBox1Paint(Sender: TObject);
begin
  PaintTextToCanvas(PaintBox1.Canvas,0,0,20,'(Gg) Size = 20');
  PaintTextToCanvas(PaintBox1.Canvas,200,0,-20,'(Gg) Size = -20');
end;

Function TFormFontTest1.PaintTextToCanvas(const aCanvas:TCanvas;const aX:Integer;const aY:Integer;const aSize:Integer;const aText:String): TRect;
begin
  aCanvas.font.Size := aSize;

  Result.Width := aCanvas.TextWidth(aText);
  Result.Height := aCanvas.TextHeight(aText);

  aCanvas.Brush.Color := clRed;
  aCanvas.Rectangle(aX,aY,aX+Result.Width,aY+Result.Height);

  aCanvas.Brush.Color := clBlack;
  aCanvas.Brush.Style := bsClear;
  aCanvas.TextOut(aX,aY,aText);
end;
Hat jemand von euch den Sinn verstanden?
Miniaturansicht angehängter Grafiken
bild_2022-12-06_131233843.png  
Gerd
Kölner Delphi Usergroup: http://wiki.delphitreff.de
  Mit Zitat antworten Zitat
Benutzerbild von Sherlock
Sherlock

Registriert seit: 10. Jan 2006
Ort: Offenbach
3.800 Beiträge
 
Delphi 12 Athens
 
#2

AW: font.size - font.height - Negative Werte - Schlechte Doku

  Alt 6. Dez 2022, 13:48
Was den "internen Abstand" angeht, könnte das hier helfen: https://en.wikipedia.org/wiki/Leading. Auch die msdn gibt etwas mehr Infos dazu: https://learn.microsoft.com/en-us/wi...di-createfonta

Aber ich bin kein Schriftsetzer...

Sherlock
Oliver
Geändert von Sherlock (Morgen um 16:78 Uhr) Grund: Weil ich es kann
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
9.646 Beiträge
 
Delphi 11 Alexandria
 
#3

AW: font.size - font.height - Negative Werte - Schlechte Doku

  Alt 6. Dez 2022, 14:00
Ganz unlogisch ist aber bei Angabe eines negativen Wertes für Size, dass der Text kleiner gezeichnet wird. Eigentlich erwarte ich, egal ob Size 13 oder -13 ist, der gezeichnete Text entspricht 13pt, nur der "Rahmen" um den Text sollte sich verändern.
Nein, das ist nicht unlogisch. Du gibst zwar mit der Größe an, wie groß ein Text gezeichnet werden soll, aber die Frage ist, wie die Umgebung dabei aussieht, ob du dich selbst um die Abstände außen herum kümmerst (z.B. stehen Klammern ja aus dem normalen Text heraus). Das Vorzeichen gibt an, ob dabei der Abstand mit in deiner Angabe enthalten ist oder nicht.

Vielleicht wird es mit dem Quelltext klarer:
Delphi-Quellcode:
procedure TFormFontTest1.PaintBox1Paint(Sender: TObject);
begin
  PaintTextToCanvas(PaintBox1.Canvas,0,0,20,'(Gg) Size = 20 - Ein Test');
  PaintTextToCanvas(PaintBox1.Canvas,0,20,20,'(Gg) Size = 20 - Ein Test');
  PaintTextToCanvas(PaintBox1.Canvas,0,40,20,'(Gg) Size = 20 - Ein Test');
  PaintTextToCanvas(PaintBox1.Canvas,400,0,-20,'(Gg) Size = -20 - Ein Test');
  PaintTextToCanvas(PaintBox1.Canvas,400,20,-20,'(Gg) Size = -20 - Ein Test');
  PaintTextToCanvas(PaintBox1.Canvas,400,40,-20,'(Gg) Size = -20 - Ein Test');
end;

Function TFormFontTest1.PaintTextToCanvas(const aCanvas:TCanvas;const aX:Integer;const aY:Integer;const aSize:Integer;const aText:String): TRect;
begin
  aCanvas.font.Size := aSize;

  Result.Width := aCanvas.TextWidth(aText);
  Result.Height := aCanvas.TextHeight(aText);

  aCanvas.Brush.Color := clRed;
// aCanvas.Rectangle(aX,aY,aX+Result.Width,aY+Result.Height);

  aCanvas.Brush.Color := clBlack;
  aCanvas.Brush.Style := bsClear;
  aCanvas.TextOut(aX,aY,aText);
end;
Ergebnis:
2022-12-06.png

Wenn du Height statt Size verwendest, stehen auch Akzente oder Buchstaben wie j nicht mehr aus der angegebenen Höhe heraus.
Sebastian Jänicke
AppCentral

Geändert von jaenicke ( 6. Dez 2022 um 14:04 Uhr)
  Mit Zitat antworten Zitat
Thomasl

Registriert seit: 19. Jun 2006
Ort: Vreden
67 Beiträge
 
Delphi 11 Alexandria
 
#4

AW: font.size - font.height - Negative Werte - Schlechte Doku

  Alt 6. Dez 2022, 14:39
Font über Size einstellen macht bei HiDPI nur Probleme
Delphi-Quellcode:

function FontHeightDpi(const Size: Integer; const Dpi: Integer): Integer;
begin
  Result := -MulDiv(Size, Dpi, 72);
end;


Function TFormFontTest1.PaintTextToCanvas(const aCanvas:TCanvas;const aX:Integer;const aY:Integer;const aSize:Integer;const aText:String): TRect;
begin
  aCanvas.font.Height := FontHeightDpi(aSize, PixelsPerInch);

...
Thomas Levering
  Mit Zitat antworten Zitat
Benutzerbild von bernau
bernau

Registriert seit: 1. Dez 2004
Ort: Köln
1.295 Beiträge
 
Delphi 12 Athens
 
#5

AW: font.size - font.height - Negative Werte - Schlechte Doku

  Alt 6. Dez 2022, 14:46
Wenn du deinen Code auf einem Medium mit anderer Auflösung (Drucker) ausgibst, dann sieht das Ergebnis wiederum ganz anders aus.
Das ist aber eher dem Zufall geschuldet, weil der Bildschirm 96dpi verwendet und die height mit dem Wert 72 berechnet wird.

Font.Height = -Font.Size * Font.PixelsPerInch {96} / 72

Wenn du deinen Code auf einem Medium mit anderer Auflösung (Drucker) ausgibst, dann sieht das Ergebnis wiederum ganz anders aus.
Miniaturansicht angehängter Grafiken
bild_2022-12-06_144312912.png  
Gerd
Kölner Delphi Usergroup: http://wiki.delphitreff.de
  Mit Zitat antworten Zitat
Benutzerbild von Sherlock
Sherlock

Registriert seit: 10. Jan 2006
Ort: Offenbach
3.800 Beiträge
 
Delphi 12 Athens
 
#6

AW: font.size - font.height - Negative Werte - Schlechte Doku

  Alt 6. Dez 2022, 14:49
Absolute Pixelwerte taugen in unterschiedlichen DPI unterschiedlich wenig. Bei der Positionierung immer die DPI mit einbeziehen.

Sherlock
Oliver
Geändert von Sherlock (Morgen um 16:78 Uhr) Grund: Weil ich es kann
  Mit Zitat antworten Zitat
Benutzerbild von bernau
bernau

Registriert seit: 1. Dez 2004
Ort: Köln
1.295 Beiträge
 
Delphi 12 Athens
 
#7

AW: font.size - font.height - Negative Werte - Schlechte Doku

  Alt 6. Dez 2022, 14:51
Font über Size einstellen macht bei HiDPI nur Probleme
Das kommt noch hinzu. Ist aber eher einem Bug bei Font.PixelsPerInch geschuldet, welches ja zur Berechnung zwischen Font.Height und Font.Size verwendet wird.
Gerd
Kölner Delphi Usergroup: http://wiki.delphitreff.de
  Mit Zitat antworten Zitat
Benutzerbild von bernau
bernau

Registriert seit: 1. Dez 2004
Ort: Köln
1.295 Beiträge
 
Delphi 12 Athens
 
#8

AW: font.size - font.height - Negative Werte - Schlechte Doku

  Alt 6. Dez 2022, 14:55
Was den "internen Abstand" angeht, könnte das hier helfen: https://en.wikipedia.org/wiki/Leading. Auch die msdn gibt etwas mehr Infos dazu: https://learn.microsoft.com/en-us/wi...di-createfonta

Aber ich bin kein Schriftsetzer...

Sherlock
Dein Wikipedia-Link bestätigt ja meine Vermutung, dass der zusätzliche Abstand zwischen zwei Textzeilen gemeint ist, der dann entweder inkludiert ist (positives Vorzeichen) oder excludiert ist (negatives Vorzeichen). Was aber wiederum bedeutet, dass die Änderung der Schriftgröße unfug ist.
Gerd
Kölner Delphi Usergroup: http://wiki.delphitreff.de
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

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

AW: font.size - font.height - Negative Werte - Schlechte Doku

  Alt 6. Dez 2022, 15:07
Dein Wikipedia-Link bestätigt ja meine Vermutung, dass der zusätzliche Abstand zwischen zwei Textzeilen gemeint ist, der dann entweder inkludiert ist (positives Vorzeichen) oder excludiert ist (negatives Vorzeichen). Was aber wiederum bedeutet, dass die Änderung der Schriftgröße unfug ist.
Wieso Unfug? Wenn Height (was ja intern auch über Size gesetzt wird) einen Wert mit oder ohne den Abstand angibt, dann muss zwingend die Schrift kleiner oder größer sein. Bei Angabe von Size ±13pt ist entweder die Zeichengröße gemeint oder die Größe der Zelle, was ja eine kleinere Zeichengröße impliziert.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von bernau
bernau

Registriert seit: 1. Dez 2004
Ort: Köln
1.295 Beiträge
 
Delphi 12 Athens
 
#10

AW: font.size - font.height - Negative Werte - Schlechte Doku

  Alt 6. Dez 2022, 16:24
Wieso Unfug? Wenn Height (was ja intern auch über Size gesetzt wird) einen Wert mit oder ohne den Abstand angibt, dann muss zwingend die Schrift kleiner oder größer sein. Bei Angabe von Size ±13pt ist entweder die Zeichengröße gemeint oder die Größe der Zelle, was ja eine kleinere Zeichengröße impliziert.
Dann ist es meines erachtens grundsätzlich eine irreführende Implementation.

Wenn ich in einer Textverarbeitung für eine Schrift 13pt auswähle, dann gibt es genau eine Größe. Ich kann bei Word, LibreOffice und co. nicht angeben, ob ich die kleinere oder die größere Version von 13pt haben möchte.

Wenn ich mit Delphi ein Zeichenprogramm schreibe, dann erwartet der Anwender zurecht, dass eine gedruckte 13pt Schrift genau so groß ist, wie bei einem Ausdruck mit InDesign.
Gerd
Kölner Delphi Usergroup: http://wiki.delphitreff.de
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 15:35 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz