Solved Scaling text without squashing it horizontally
-
I need to scale text in my project, but I don't like the way it looks when it's scaled horizontally without being scaled down vertically too.
For example, HISE deals with the line under "30 Divisions of the Octave" like this:
Whereas I'd want it to look more like this:
Is there a way to do achieve this?
-
@cynthasiser If it's in a label change the height of the label. If it's in a paint routine change the height of the area.
-
@d-healey that doesn't change the scaling though? it only changes how much of the text is visible:
(the example is in a label)
-
@cynthasiser Post a snippet
-
@d-healey I'm not sure what the snippet would show? It's standard HISE behaviour (at least on my computer) that text boxes try to scale text horizontally but not vertically.
-
@cynthasiser I see the issue. If changing the font size doesn't help you'll need to draw it in a panel instead of using a label.
-
You get the same horizontal squishing behaviour even in a panel though:
Updating the font size would work, but I'd have to somehow know exactly how many pixels the text would take up to know if I needed to scale it down.
e.g.
If I had a text box that's 200 pixels wide and the sentence "the quick brown fox jumped over the lazy dog" in Arial at 20pt size. Let's pretend this sentence would take up 220 pixels of screen space. I'd want to write a for loop that keeps decreasing the font size until the sentence was less than 200 pixels wide.But how would I check the "pixel width" of a given text string in a given font?
-
@cynthasiser said in Scaling text without squashing it horizontally:
But how would I check the "pixel width" of a given text string in a given font?
g.getStringWidth()
-
@d-healey ah that's great news, I'll give it a go! thank you!
-
Yep, that's perfect, thanks!
-