Canvas Texte verschiedener Größen auf einer Linie ausgeben?
4. Jan 2014, 20:02
Wie der Titel schon aussagt, ich möchte Texte mit verschiedenen Größen auf einer Grundlinie ausgeben, also wie es jede beliebige Textverarbeitung auch macht. Die Standardmöglichkeiten bieten nur die Möglichkeit die Texte auf gleicher Höhe auszugeben.
AW: Canvas Texte verschiedener Größen auf einer Linie ausgeben?
4. Jan 2014, 21:49
Danke, kam gerade durch stöbern in der Api auch auf SetTextAlign. Insoweit klappt es jetzt. Wobei wir dann aber beim nächsten Problem wären, denn einerseits soll der Text auf der gleichen Grundlinie sein, auf der anderen Seite hat es eine Oberkannte. Somit müsste ich jetzt die Höhe haben...
AW: Canvas Texte verschiedener Größen auf einer Linie ausgeben?
4. Jan 2014, 21:57
Ok, vielen Dank. Die offene Frage habe ich mir anscheinend schon vorher selbst beantwortet. Die größte Schrift bildet die Oberkannte, womit man nur die Höhe der der größte Schrift ermitteln muss und die dann abziehen. So kann man dann auch die Oberkannte einhalten.
AW: Canvas Texte verschiedener Größen auf einer Linie ausgeben?
4. Jan 2014, 22:21
Die Oberkante und Unterlänge beziehen sich auf den Schriftkegel, in der Delphihilfe als Boundingbox bezeichnet.
D.h. Oberkante (TA_TOP) ist Versalhöhe PLUS Versalakzent, bei kleinen Schriftgrößen kaum zu unterscheiden.
Die Unterlänge (TA_BOTTOM) ebenso Kegel (Boundingbox), d.h. Unterlänge PLUS Mindestdurchschuß (compress), bei kleinen Schriftgrößen auch kaum zu unterscheiden.
Nur die BaseLine bezieht sich wirklich auf die Schrift (den Buchstaben) selbst.
AW: Canvas Texte verschiedener Größen auf einer Linie ausgeben?
5. Jan 2014, 09:59
Ok, ich hab noch ein Problem. Was ich mache könnte man fast mit Zeilen in einem Textverarbeitungsprogramm zu vergleichen. Zeilen werden von oben nach unten aneinander gedeiht, eben wie auch in einem TVP. Das Problem ist aber, dass die Schrift auch ganz groß werden kann, u. U. auch 200pt. Was nun bei kleinem Schriftgrad kaum auffällt, macht hier schon paar hundert Pixel aus (siehe Bild).
SetTextAlign(Canvas.Handle, TA_BASELINE) erfüllt seinen Zweck, d. h. alle Texte werden auf der Grundlinie ausgerichtet, aber dabei entsteht oben eine Lücke. Bei großer Schrift ist die Lücke gewaltig, und das erkennt man auch. Das müsste ich nun ausgleichen, die Frage ist nur wie. Das rote Rechteck zeigt die Grenzen die Canvas.TextExtent liefert. Die weiße Hintergrundfarbe zeigt die Fläche die der Text eigentlich ausfüllt. Da ist eine Lücke. Wüßte ich die zweite Unterkannte (die erste kenne ich), könnte ich es ausgleichen. Was mir also fehlt ist der Abstand zwischen der Grundlinie und der Unterkante. Weiß einer wie man sowas über die Schrift erfahren kann?
AW: Canvas Texte verschiedener Größen auf einer Linie ausgeben?
5. Jan 2014, 11:43
Ok, ich hab weiter in der Api gestöbert und GetTextMetrics gefunden. Ich denke tmAscent und tmDescent liefern das was ich brauche. tmDescent ist die Unterlänge und entspricht dabei der Lücke die mir Probleme bereitete.
Falls es später einem auch mal interessiert, hier die Prozedur mit der ich etwas experimentiert habe: