1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
//! This example shows how to add custom Views to the Rerun Viewer.
use re_viewer::external::{re_log, re_memory};
mod color_coordinates_view;
mod color_coordinates_visualizer_system;
// By using `re_memory::AccountingAllocator` Rerun can keep track of exactly how much memory it is using,
// and prune the data store when it goes above a certain limit.
// By using `mimalloc` we get faster allocations.
#[global_allocator]
static GLOBAL: re_memory::AccountingAllocator<mimalloc::MiMalloc> =
re_memory::AccountingAllocator::new(mimalloc::MiMalloc);
fn main() -> Result<(), Box<dyn std::error::Error>> {
let main_thread_token = re_viewer::MainThreadToken::i_promise_i_am_on_the_main_thread();
// Direct calls using the `log` crate to stderr. Control with `RUST_LOG=debug` etc.
re_log::setup_logging();
// Install handlers for panics and crashes that prints to stderr and send
// them to Rerun analytics (if the `analytics` feature is on in `Cargo.toml`).
re_crash_handler::install_crash_handlers(re_viewer::build_info());
// Listen for TCP connections from Rerun's logging SDKs.
// There are other ways of "feeding" the viewer though - all you need is a `re_smart_channel::Receiver`.
let rx = re_sdk_comms::serve(
"0.0.0.0",
re_sdk_comms::DEFAULT_SERVER_PORT,
Default::default(),
)?;
let startup_options = re_viewer::StartupOptions::default();
// This is used for analytics, if the `analytics` feature is on in `Cargo.toml`
let app_env = re_viewer::AppEnvironment::Custom("My extended Rerun Viewer".to_owned());
println!(
"This example starts a custom Rerun Viewer that is ready to accept data… you have to give it some!"
);
println!("Try for example to run: `cargo run -p minimal_options -- --connect` in another terminal instance.");
re_viewer::run_native_app(
main_thread_token,
Box::new(move |cc| {
let mut app = re_viewer::App::new(
main_thread_token,
re_viewer::build_info(),
&app_env,
startup_options,
cc,
);
app.add_receiver(rx);
// Register the custom view
app.add_view_class::<color_coordinates_view::ColorCoordinatesView>()
.unwrap();
Box::new(app)
}),
None,
)?;
Ok(())
}