-
Notifications
You must be signed in to change notification settings - Fork 350
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Wayland: text is garbled on non-scaled monitors #1316
Comments
did you enable |
Yes, with no effect. From what I can see, this settings is X11-only. |
I am checking the code and it is indeed an x11 only option. But does the error occur only when the scaled screen is connected? |
Yes, only when the scaled screen is connected. Otherwise, it works fine. |
are you able to compile dunst ? I can add some logging in the wl_get_scale function. Unfortunately I can't test it myself because I don't have such wayland environment |
Yes, I can compile it. Feel free to point me to a branch with extra logs. |
I have made that small modification in my fork (https://github.com/bynect/dunst/tree/log-scale). If you could try it maybe we can get a better understanding of what's going on |
Sorry this took a while. Here is log from notification on non-scaled monitor:
Here is log from notification on scaled monitor:
Scaled monitor = 3840x2160 with 2x scaling |
@matejdro I am very sorry I just noticed that the branch I pointed you was not actually synced with the changes I made. I added some logging calls in the wl_get_scale function. This time the changes are actually up on github at the aforementioned link, but I will send also the diff diff --git a/src/wayland/wl.c b/src/wayland/wl.c
index 18a2173..7c792bd 100644
--- a/src/wayland/wl.c
+++ b/src/wayland/wl.c
@@ -896,13 +896,20 @@ double wl_get_scale(void) {
struct dunst_output *output = get_configured_output();
if (output) {
scale = output->scale;
+
+ LOG_I("Output found, global name = %u, name = %s, scale = %u", output->global_name, output->name, output->scale);
} else {
+ LOG_I("Output not found!");
+
// return the largest scale
struct dunst_output *output;
wl_list_for_each(output, &ctx.outputs, link) {
scale = MAX(output->scale, scale);
+ LOG_I("Checking output %s (%u) with scale %u", output->name, output->global_name, output->scale);
}
}
+
+ LOG_I("Scale is %d", scale);
if (scale <= 0)
scale = 1;
return scale;
Could you please test with these changes so I can understand if the monitor are correctly detected |
Both monitors print:
So, detected scale is 2 at both. If I hardcode that method to return 1, then text is not garbled anymore on the non-scaled monitor, but it is blurry on the scaled one. from what I can see, the problem seems to be the get_configured_output method? It always returns null when FOLLOW_MOUSE or FOLLOW_KEYBOARD is enabled. There is no actual detection of the currently focused monitor. |
Right, I figured it probably was the monitor detection. I am not an expert in wayland but I'll try looking into it. Maybe returning the scale of the monitor where the window currently is positioned is a better choice? I don't know the rationale behind the way follow is implemented in wayland |
@alebastr sorry to disturb you, but you seem to be one of the people that know the wayland backend the most. Do you know why the get_configured_output function doesn't return the focused monitor if the follow mode is not none? Is there a profound reason related to the protocol or was it just a past miscalculation ? For reference switch (settings.f_mode){
case FOLLOW_NONE: ; // this semicolon is neccesary
if (!configured_output) {
LOG_W("Monitor %s doesn't exist, using focused monitor", settings.monitor);
}
return configured_output;
/// why? VVVV
case FOLLOW_MOUSE:
// fallthrough
case FOLLOW_KEYBOARD:
// fallthrough
default:
return NULL;
} |
I'm afraid that is a correct behavior. Wayland does not offer info about the currently focused output, partly because it is considered a sensitive information, partly because it doesn't make much sense with multi-seat support and multiple independent pointers. So if you don't have an output that is explicitly set in the configuration and exists in runtime, there's nothing to return. The fallback code in Edit: a bit tricky to get it right; the event order is following (starting from draw.c:draw): Should be fine to move the surface recreation a bit ahead. It could be nice to reduce the amount of scaled calculations with something like I'll try to get the Wayland parts done next week and will look into the rest. |
Thank you very much. I was thinking of using cairo device scaling but I have yet to code anything. Does wayland not allow to know the output where the window currently is? Is this a limitation of the layer protocol we are using? |
It is known. But |
Just want to copy mention this for record keeping: It appears that this jaggedness happens on Sway. On Hyprland, text is still worse when scaling is enabled, but not as bad as on Sway. |
Issue description
When using dunst with Sway and using multiple monitors, where at least one monitor is using scaling, dunst's text will be garbled on non-scaled monitors:
On scaled monitors it appears fine:
Installation info
Dunst - A customizable and lightweight notification-daemon 1.10.0 (2024-02-19)
package
sway version 1.9
Arch
Minimal dunstrc
default + `follow` option enabled to allow displaying on multiple monitorsSetting
force_xwayland
totrue
fixes the issue, but it also breaksfollow
, which makes it an useless workaround.The text was updated successfully, but these errors were encountered: