-
Notifications
You must be signed in to change notification settings - Fork 7
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
Sometimes returns negative offset values #29
Comments
-8 is still a valid offset, though? I can drag windows to be partly outside my desktop (top left) and I will get negative offsets as expected. |
Yes, it's perfectly normal for a window's geometry to overflow the bounds of the screen. Whether it's up to hacksaw to clamp the return value is a very good question though. There are arguments either way, and considering it's not a trivial thing to do in a script, I suppose an option could be added for it. |
Not that complicated? hacksaw | sed -r 's/-[0-9]+/0/g' |
That's not enough, you also need to subtract the excess from the width and height, and account for overflow on the bottom and right edges. |
Behold my bash skills. Yeah probably just adding |
In this case, my point was to equal parts that the window is not actually off-screen and the difference to slop for the same window. The program that broke was ffmpeg, or more specifically the |
I know that filtering out the negative values as a workaround isn't too difficult (esp. since I'm parsing the output into separate variables anyway for this script), but I was wondering about why this happens as well. |
As for an example of unclamped geometry being useful, when you pass both
I'm not entirely sure I understood that sentence, but it sounds like your window manager's decorations are off-screen, while the window contents are not. The
It's just a limitation of the X11 protocol, albeit a reasonable one. You can't capture the contents of a window outside of its boundaries. |
I think it's easiest to show with images. This is how the window looks maximized, while this is how it looks right when starting up. As you can see, there's some pixels of background on the top corners due to rounded corners on the title bar, but otherwise they look exactly the same (save for the different title, which is solely because I hadn't restarted playback yet). Yet the first returns a vertical offset of 0, while the second comes out to -8. |
This is strange. To be honest I'm not sure what could be causing this. What's your DE/window manager? Does it add shadows to your windows? |
I'm using GNOME 3.36.2 on Arch, and no, there's no shadows as far as I'm aware. If you want me to, I could whip out good ol' GDB and look into it further, e.g. by comparing the values going into and coming out of libxcb. |
GNOME is known to do weird things that no other WM does, I believe that's what |
This is the reply from |
Based on what you said and that comment, I'm assuming it's indeed Mutter doing something stupid, as usual. |
Yes, I was looking at the same piece of code. The reason for this is precisely what the comment says: Mutter (and GTK3 CSD) draws shadows as part of the decoration window rather than as a compositor effect (why?), so the actual window is larger than it looks, even if your theme has no visible shadows. This means that we need to do the same thing as slop here (maybe optionally, because you may still want to capture the shadow). |
Something that might work as a fix for your particular situation could be to change the |
Indeed, using However, there's another thing. I tried testing the out-of-bounds thing with slop on bspwm with a window that was out of the screen in the top-left corner, and both hacksaw and slop returned the same geometry with negative values for X and Y. So far, so good. But, in the process I noticed that somehow, hacksaw starts lagging hard in comparison to slop when there's lots of moving parts on the screen. An example. This happened even without recording, so it's definitely not an issue of the encoder hogging my CPU (which it's configured not to do anyway). |
That's the expected behavior.
I think both
Yep, @expectocode has also confirmed this, so the only difference here is just us not supporting
I'm not quite sure what would cause this, but you should open a separate issue about it. |
Gonna do that tomorrow probs. Thanks for the help and quick responses. |
Okay, I'm assuming this ties in with the whole Mutter thing, but I noticed something else as well: All the other coordinates are somewhat off as well, as you can see in the following snippet. Noticed because I was trying to with manual clamping but still got out-of-bounds errors from x11grab.
|
Yeah that's basically the same problem. |
Spotify doesn't start maximized, but still takes up the full screen. Trying to use hacksaw to grab the size and coordinates of that window in it's non-maximized form returns a Y offset of -8, which breaks things trying to consume that value. For comparison, slop returns a Y offset of 0 for the same window.
I'm not really sure what information to provide beyond this, but I'll provide what I can if you ask me for it.
The text was updated successfully, but these errors were encountered: