mirror of
https://github.com/a-b-street/abstreet.git
synced 2025-01-07 06:57:25 +03:00
put action buttons higher up in info panels
This commit is contained in:
parent
171335f64d
commit
b4017cc0e2
@ -46,7 +46,25 @@ impl InfoPanel {
|
|||||||
actions.insert(0, (Key::F, "follow agent".to_string()));
|
actions.insert(0, (Key::F, "follow agent".to_string()));
|
||||||
}
|
}
|
||||||
|
|
||||||
let mut col = info_for(id.clone(), ctx, ui);
|
let action_btns = actions
|
||||||
|
.iter()
|
||||||
|
.map(|(key, label)| {
|
||||||
|
let mut txt = Text::new();
|
||||||
|
txt.append(Line(key.describe()).fg(ezgui::HOTKEY_COLOR));
|
||||||
|
txt.append(Line(format!(" - {}", label)));
|
||||||
|
ManagedWidget::btn(Button::text_bg(
|
||||||
|
txt,
|
||||||
|
colors::SECTION_BG,
|
||||||
|
colors::HOVERING,
|
||||||
|
hotkey(*key),
|
||||||
|
label,
|
||||||
|
ctx,
|
||||||
|
))
|
||||||
|
.margin(5)
|
||||||
|
})
|
||||||
|
.collect();
|
||||||
|
|
||||||
|
let mut col = info_for(ctx, ui, id.clone(), action_btns);
|
||||||
|
|
||||||
let trip_details = if let Some(trip) = match id {
|
let trip_details = if let Some(trip) = match id {
|
||||||
ID::Trip(t) => Some(t),
|
ID::Trip(t) => Some(t),
|
||||||
@ -67,23 +85,6 @@ impl InfoPanel {
|
|||||||
None
|
None
|
||||||
};
|
};
|
||||||
|
|
||||||
for (key, label) in &actions {
|
|
||||||
let mut txt = Text::new();
|
|
||||||
txt.append(Line(key.describe()).fg(ezgui::HOTKEY_COLOR));
|
|
||||||
txt.append(Line(format!(" - {}", label)));
|
|
||||||
col.push(
|
|
||||||
ManagedWidget::btn(Button::text_bg(
|
|
||||||
txt,
|
|
||||||
colors::SECTION_BG,
|
|
||||||
colors::HOVERING,
|
|
||||||
hotkey(*key),
|
|
||||||
label,
|
|
||||||
ctx,
|
|
||||||
))
|
|
||||||
.margin(5),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Follow the agent. When the sim is paused, this lets the player naturally pan away,
|
// Follow the agent. When the sim is paused, this lets the player naturally pan away,
|
||||||
// because the InfoPanel isn't being updated.
|
// because the InfoPanel isn't being updated.
|
||||||
// TODO Should we pin to the trip, not the specific agent?
|
// TODO Should we pin to the trip, not the specific agent?
|
||||||
@ -261,7 +262,12 @@ impl InfoPanel {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn info_for(id: ID, ctx: &EventCtx, ui: &UI) -> Vec<ManagedWidget> {
|
fn info_for(
|
||||||
|
ctx: &EventCtx,
|
||||||
|
ui: &UI,
|
||||||
|
id: ID,
|
||||||
|
action_btns: Vec<ManagedWidget>,
|
||||||
|
) -> Vec<ManagedWidget> {
|
||||||
let (map, sim, draw_map) = (&ui.primary.map, &ui.primary.sim, &ui.primary.draw_map);
|
let (map, sim, draw_map) = (&ui.primary.map, &ui.primary.sim, &ui.primary.draw_map);
|
||||||
let header_btns = ManagedWidget::row(vec![
|
let header_btns = ManagedWidget::row(vec![
|
||||||
ManagedWidget::btn(Button::rectangle_svg(
|
ManagedWidget::btn(Button::rectangle_svg(
|
||||||
@ -298,6 +304,7 @@ fn info_for(id: ID, ctx: &EventCtx, ui: &UI) -> Vec<ManagedWidget> {
|
|||||||
Text::from(Line(format!("@ {}", r.get_name()))),
|
Text::from(Line(format!("@ {}", r.get_name()))),
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
rows.extend(action_btns);
|
||||||
|
|
||||||
// Properties
|
// Properties
|
||||||
{
|
{
|
||||||
@ -396,6 +403,8 @@ fn info_for(id: ID, ctx: &EventCtx, ui: &UI) -> Vec<ManagedWidget> {
|
|||||||
txt.add(Line(format!("- {}", r)));
|
txt.add(Line(format!("- {}", r)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
rows.extend(action_btns);
|
||||||
|
|
||||||
let trip_lines = sim.count_trips_involving_border(id).describe();
|
let trip_lines = sim.count_trips_involving_border(id).describe();
|
||||||
if !trip_lines.is_empty() {
|
if !trip_lines.is_empty() {
|
||||||
txt.add(Line(""));
|
txt.add(Line(""));
|
||||||
@ -404,7 +413,6 @@ fn info_for(id: ID, ctx: &EventCtx, ui: &UI) -> Vec<ManagedWidget> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
txt.add(Line(""));
|
|
||||||
txt.add(Line("Throughput").roboto_bold());
|
txt.add(Line("Throughput").roboto_bold());
|
||||||
txt.add(Line(format!(
|
txt.add(Line(format!(
|
||||||
"Since midnight: {} agents crossed",
|
"Since midnight: {} agents crossed",
|
||||||
@ -443,6 +451,7 @@ fn info_for(id: ID, ctx: &EventCtx, ui: &UI) -> Vec<ManagedWidget> {
|
|||||||
header_btns,
|
header_btns,
|
||||||
]));
|
]));
|
||||||
}
|
}
|
||||||
|
rows.extend(action_btns);
|
||||||
|
|
||||||
// Properties
|
// Properties
|
||||||
{
|
{
|
||||||
@ -528,6 +537,7 @@ fn info_for(id: ID, ctx: &EventCtx, ui: &UI) -> Vec<ManagedWidget> {
|
|||||||
header_btns,
|
header_btns,
|
||||||
]));
|
]));
|
||||||
}
|
}
|
||||||
|
rows.extend(action_btns);
|
||||||
|
|
||||||
let (kv, extra) = sim.car_properties(id, map);
|
let (kv, extra) = sim.car_properties(id, map);
|
||||||
rows.extend(make_table(ctx, kv));
|
rows.extend(make_table(ctx, kv));
|
||||||
@ -550,6 +560,7 @@ fn info_for(id: ID, ctx: &EventCtx, ui: &UI) -> Vec<ManagedWidget> {
|
|||||||
header_btns,
|
header_btns,
|
||||||
]));
|
]));
|
||||||
}
|
}
|
||||||
|
rows.extend(action_btns);
|
||||||
|
|
||||||
let (kv, extra) = sim.ped_properties(id, map);
|
let (kv, extra) = sim.ped_properties(id, map);
|
||||||
rows.extend(make_table(ctx, kv));
|
rows.extend(make_table(ctx, kv));
|
||||||
@ -572,6 +583,7 @@ fn info_for(id: ID, ctx: &EventCtx, ui: &UI) -> Vec<ManagedWidget> {
|
|||||||
header_btns,
|
header_btns,
|
||||||
]));
|
]));
|
||||||
}
|
}
|
||||||
|
rows.extend(action_btns);
|
||||||
|
|
||||||
let mut txt = Text::new();
|
let mut txt = Text::new();
|
||||||
txt.add(Line(format!("Crowd of {}", members.len())));
|
txt.add(Line(format!("Crowd of {}", members.len())));
|
||||||
@ -585,6 +597,7 @@ fn info_for(id: ID, ctx: &EventCtx, ui: &UI) -> Vec<ManagedWidget> {
|
|||||||
header_btns,
|
header_btns,
|
||||||
]));
|
]));
|
||||||
}
|
}
|
||||||
|
rows.extend(action_btns);
|
||||||
|
|
||||||
let mut txt = Text::new();
|
let mut txt = Text::new();
|
||||||
txt.add(Line(format!(
|
txt.add(Line(format!(
|
||||||
@ -627,6 +640,7 @@ fn info_for(id: ID, ctx: &EventCtx, ui: &UI) -> Vec<ManagedWidget> {
|
|||||||
header_btns,
|
header_btns,
|
||||||
]));
|
]));
|
||||||
}
|
}
|
||||||
|
rows.extend(action_btns);
|
||||||
|
|
||||||
let a = map.get_a(id);
|
let a = map.get_a(id);
|
||||||
let mut kv = Vec::new();
|
let mut kv = Vec::new();
|
||||||
@ -646,6 +660,7 @@ fn info_for(id: ID, ctx: &EventCtx, ui: &UI) -> Vec<ManagedWidget> {
|
|||||||
header_btns,
|
header_btns,
|
||||||
]));
|
]));
|
||||||
}
|
}
|
||||||
|
rows.extend(action_btns);
|
||||||
|
|
||||||
let es = draw_map.get_es(id);
|
let es = draw_map.get_es(id);
|
||||||
let mut kv = Vec::new();
|
let mut kv = Vec::new();
|
||||||
|
Loading…
Reference in New Issue
Block a user