On Sun, Jun 16 2024 at 12:30:51 +02:00:00, Johannes Sixt <j6t@xxxxxxxx>
wrote:
Am 15.06.24 um 10:53 schrieb Serhii Tereshchenko:
This fixes font scaling for default fonts, where we don't set font
sizes explicitly.
Without this, on 4k monitor with text-scaling-factor configured in
Gnome,
labels, buttons and settings are using very small font sizes.
(Probably,
not just Gnome but anything that sets custom DPI).
Screenshots here:
https://twiukraine.com/@partizan/112619567918546426
Signed-off-by: Serhii Tereshchenko <serg.partizan@xxxxxxxxx>
Thank you. I have adjusted the title to read
git-gui: fix scaled default fonts
to follow the convention.
---
git-gui.sh | 10 ++++++++++
1 file changed, 10 insertions(+)
diff --git a/git-gui.sh b/git-gui.sh
index 8bc8892..23dd82d 100755
--- a/git-gui.sh
+++ b/git-gui.sh
@@ -810,6 +810,16 @@ if {[is_Windows]} {
## config defaults
set cursor_ptr arrow
+
+# For whatever reason, Tk does not apply font scaling to default
fonts,
+# but applies font scaling when setting size explicitly.
+# Default -size 10 is still 10, when you look at it with `font
actual ...`,
+# but explicitl -size 10 becomes 10 * scale factor.
I fixed this typo: s/explicitl/explict/
Thanks!
+# So, we need to configure fonts to use their default font sizes,
but scaled.
+foreach font_name [font names] {
+ font configure $font_name -size [font actual $font_name -size]
+}
Have you seen https://wiki.tcl-lang.org/page/font+scaling where [font
configure ...] instead of [font actual ...] is suggested as a
preferable
solution? I am not so much into Tcl/Tk that I can judge what is best.
No, I haven't seen this, but suggested preferable solution doesn't work.
`font configure $font -size` returns negative numbers for me.
According to this
https://tkdocs.com/shipman/fonts.html
it means "size in pixels". And size in pixels does not scale. So, if we
want fonts to scale with DPI, we should use "points" - and that's what
`font actual ...` returns (i just hope it returns points, because it
works for me and scales like points).
I'm also no expert in Tcl/Tk, this just my second time writing patches
for git-gui :)
Probably, after all this we should change comment to:
# Default Tk fonts are defined in pixels, and they
# does not scale with DPI, here we're converting them
# into points, allowing them to scale just like
# explicitly defined fonts.
+
font create font_ui
if {[lsearch -exact [font names] TkDefaultFont] != -1} {
eval [linsert [font actual TkDefaultFont] 0 font configure
font_ui]
My setup does not have a 4k monitor, I run KDE and I do not know if I
have changed a DPI setting. For the test, I have removed the [gui]
sections from my configurations to ensure that the defaults are used.
Under these conditions, this change does not make a difference in how
Git GUI appears. I assume this is the expected outcome, so I take it
as
a good sign.
You can test it, by changing DPI in `~/.Xresources`
`xrdb -query` to see your current DPI, then increase it a little.
```
Xft.dpi: 154
```
`xrdb -merge ~/.Xresources` to apply new scaling.
The patch is available as
https://github.com/j6t/git-gui.git st/font-scaling-fix
for others to test. I'd appreciate your feedback.
-- Hannes