From 68100102be588aea3dd42cb64647e1f8624615b2 Mon Sep 17 00:00:00 2001 From: msiglreith Date: Wed, 12 Aug 2020 20:56:28 +0200 Subject: [PATCH] android: fix event loop polling (#1638) * android: poll looper for ControlFlow::Poll and don't exit when no new event received * Add Android ControlFlow:Poll fix to CHANGELOG --- CHANGELOG.md | 1 + src/platform_impl/android/mod.rs | 9 ++++++--- 2 files changed, 7 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index d9257f7a..ae81ae6f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -14,6 +14,7 @@ - On Windows, `set_ime_position` is now a no-op instead of a runtime crash. - On Android, `set_fullscreen` is now a no-op instead of a runtime crash. - On iOS and Android, `set_inner_size` is now a no-op instead of a runtime crash. +- On Android, fix `ControlFlow::Poll` not polling the Android event queue. - **Breaking:** On Web, `set_cursor_position` and `set_cursor_grab` will now always return an error. - **Breaking:** `PixelDelta` scroll events now return a `PhysicalPosition`. diff --git a/src/platform_impl/android/mod.rs b/src/platform_impl/android/mod.rs index e4bdef82..453815d8 100644 --- a/src/platform_impl/android/mod.rs +++ b/src/platform_impl/android/mod.rs @@ -211,9 +211,7 @@ impl EventLoop { ); } } - None => { - control_flow = ControlFlow::Exit; - } + None => {} } call_event_handler!( @@ -258,6 +256,11 @@ impl EventLoop { break 'event_loop; } ControlFlow::Poll => { + self.first_event = poll( + self.looper + .poll_all_timeout(Duration::from_millis(0)) + .unwrap(), + ); self.start_cause = event::StartCause::Poll; } ControlFlow::Wait => {