use eframe::egui;
use egui_map_view::{
Map,
config::OpenStreetMapConfig,
layers::svg::{SvgElement, SvgLayer},
};
fn main() -> eframe::Result {
let options = eframe::NativeOptions {
viewport: egui::ViewportBuilder::default().with_inner_size([800.0, 600.0]),
..Default::default()
};
eframe::run_native(
"SVG Layer Example",
options,
Box::new(|_cc| Ok(Box::<MyApp>::default())),
)
}
struct MyApp {
map: Map,
}
impl Default for MyApp {
fn default() -> Self {
let mut map = Map::new(OpenStreetMapConfig::default());
let mut svg_layer = SvgLayer::default();
let red_circle = r#"<svg height="100" width="100" xmlns="http://www.w3.org/2000/svg">
<circle r="40" cx="50" cy="50" fill="red" />
</svg>"#;
let blue_square = r#"<svg height="100" width="100" xmlns="http://www.w3.org/2000/svg">
<rect width="80" height="80" x="10" y="10" fill="blue" />
</svg>"#;
let green_triangle = r#"<svg height="100" width="100" xmlns="http://www.w3.org/2000/svg">
<polygon points="50,15 90,85 10,85" fill="green" />
</svg>"#;
svg_layer.add_element(
SvgElement::from_xy(24.94, 60.17, red_circle, "Helsinki Red Circle (Clickable)")
.with_scalable(true),
);
svg_layer.add_element(
SvgElement::from_xy(
-0.12,
51.50,
blue_square,
"London Blue Square (Non-clickable)",
)
.with_clickable(false),
);
svg_layer.add_element(
SvgElement::from_xy(
18.06,
59.32,
green_triangle,
"Stockholm Green Triangle (Draggable)",
)
.with_draggable(true),
);
map.add_layer("svg_icons", svg_layer);
Self { map }
}
}
impl eframe::App for MyApp {
fn ui(&mut self, ui: &mut egui::Ui, _frame: &mut eframe::Frame) {
egui::CentralPanel::default()
.frame(egui::Frame::NONE)
.show_inside(ui, |ui| {
ui.add_sized(ui.available_size_before_wrap(), &mut self.map);
});
if let Some(svg_layer) = self.map.layer_mut::<SvgLayer>("svg_icons") {
for event in svg_layer.take_events() {
println!(
"SVG clicked: {} with {:?} button at geo: {:?}, screen: {:?}",
event.metadata, event.button, event.world_pos, event.screen_pos
);
}
}
}
}