aboutsummaryrefslogtreecommitdiff
path: root/src_testbed
diff options
context:
space:
mode:
authorrezural <rezural@protonmail.com>2021-05-29 13:00:01 +1000
committerrezural <rezural@protonmail.com>2021-05-29 13:00:01 +1000
commita49605bd9b0ae538ae9cf83b74132d0f0e820a9a (patch)
treeed7c95660f5fa659a3f62fca96cbdeb7134f57a3 /src_testbed
parent3bac79ecacdeaa18de19127b7a6c82cbfab29d14 (diff)
downloadrapier-a49605bd9b0ae538ae9cf83b74132d0f0e820a9a.tar.gz
rapier-a49605bd9b0ae538ae9cf83b74132d0f0e820a9a.tar.bz2
rapier-a49605bd9b0ae538ae9cf83b74132d0f0e820a9a.zip
check if the egui context wants pointer focus, disable orbit camera if so. this disables egui interactions being sent to the orbital camera
Diffstat (limited to 'src_testbed')
-rw-r--r--src_testbed/testbed.rs11
1 files changed, 11 insertions, 0 deletions
diff --git a/src_testbed/testbed.rs b/src_testbed/testbed.rs
index 6e314c8..bd0af2c 100644
--- a/src_testbed/testbed.rs
+++ b/src_testbed/testbed.rs
@@ -423,6 +423,7 @@ impl TestbedApp {
.insert_non_send_resource(self.plugins)
.add_stage_before(CoreStage::Update, "physics", SystemStage::single_threaded())
.add_system_to_stage("physics", update_testbed.system())
+ .add_system(egui_focus.system())
.run();
}
}
@@ -841,6 +842,16 @@ fn setup_graphics_environment(mut commands: Commands) {
});
}
+fn egui_focus(ui_context: Res<EguiContext>, mut cameras: Query<&mut OrbitCamera>) {
+ let mut camera_enabled = true;
+ if ui_context.ctx().wants_pointer_input() {
+ camera_enabled = false;
+ }
+ for mut camera in cameras.iter_mut() {
+ camera.enabled = camera_enabled;
+ }
+}
+
fn update_testbed(
mut commands: Commands,
windows: Res<Windows>,