Re: [PATCH] Fix default font scaling

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 





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







[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux