-
-
Notifications
You must be signed in to change notification settings - Fork 687
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
Added on_resize
handler on toga.Window
#2364
base: main
Are you sure you want to change the base?
Conversation
Quick question, there are actually 2 events that can be interpreted as
So, which one should we implement for |
I think the event would only be useful if we deliver it after the new size is available for rendering the window content. Whether this happens continuously during the resize, or only at the end, may vary between platforms. |
I am not sure, if I understood what you meant. There are 2 ways to resize a window:
So, in all cases the new size will be valid, as the new window size is obtained from the platform itself. So, what should we be validating here? As per the current implementation, the behavior is that the But I am not sure if this is the behavior that the user expects. Do you think the |
The mechanism for changing the window size isn't the issue. Depending on the platform, it's possible for the window system to generate window sizes that are invalid - consider the case of resizing a window to be smaller than the size that would be allowed by the content layout rules. Toga then internally rejects or adjusts those window sizes as necessary. In this case, you may get a system notification of a window size that isn't legal, because it's smaller than Toga will allow for content. This would be the window size that a "pre-resize" event (on_resizing, by your naming scheme) would generate. However, I'd argue there's no practical purpose to such an event in Toga. It would only be useful if there was a mechanism to reject the proposed size, and that won't be the case here. On that basis, I'd argue the "on_resized" interpretation is the only one that makes sense for Toga's public API purposes. This event may be generated multiple times as a window is dragged; however, that's a platform implementation detail. When the user-space event is triggered, it should reflect the fact that a new window size (however transient it may be) is available and in effect; and the last on_resize event that is received should be sent when the final window size has been confirmed (i.e., evaluating |
Toga Windows now supports calling user functions on resize events using
on_resize
handler.Fixes #2304
Also, gtk doesn't provide a native signal for detecting window resize only. The closest, I have found is the
configure-event
, but it triggers when the window is resized and also when the window is moved.I was thinking of using the
configure-event
& checking if the window is not moving, and only then triggering theon_resize
handler. If this doesn't work, we would need to use a timer and periodically check the window size.PR Checklist: