mirror of
https://github.com/emilk/egui.git
synced 2026-06-27 07:03:14 -04:00
* Part of https://github.com/emilk/egui/issues/5113 * Part of https://github.com/emilk/egui/issues/3524 ## What This deprecates `eframe::App::update` and replaces it with two new functions: ```rs pub trait App { /// Called just before `ui`, and in the future this will /// also be called for background apps when needed. fn logic(&mut self, ctx: &egui::Context, frame: &mut Frame) { } /// Show your user interface to the user. fn ui(&mut self, ui: &mut egui::Ui, frame: &mut Frame); … } ``` Similarly, `Context::run` is deprecated in favor of `Context::run_ui`. `Plugin`s are now handed a `Ui` instead of just a `Context` in `on_begin/end_frame`. ## TODO …either in this PR or a later one * [x] Deprecate `App::update` * [x] Deprecate `Context::run` * [x] Change plugins to get a `Ui` * [x] Update kittest * [x] Change viewports to get UI:s (`show_viewport_immediate` etc) - https://github.com/emilk/egui/pull/7779 ## Later PRs * [ ] Deprecate `Panel::show` * [ ] Deprecate `CentralPanel::show` * [ ] Deprecate `CentralPanel` ?
53 lines
1.4 KiB
Rust
53 lines
1.4 KiB
Rust
#![doc = include_str!("../README.md")]
|
|
|
|
use eframe::{CreationContext, egui};
|
|
|
|
#[cfg(target_os = "android")]
|
|
#[no_mangle]
|
|
fn android_main(app: winit::platform::android::activity::AndroidApp) {
|
|
// Log to android output
|
|
android_logger::init_once(
|
|
android_logger::Config::default().with_max_level(log::LevelFilter::Info),
|
|
);
|
|
|
|
let options = eframe::NativeOptions {
|
|
android_app: Some(app),
|
|
..Default::default()
|
|
};
|
|
eframe::run_native(
|
|
"My egui App",
|
|
options,
|
|
Box::new(|cc| Ok(Box::new(MyApp::new(cc)))),
|
|
)
|
|
.unwrap()
|
|
}
|
|
|
|
pub struct MyApp {
|
|
demo: egui_demo_lib::DemoWindows,
|
|
}
|
|
|
|
impl MyApp {
|
|
pub fn new(cc: &CreationContext) -> Self {
|
|
egui_extras::install_image_loaders(&cc.egui_ctx);
|
|
Self {
|
|
demo: egui_demo_lib::DemoWindows::default(),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl eframe::App for MyApp {
|
|
fn ui(&mut self, ui: &mut egui::Ui, _frame: &mut eframe::Frame) {
|
|
// Reserve some space at the top so the demo ui isn't hidden behind the android status bar
|
|
// TODO(lucasmerlin): This is a pretty big hack, should be fixed once safe_area implemented
|
|
// for android:
|
|
// https://github.com/rust-windowing/winit/issues/3910
|
|
egui::Panel::top("status_bar_space").show_inside(ui, |ui| {
|
|
ui.set_height(32.0);
|
|
});
|
|
|
|
egui::CentralPanel::default().show_inside(ui, |ui| {
|
|
self.demo.ui(ui);
|
|
});
|
|
}
|
|
}
|