mirror of
https://github.com/a-b-street/abstreet.git
synced 2025-01-04 04:23:25 +03:00
starting a plugin to show all neighborhoods with a very basic text summary
This commit is contained in:
parent
118b676220
commit
3d40f7c91b
@ -13,6 +13,7 @@ pub mod hider;
|
||||
pub mod layers;
|
||||
pub mod logs;
|
||||
pub mod map_edits;
|
||||
pub mod neighborhood_summary;
|
||||
pub mod road_editor;
|
||||
pub mod scenarios;
|
||||
pub mod search;
|
||||
|
102
editor/src/plugins/neighborhood_summary.rs
Normal file
102
editor/src/plugins/neighborhood_summary.rs
Normal file
@ -0,0 +1,102 @@
|
||||
use abstutil;
|
||||
use ezgui::{Color, GfxCtx, Text};
|
||||
use geom::{Polygon, Pt2D};
|
||||
use map_model::{LaneID, Map};
|
||||
use objects::{Ctx, DEBUG};
|
||||
use piston::input::Key;
|
||||
use plugins::{Plugin, PluginCtx};
|
||||
use sim::Neighborhood;
|
||||
use std::collections::HashSet;
|
||||
|
||||
pub struct NeighborhoodSummary {
|
||||
regions: Vec<Region>,
|
||||
active: bool,
|
||||
}
|
||||
|
||||
impl NeighborhoodSummary {
|
||||
pub fn new(map: &Map) -> NeighborhoodSummary {
|
||||
NeighborhoodSummary {
|
||||
regions: abstutil::load_all_objects("neighborhoods", map.get_name())
|
||||
.into_iter()
|
||||
.enumerate()
|
||||
.map(|(idx, (_, n))| Region::new(idx, n, map))
|
||||
.collect(),
|
||||
active: false,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl Plugin for NeighborhoodSummary {
|
||||
fn event(&mut self, ctx: PluginCtx) -> bool {
|
||||
if self.active {
|
||||
if ctx
|
||||
.input
|
||||
.key_pressed(Key::Z, "stop showing neighborhood summaries")
|
||||
{
|
||||
self.active = false;
|
||||
}
|
||||
} else {
|
||||
self.active = ctx.primary.current_selection.is_none() && ctx
|
||||
.input
|
||||
.unimportant_key_pressed(Key::Z, DEBUG, "show neighborhood summaries");
|
||||
}
|
||||
|
||||
self.active
|
||||
}
|
||||
|
||||
fn draw(&self, g: &mut GfxCtx, ctx: Ctx) {
|
||||
if !self.active {
|
||||
return;
|
||||
}
|
||||
|
||||
for r in &self.regions {
|
||||
// TODO some text
|
||||
g.draw_polygon(r.color, &r.polygon);
|
||||
|
||||
let mut txt = Text::new();
|
||||
txt.add_line(format!("{} has {} lanes", r.name, r.lanes.len()));
|
||||
ctx.canvas.draw_text_at(g, txt, r.center);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// sim::Neighborhood is already taken, just call it something different here. :\
|
||||
struct Region {
|
||||
name: String,
|
||||
polygon: Polygon,
|
||||
center: Pt2D,
|
||||
lanes: HashSet<LaneID>,
|
||||
color: Color,
|
||||
}
|
||||
|
||||
impl Region {
|
||||
fn new(idx: usize, n: Neighborhood, map: &Map) -> Region {
|
||||
let center = Pt2D::center(&n.points);
|
||||
let polygon = Polygon::new(&n.points);
|
||||
// TODO polygon overlap or complete containment would be more ideal
|
||||
let lanes = map
|
||||
.all_lanes()
|
||||
.iter()
|
||||
.filter_map(|l| {
|
||||
if polygon.contains_pt(l.first_pt()) && polygon.contains_pt(l.last_pt()) {
|
||||
Some(l.id)
|
||||
} else {
|
||||
None
|
||||
}
|
||||
}).collect();
|
||||
Region {
|
||||
name: n.name.clone(),
|
||||
polygon,
|
||||
center,
|
||||
lanes,
|
||||
color: COLORS[idx % COLORS.len()],
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
const COLORS: [Color; 3] = [
|
||||
// TODO these are awful choices
|
||||
[1.0, 0.0, 0.0, 0.8],
|
||||
[0.0, 1.0, 0.0, 0.8],
|
||||
[0.0, 0.0, 1.0, 0.8],
|
||||
];
|
@ -242,6 +242,7 @@ impl PerMapUI {
|
||||
flame::dump_stdout();
|
||||
|
||||
let steepness_viz = plugins::steep::SteepnessVisualizer::new(&map);
|
||||
let neighborhood_summary = plugins::neighborhood_summary::NeighborhoodSummary::new(&map);
|
||||
|
||||
let state = PerMapUI {
|
||||
map,
|
||||
@ -270,6 +271,7 @@ impl PerMapUI {
|
||||
Box::new(plugins::scenarios::ScenarioManager::new()),
|
||||
Box::new(plugins::map_edits::EditsManager::new()),
|
||||
Box::new(plugins::chokepoints::ChokepointsFinder::new()),
|
||||
Box::new(neighborhood_summary),
|
||||
],
|
||||
};
|
||||
(state, plugins)
|
||||
|
Loading…
Reference in New Issue
Block a user