GTK3 apps no longer have antialiasing on Neon

Running on up to date Neon testing, since a couple of days ago - after a restart - on Wayland locally install Gtk3 apps (also Flatpak, but I’m assuming its for the same reason) render really badly - without anti-aliasing (Plasma GTK theme preview):

Things that aren’t affected:

  • X11 or XWayland
  • libadwaita apps
  • other GTK4 apps (verified with awf-gtk4)
  • Firefox (native, flatpak or snap)
  • GIMP 2.10 from Flatpak

Here’s awf-gtk3 Wayland (top) vs aws-gtk3 XWayland (bottom):

This is the same app, running normally and then with WAYLAND_DISPLAY= override.

I tried all the reported fixes: install xdg-desktop-portal-gtk instead of xdg-desktop-portal-gnome; make sure ~/.xsettingsd has the correct Xft settings; check that font-config has the correct anti-aliasing setting

I’m not sure what else to check. Please advise.

kinfo:
Operating System: KDE neon Testing Edition
KDE Plasma Version: 6.2.4
KDE Frameworks Version: 6.9.0
Qt Version: 6.8.0
Kernel Version: 6.8.0-49-generic (64-bit)
Graphics Platform: Wayland
Processors: 20 × 12th Gen Intel® Core™ i7-12700H
Memory: 31.0 GiB of RAM
Graphics Processor: Mesa Intel® Graphics

1 Like

Just curious, do you have your overall display scaled up in the Display & Monitor settings?

Good question - but no: this is all 100% scaling. In the office I have displays that are scaled at 125% but I haven’t been there since the issue started happening.

Hmm…just a thought, perhaps check and see what packages updated before that restart to see if anything jumps out as potentially related - ex. Plasma itself, or any xdg-desktop/portal related ones?

It sounds likely to be a software configuration change - looking back from Nov 26, the likely candidates (upgrades that have happened since then and sound possibly related are):

  • xdg-desktop-portal:amd64 (1.18.4-1+24.04+noble+unstable+build1, 1.19.0-0zneon+24.04+noble+release+build11)
  • plasma-framework:amd64 (6.2.3+p24.04+vstable+git20241105.
    1449-0, 6.2.4-0zneon+24.04+noble+release+build11)
  • breeze-gtk-theme:amd64 (6.2.3+p24.04+vstable+git202
    41106.0141-0, 6.2.4-0zneon+24.04+noble+release+build9)
  • kde-style-breeze:amd64 (4:6.2.3+p24.04+vstable+git20241105.2221-0, 4:6.2.4-0zneon+24.04+noble+release+build12)
  • kde-config-gtk-style-preview:amd64 (4:6.2.3+p24.04+vstable+git20241105.2305-0, 4:6.2.4-0zneon+24.04+noble+release+build11)
  • kde-config-gtk-style:amd64 (4:6.2.3+p24.04+vstable+git20
    241105.2305-0, 4:6.2.4-0zneon+24.04+noble+release+build11)
  • plasma-workspace:amd64 (4:6.2.3+p24.04+vstable+git20241112.2253-0, 4:6.2.4-0zneon+24.04+noble+release+build18)
  • plasma-workspace-wayland:amd64 (4:6.2.3+
    p24.04+vstable+git20241112.2253-0, 4:6.2.4-0zneon+24.04+noble+release+build18)
  • xdg-desktop-portal-kde:amd64 (6.2.3+p24.04+vstable+git20241105.1533-0, 6.2.4-0zneon+2
    4.04+noble+release+build8)
  • kwin-wayland:amd64 (4:6.2.3+p24.04+vstable+git20241112.2254-0, 4:6.2.4-0zneon+24.04+noble+release+build15)

Update:

Reverting kde-style-breeze, breeze, breeze-cursor-theme, kwin-style-breeze, breeze-gtk-theme, xdg-desktop-portal, plasma-framework, kde-style-breeze, kde-config-gtk-style-preview, kde-config-gtk-style, xdg-desktop-portal-kde does fix the problem. Now to fine the specific package causing the issue - unfortunately this requires logging in and out multiple times :frowning:

Update:

The problem is the update of xdg-desktop-portal from 1.18.4-1+24.04+noble+stable+build1 to 1.19.0-0zneon+24.04+noble+release+build11

Now to understand why…

Hmm, the xdg-desktop-portal one jumps out as that’s newer (1.19.0) than the version I’ve got on Fedora 41 (1.18.4) - that looks to be newer than the tagged release on their GitHub - GitHub - flatpak/xdg-desktop-portal: Desktop integration portal - though there may be totally legit reasons for that.

As I’m typing this, I can now see your update - hmm, yeah that’s an interesting one as not even Arch Linux is on that version yet…perhaps an upstream bug report might help?

I can see that 1.19.0 is tagged on Nov 28. I got the update from the Neon release channel on Nov 29. I’m surprised that Neon ships 1.19, as No Ubuntu version (not even 25.04 dev) ships 1.19.

Also the NEWS file for 1.19.0 is weird in that it does not include the changes for 1.18.2 through 1.18.4.

Reviewing the packaging changelog, it reports that 1.19.0 was pushed as an experimental development release, then picked up by Neon automated build. :question:

I’ve found this resolved issue that looks to be relevant: GTK_USE_PORTAL=1 breaks GTK apps antialiasing and mouse cursor size · Issue #1123 · flatpak/xdg-desktop-portal · GitHub . I do have GTK_USE_PORTAL=1 in the environment and indeed turning it off seems to also solve the problem. I added my report there. There’s also this KDE bug report: 450175 – GTK_USE_PORTAL=1 messes up the look of many GTK apps in Wayland.

Apparently I had GTK_USE_PORTAL=1 in my local configuration, but after unsetting it - it is still set on reboot, which makes sense - it is a useful setting that causes Firefox and SWT applications to use KDE file open/save dialogs, so its probably defined as a default in some package (I have yet to locate the guilty party).

After more analysis, I think the problem is that the desktop portal fallbacks aren’t handled properly - the xdg-desktop-portal daemon complains (in its service log) about portals.conf misconfiguration (even though I can see it opening the kde-portals.conf file and doesn’t seem to invoke the GTK portal at all. The 1.19.0 NEWS file has this entry:

  • The portals.conf parser is now able to handle fallback backends better, and respects the order of backends in the config file.

Which sounds to me like they changed something and now it is broken.

I added a report in the GitHub issue - we’ll see what gets out of that. After rebooting another time, the GTK_USE_PORTAL environment variable is no longer set - so it isn’t set by default on Neon and there was some weird thing going on on my system (likely the systemd user session didn’t close properly the previous time I tried to log out). So this is currently my workaround: no KDE file dialogs on native GTK applications (the portal is still used correctly for Flatpak and Snap apps, so I’m not missing a lot).

1 Like

Awesome digging there - and yes, maybe one of the folks working on Neon can give some context around what I imagine was a change in 1.19.0 that might have fixed some other issue and required pulling in a pre-release version early?

An analogy I can think of is, the RPMFusion repositories for Fedora pushed the beta version of the Nvidia drivers to their regular release repository, I believe in large part because of the well-publicized security bug that A) impacted the major version that had been in use and B) wasn’t going to be patched in that major version by Nvidia.

Either way, this is great context to have for any other Neon users who come across the same challenge!

Same here too with firefox (Print dialog) or LibreOffice flatpak/snap/apt:

  • But gparted has good font.
  • LibreOffice Calc left top corner has a yellow W icon instead of the app icon

System:
Operating System: KDE neon 6.2
KDE Plasma Version: 6.2.4
KDE Frameworks Version: 6.8.0
Qt Version: 6.8.1
Kernel Version: 6.8.0-49-generic (64-bit)
Graphics Platform: Wayland
Processors: 16 × AMD Ryzen 7 PRO 7840U w/ Radeon 780M Graphics
Memory: 61,5 GiB of RAM
Graphics Processor: AMD Radeon Graphics
Manufacturer: LENOVO
Product Name: 21JVCTO1WW
System Version: ThinkPad Z13 Gen 2

Did you check that System Settings GTK 3 preview exhibits the problem?

No, there it looks good:

LibreOffice:

Then it’s likely not the same problem. You should still check if any of the workarounds discussed in this thread help.

I fixed it by choosing “X11”.

Now many other things suddenly work as smooth as in windows for my team:
Multiple Hotplugging to docking station (Office/Home 2x 4k 43" inch screens 100dpi @60Hz) - crucial for me and our teams for daily change of place (Home+Work),
Window position remembering like in WIndows ,
Proper Icons topleft. No mouse lags anymore

Very nice to see good progress .

And also very nice, that the installer supports LUKS+btrfs hibernate so easy encrypted Disc like in Windows is possible

PS Using Thinkpad Z13 Gen2 64GB

You mean, choosing “Plasma (X11)” as the login session? The point of the “X11 workaround” in the thread was running just the offending application under X11 (aka XWayland).

Generally it is not advised to stay on a full X11 session as it is less supported now and will become obsolete over time.

Yes, I chose Plasma (X11) - temporarily :-).

I use X11 specifically, I’m not using Wayland until I have feature parity with X11. At the moment, fractional scaling under Wayland is a hot mess compared to X11, certain desktop animations and scrolling under FF are also choppy.

Running Nvidia with 560.35.03 drivers, with GSP firmware disabled running Wayland.

Fully disagree here - HiDPI support on kwin Wayland is so much better then on X11. I’m running two vertical UHD screens at 130% scale and one horizontal 1080p display, and dragging windows across screens (even between the two HiDPI ones) is ridiculous in X11 with the window jumping in size and never in the correct size. Under Wayland it is always perfect.

The main problem are GTK apps - that under Wayland that isn’t GNOME, always decide to do the wrong thing.

And the scaling of GTK apps, as well as the pointer as it passes over GTK apps, is a hot mess. Pointer passes over GTK app, pointer either goes really tiny or really big.

I run a single 27" 4k monitor and 150% scaling works far better under X11 than it does under Wayland for the reason mentioned above. Furthermore, certain desktop animations as well as scrolling under FF are nowhere as janky running X11. Therefore running a single HiDPI monitor, X11 offers less in the way of compromises at this point in time.

The problem with Wayland is the fact that as a protocol it’s far too stripped out, leaving everything up to the DE, resulting in a fragmented experience depending on DE used. When it reaches a no compromise parity with literally every other OS, then I’ll switch. Until then, I’ll use X11 and PC goes burrr with my single monitor HiDPI configuration.

can confirm that 1.18.4 fixes all these issues, so with no upstream fix in sight, pins have been added, 1.19 deleted from the archives and new 1.18.4 packages landed in the archives. snapshot’s are running so all editions should be good to go very soon TM :slight_smile:

4 Likes