2021-01-17 13:48:59 +00:00
|
|
|
//! eframe - the egui framework crate
|
2020-12-29 14:57:13 +00:00
|
|
|
//!
|
2021-01-17 09:52:01 +00:00
|
|
|
//! If you are planning to write an app for web or native,
|
2021-01-17 13:48:59 +00:00
|
|
|
//! and are happy with just using egui for all visuals,
|
2021-01-17 09:52:01 +00:00
|
|
|
//! Then `eframe` is for you!
|
2020-12-29 14:57:13 +00:00
|
|
|
//!
|
2021-01-02 10:59:20 +00:00
|
|
|
//! To get started, look at <https://github.com/emilk/egui_template>.
|
2020-12-29 14:57:13 +00:00
|
|
|
//!
|
2021-01-17 09:52:01 +00:00
|
|
|
//! You write your application code for [`epi`] (implementing [`epi::App`]) and then
|
|
|
|
//! call from [`crate::run_native`] your `main.rs`, and/or call `eframe::start_web` from your `lib.rs`.
|
|
|
|
//!
|
|
|
|
//! `eframe` is implemented using [`egui_web`](https://docs.rs/egui_web) and [`egui_glium`](https://docs.rs/egui_glium).
|
2020-12-29 14:57:13 +00:00
|
|
|
|
|
|
|
#![forbid(unsafe_code)]
|
|
|
|
#![cfg_attr(not(debug_assertions), deny(warnings))] // Forbid warnings in release builds
|
2021-01-02 11:02:26 +00:00
|
|
|
#![warn(clippy::all, missing_docs, rust_2018_idioms)]
|
2020-12-29 14:57:13 +00:00
|
|
|
|
|
|
|
pub use {egui, epi};
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// When compiling for web
|
|
|
|
|
|
|
|
#[cfg(target_arch = "wasm32")]
|
|
|
|
pub use egui_web::wasm_bindgen;
|
|
|
|
|
|
|
|
/// Install event listeners to register different input events
|
|
|
|
/// and start running the given app.
|
|
|
|
///
|
|
|
|
/// Usage:
|
2021-01-17 09:52:01 +00:00
|
|
|
/// ``` no_run
|
2020-12-29 14:57:13 +00:00
|
|
|
/// #[cfg(target_arch = "wasm32")]
|
|
|
|
/// use wasm_bindgen::prelude::*;
|
|
|
|
///
|
|
|
|
/// /// This is the entry-point for all the web-assembly.
|
|
|
|
/// /// This is called once from the HTML.
|
|
|
|
/// /// It loads the app, installs some callbacks, then returns.
|
|
|
|
/// /// You can add more callbacks like this if you want to call in to your code.
|
|
|
|
/// #[cfg(target_arch = "wasm32")]
|
|
|
|
/// #[wasm_bindgen]
|
|
|
|
/// pub fn start(canvas_id: &str) -> Result<(), eframe::wasm_bindgen::JsValue> {
|
|
|
|
/// let app = MyEguiApp::default();
|
|
|
|
/// eframe::start_web(canvas_id, Box::new(app))
|
|
|
|
/// }
|
|
|
|
/// ```
|
|
|
|
#[cfg(target_arch = "wasm32")]
|
|
|
|
pub fn start_web(canvas_id: &str, app: Box<dyn epi::App>) -> Result<(), wasm_bindgen::JsValue> {
|
|
|
|
egui_web::start(canvas_id, app)?;
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// When compiling natively
|
|
|
|
|
2021-01-02 10:59:20 +00:00
|
|
|
/// Call from `fn main` like this: `eframe::run_native(Box::new(MyEguiApp::default()))`
|
2020-12-29 14:57:13 +00:00
|
|
|
#[cfg(not(target_arch = "wasm32"))]
|
2021-01-02 10:59:20 +00:00
|
|
|
pub fn run_native(app: Box<dyn epi::App>) -> ! {
|
2020-12-29 14:57:13 +00:00
|
|
|
egui_glium::run(app)
|
|
|
|
}
|