-
Notifications
You must be signed in to change notification settings - Fork 930
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
macos: Handle resizes synchronously #1911
Conversation
Allows for a lot better resize behaviour on macos, when allowed to redraw the frame within the resize event callback.
I thought #1901 would of fixed this, but it doesn't do anything when the view has a metal or opengl CALayer attached, as |
Hmm, on further testing, this fixes especially the case when I actually render in the So I'm not sure, but is the OS resizing the window, winit giving But in any case, I believe rendering within the I'm curious is all the queuing of the events all that necessary overall though. |
I think that the biggest problem -that #1901 did not address- is that now you get the redraw events before the resized events, which is almost certainly unexpected by developers. Note that it's advised to render in the However I do believe that there's merit in solving the problem of "getting the redraw events before the resized events" and this PR does solve that. Although I am somewhat uncomfortable with synchronously dispatching some events while others are queued. I have to admit that I don't really understand why we queue events in the first place rather than just immediately dispatching all of them (I tried getting to the bottom of this but all I found was #853 which didn't help enlightening me). Maybe @francesca64 knows why events are queued and only dispatched in the |
I'm totally fine with changing all the callbacks to non-queueing, thats just changing the it seems Francesca did set it to send resizes directly in francesca64@b75073a but then later in #1173 it was then deferred again. Unfortunately it seems Aleksi has removed his github account. In there he both defers the event and change a runloop mode. I guess I didn't double-check that the other events come through, but with a quick check, key events are not coming through while resizing, but thats not too unexpected. But I did get continuous rendering of the app still (and with maineventscleared), so should be fine on that front. |
It would be to the very least surprising if there wouldn't be a good reason why events are queued instead of dispatched immediately. Unfortunately I don't know what that reason is. As another attempt I'm tagging @goddessfreya to help here. Otherwise I can't think of a better way of finding the reason, than to try to make every event dispatched immediately. |
@scoopr thanks for doing the archaeology on that! @ArturKovacs neither Osspial nor me have been able to communicate with Freya over either email or Discord in the past year or so, and her website's been gone for just as long, so all we can do is hope that she's alright. On the bright side, she likely wouldn't know about this, since #853 was her politely rebasing my macOS EL2 work that I'd sorta kinda abandoned. For more historical background, I based the macOS As for resize in particular... we apparently discussed issues I found with queuing resizes, but since 99% of the discussion happened in calls, that's all the info left now. It's possible he remembers why it was important to queue events in the first place, but he's presently on leave, so I'm not sure when I'd be able to ask him. |
First of all thank you @francesca64 for clarifying the situation with Freya. I wish her the best. And thanks for describing the history of how we came to queue events, it is definitely helpful. I'll probably spend some time with this in the near future as I think it's an important issue, but in any case I'm looking forward to hearing from @mtak- because even if the immediate dispatch would seem to work, I'd have the feeling that we are missing something that @mtak- knew about. |
See #2640 (comment), I plan to fix this myself, but it'll take a while. |
Allows for a lot better resize behaviour on macos, when allowed
to redraw the frame within the resize event callback.
cargo fmt
has been run on this branchcargo doc
builds successfullyCHANGELOG.md
if knowledge of this change could be valuable to users