mirror of
https://github.com/a-b-street/abstreet.git
synced 2025-01-04 04:23:25 +03:00
change the colorscheme method name to find more easily in parsing
This commit is contained in:
parent
9d653b103d
commit
010a636ae6
@ -5,7 +5,7 @@ use std::collections::{BTreeMap, HashMap};
|
|||||||
use std::io::Error;
|
use std::io::Error;
|
||||||
|
|
||||||
pub struct ColorScheme {
|
pub struct ColorScheme {
|
||||||
// Filled out by lazy calls to get()
|
// Filled out by lazy calls to get_def()
|
||||||
map: HashMap<String, Color>,
|
map: HashMap<String, Color>,
|
||||||
|
|
||||||
// A subset of map
|
// A subset of map
|
||||||
@ -32,7 +32,8 @@ impl ColorScheme {
|
|||||||
abstutil::write_json("color_scheme", &self.modified).expect("Saving color_scheme failed");
|
abstutil::write_json("color_scheme", &self.modified).expect("Saving color_scheme failed");
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn get(&mut self, name: &str, default: Color) -> Color {
|
// Get, but specify the default inline
|
||||||
|
pub fn get_def(&mut self, name: &str, default: Color) -> Color {
|
||||||
if let Some(existing) = self.map.get(name) {
|
if let Some(existing) = self.map.get(name) {
|
||||||
if default != *existing && !self.modified.map.contains_key(name) {
|
if default != *existing && !self.modified.map.contains_key(name) {
|
||||||
panic!(
|
panic!(
|
||||||
|
@ -7,7 +7,7 @@ def run():
|
|||||||
|
|
||||||
for path, _, files in os.walk('.'):
|
for path, _, files in os.walk('.'):
|
||||||
for f in files:
|
for f in files:
|
||||||
if f.endswith('.rs') and f != 'colors.rs' and f != 'objects.rs':
|
if f.endswith('.rs') and f != 'colors.rs':
|
||||||
for k, v in read_file(os.path.join(path, f)):
|
for k, v in read_file(os.path.join(path, f)):
|
||||||
# TODO Check for double-definitions
|
# TODO Check for double-definitions
|
||||||
mapping[k] = v
|
mapping[k] = v
|
||||||
@ -17,13 +17,12 @@ def run():
|
|||||||
|
|
||||||
|
|
||||||
def read_file(filename):
|
def read_file(filename):
|
||||||
print filename
|
|
||||||
entries = []
|
entries = []
|
||||||
with open(filename, 'r') as f:
|
with open(filename, 'r') as f:
|
||||||
src = ''.join(f.readlines())
|
src = ''.join(f.readlines())
|
||||||
while src:
|
while src:
|
||||||
if src.startswith('get('):
|
if src.startswith('get_def('):
|
||||||
src = src[len('get('):]
|
src = src[len('get_def('):]
|
||||||
|
|
||||||
# Look for the opening "
|
# Look for the opening "
|
||||||
while src[0] != '"':
|
while src[0] != '"':
|
||||||
@ -46,7 +45,7 @@ def read_file(filename):
|
|||||||
while not src.startswith('Color'):
|
while not src.startswith('Color'):
|
||||||
src = src[1:]
|
src = src[1:]
|
||||||
|
|
||||||
# Wait for the ()'s to be mismatched, meaning we found the ) of the get()
|
# Wait for the ()'s to be mismatched, meaning we found the ) of the get_def()
|
||||||
counter = 0
|
counter = 0
|
||||||
value = ''
|
value = ''
|
||||||
while True:
|
while True:
|
||||||
|
@ -39,7 +39,7 @@ impl Plugin for ChokepointsFinder {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn color_for(&self, obj: ID, ctx: &mut Ctx) -> Option<Color> {
|
fn color_for(&self, obj: ID, ctx: &mut Ctx) -> Option<Color> {
|
||||||
let color = ctx.cs.get("chokepoint", Color::RED);
|
let color = ctx.cs.get_def("chokepoint", Color::RED);
|
||||||
match obj {
|
match obj {
|
||||||
ID::Lane(l) if self.lanes.contains(&l) => Some(color),
|
ID::Lane(l) if self.lanes.contains(&l) => Some(color),
|
||||||
ID::Intersection(i) if self.intersections.contains(&i) => Some(color),
|
ID::Intersection(i) if self.intersections.contains(&i) => Some(color),
|
||||||
|
@ -38,19 +38,19 @@ impl Plugin for OsmClassifier {
|
|||||||
{
|
{
|
||||||
// From https://wiki.openstreetmap.org/wiki/Map_Features#Highway
|
// From https://wiki.openstreetmap.org/wiki/Map_Features#Highway
|
||||||
Some("motorway") | Some("motorway_link") => {
|
Some("motorway") | Some("motorway_link") => {
|
||||||
Some(ctx.cs.get("OSM motorway", Color::rgb(231, 141, 159)))
|
Some(ctx.cs.get_def("OSM motorway", Color::rgb(231, 141, 159)))
|
||||||
}
|
}
|
||||||
Some("trunk") | Some("trunk_link") => {
|
Some("trunk") | Some("trunk_link") => {
|
||||||
Some(ctx.cs.get("OSM trunk", Color::rgb(249, 175, 152)))
|
Some(ctx.cs.get_def("OSM trunk", Color::rgb(249, 175, 152)))
|
||||||
}
|
}
|
||||||
Some("primary") | Some("primary_link") => {
|
Some("primary") | Some("primary_link") => {
|
||||||
Some(ctx.cs.get("OSM primary", Color::rgb(252, 213, 160)))
|
Some(ctx.cs.get_def("OSM primary", Color::rgb(252, 213, 160)))
|
||||||
}
|
}
|
||||||
Some("secondary") | Some("secondary_link") => {
|
Some("secondary") | Some("secondary_link") => {
|
||||||
Some(ctx.cs.get("OSM secondary", Color::rgb(252, 213, 160)))
|
Some(ctx.cs.get_def("OSM secondary", Color::rgb(252, 213, 160)))
|
||||||
}
|
}
|
||||||
Some("residential") => {
|
Some("residential") => {
|
||||||
Some(ctx.cs.get("OSM residential", Color::rgb(254, 254, 254)))
|
Some(ctx.cs.get_def("OSM residential", Color::rgb(254, 254, 254)))
|
||||||
}
|
}
|
||||||
_ => None,
|
_ => None,
|
||||||
}
|
}
|
||||||
@ -60,7 +60,7 @@ impl Plugin for OsmClassifier {
|
|||||||
}
|
}
|
||||||
ID::Building(b) => {
|
ID::Building(b) => {
|
||||||
if ctx.map.get_b(b).osm_tags.contains_key("addr:housenumber") {
|
if ctx.map.get_b(b).osm_tags.contains_key("addr:housenumber") {
|
||||||
Some(ctx.cs.get("OSM house", Color::GREEN))
|
Some(ctx.cs.get_def("OSM house", Color::GREEN))
|
||||||
} else {
|
} else {
|
||||||
None
|
None
|
||||||
}
|
}
|
||||||
|
@ -58,14 +58,14 @@ impl Plugin for Floodfiller {
|
|||||||
fn color_for(&self, obj: ID, ctx: &mut Ctx) -> Option<Color> {
|
fn color_for(&self, obj: ID, ctx: &mut Ctx) -> Option<Color> {
|
||||||
if let ID::Lane(l) = obj {
|
if let ID::Lane(l) = obj {
|
||||||
if self.visited.contains(&l) {
|
if self.visited.contains(&l) {
|
||||||
return Some(ctx.cs.get("visited in floodfill", Color::BLUE));
|
return Some(ctx.cs.get_def("visited in floodfill", Color::BLUE));
|
||||||
}
|
}
|
||||||
if !self.queue.is_empty() && *self.queue.front().unwrap() == l {
|
if !self.queue.is_empty() && *self.queue.front().unwrap() == l {
|
||||||
return Some(ctx.cs.get("next to visit in floodfill", Color::GREEN));
|
return Some(ctx.cs.get_def("next to visit in floodfill", Color::GREEN));
|
||||||
}
|
}
|
||||||
// TODO linear search shouldnt suck too much for interactive mode
|
// TODO linear search shouldnt suck too much for interactive mode
|
||||||
if self.queue.contains(&l) {
|
if self.queue.contains(&l) {
|
||||||
return Some(ctx.cs.get("queued in floodfill", Color::RED));
|
return Some(ctx.cs.get_def("queued in floodfill", Color::RED));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
None
|
None
|
||||||
|
@ -112,7 +112,7 @@ impl Plugin for DrawNeighborhoodState {
|
|||||||
|
|
||||||
if pts.len() == 2 {
|
if pts.len() == 2 {
|
||||||
g.draw_line(
|
g.draw_line(
|
||||||
ctx.cs.get("neighborhood point", Color::RED),
|
ctx.cs.get_def("neighborhood point", Color::RED),
|
||||||
POINT_RADIUS / 2.0,
|
POINT_RADIUS / 2.0,
|
||||||
&Line::new(pts[0], pts[1]),
|
&Line::new(pts[0], pts[1]),
|
||||||
);
|
);
|
||||||
@ -120,25 +120,26 @@ impl Plugin for DrawNeighborhoodState {
|
|||||||
if pts.len() >= 3 {
|
if pts.len() >= 3 {
|
||||||
g.draw_polygon(
|
g.draw_polygon(
|
||||||
ctx.cs
|
ctx.cs
|
||||||
.get("neighborhood polygon", Color::rgba(0, 0, 255, 0.6)),
|
.get_def("neighborhood polygon", Color::rgba(0, 0, 255, 0.6)),
|
||||||
&Polygon::new(&pts),
|
&Polygon::new(&pts),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
for pt in &pts {
|
for pt in &pts {
|
||||||
g.draw_circle(
|
g.draw_circle(
|
||||||
ctx.cs.get("neighborhood point", Color::RED),
|
ctx.cs.get_def("neighborhood point", Color::RED),
|
||||||
&Circle::new(*pt, POINT_RADIUS),
|
&Circle::new(*pt, POINT_RADIUS),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
if let Some(last) = pts.last() {
|
if let Some(last) = pts.last() {
|
||||||
g.draw_circle(
|
g.draw_circle(
|
||||||
ctx.cs.get("neighborhood last placed point", Color::GREEN),
|
ctx.cs
|
||||||
|
.get_def("neighborhood last placed point", Color::GREEN),
|
||||||
&Circle::new(*last, POINT_RADIUS),
|
&Circle::new(*last, POINT_RADIUS),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
if let Some(idx) = current_idx {
|
if let Some(idx) = current_idx {
|
||||||
g.draw_circle(
|
g.draw_circle(
|
||||||
ctx.cs.get("neighborhood point to move", Color::CYAN),
|
ctx.cs.get_def("neighborhood point to move", Color::CYAN),
|
||||||
&Circle::new(pts[idx], POINT_RADIUS),
|
&Circle::new(pts[idx], POINT_RADIUS),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -80,7 +80,7 @@ impl Plugin for ScenarioManager {
|
|||||||
if let Some(neighborhood) = wizard.current_menu_choice::<Neighborhood>() {
|
if let Some(neighborhood) = wizard.current_menu_choice::<Neighborhood>() {
|
||||||
g.draw_polygon(
|
g.draw_polygon(
|
||||||
ctx.cs
|
ctx.cs
|
||||||
.get("neighborhood polygon", Color::rgba(0, 0, 255, 0.6)),
|
.get_def("neighborhood polygon", Color::rgba(0, 0, 255, 0.6)),
|
||||||
&neighborhood.polygon,
|
&neighborhood.polygon,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -73,10 +73,12 @@ impl Plugin for StopSignEditor {
|
|||||||
return None;
|
return None;
|
||||||
}
|
}
|
||||||
match ctx.map.get_stop_sign(self.i).get_priority(t) {
|
match ctx.map.get_stop_sign(self.i).get_priority(t) {
|
||||||
TurnPriority::Priority => Some(ctx.cs.get("priority stop sign turn", Color::GREEN)),
|
TurnPriority::Priority => {
|
||||||
TurnPriority::Yield => Some(ctx.cs.get("yield stop sign turn", Color::YELLOW)),
|
Some(ctx.cs.get_def("priority stop sign turn", Color::GREEN))
|
||||||
TurnPriority::Stop => Some(ctx.cs.get("stop turn", Color::RED)),
|
}
|
||||||
TurnPriority::Banned => Some(ctx.cs.get("banned turn", Color::BLACK)),
|
TurnPriority::Yield => Some(ctx.cs.get_def("yield stop sign turn", Color::YELLOW)),
|
||||||
|
TurnPriority::Stop => Some(ctx.cs.get_def("stop turn", Color::RED)),
|
||||||
|
TurnPriority::Banned => Some(ctx.cs.get_def("banned turn", Color::BLACK)),
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
None
|
None
|
||||||
|
@ -237,7 +237,8 @@ impl Plugin for TrafficSignalEditor {
|
|||||||
|
|
||||||
let old_ctx = g.fork_screenspace();
|
let old_ctx = g.fork_screenspace();
|
||||||
g.draw_polygon(
|
g.draw_polygon(
|
||||||
ctx.cs.get("signal editor panel", Color::BLACK.alpha(0.95)),
|
ctx.cs
|
||||||
|
.get_def("signal editor panel", Color::BLACK.alpha(0.95)),
|
||||||
&Polygon::rectangle_topleft(
|
&Polygon::rectangle_topleft(
|
||||||
Pt2D::new(10.0, 10.0),
|
Pt2D::new(10.0, 10.0),
|
||||||
2.0 * width * zoom,
|
2.0 * width * zoom,
|
||||||
@ -247,7 +248,7 @@ impl Plugin for TrafficSignalEditor {
|
|||||||
// TODO Padding and offsets all a bit off. Abstractions are a bit awkward. Want to
|
// TODO Padding and offsets all a bit off. Abstractions are a bit awkward. Want to
|
||||||
// center a map-space thing inside a screen-space box.
|
// center a map-space thing inside a screen-space box.
|
||||||
g.draw_polygon(
|
g.draw_polygon(
|
||||||
ctx.cs.get(
|
ctx.cs.get_def(
|
||||||
"current cycle in signal editor panel",
|
"current cycle in signal editor panel",
|
||||||
Color::BLUE.alpha(0.95),
|
Color::BLUE.alpha(0.95),
|
||||||
),
|
),
|
||||||
@ -292,7 +293,7 @@ impl Plugin for TrafficSignalEditor {
|
|||||||
DrawTurn::draw_full(
|
DrawTurn::draw_full(
|
||||||
ctx.map.get_t(id),
|
ctx.map.get_t(id),
|
||||||
g,
|
g,
|
||||||
ctx.cs.get("selected turn icon", Color::BLUE.alpha(0.5)),
|
ctx.cs.get_def("selected turn icon", Color::BLUE.alpha(0.5)),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -311,13 +312,13 @@ impl Plugin for TrafficSignalEditor {
|
|||||||
let cycle = &ctx.map.get_traffic_signal(self.i).cycles[self.current_cycle];
|
let cycle = &ctx.map.get_traffic_signal(self.i).cycles[self.current_cycle];
|
||||||
|
|
||||||
return Some(match cycle.get_priority(t) {
|
return Some(match cycle.get_priority(t) {
|
||||||
TurnPriority::Priority => {
|
TurnPriority::Priority => ctx
|
||||||
ctx.cs.get("priority turn in current cycle", Color::GREEN)
|
.cs
|
||||||
}
|
.get_def("priority turn in current cycle", Color::GREEN),
|
||||||
TurnPriority::Yield => ctx
|
TurnPriority::Yield => ctx
|
||||||
.cs
|
.cs
|
||||||
.get("yield turn in current cycle", Color::rgb(255, 105, 180)),
|
.get_def("yield turn in current cycle", Color::rgb(255, 105, 180)),
|
||||||
TurnPriority::Banned => ctx.cs.get("turn not in current cycle", Color::BLACK),
|
TurnPriority::Banned => ctx.cs.get_def("turn not in current cycle", Color::BLACK),
|
||||||
TurnPriority::Stop => panic!("Can't have TurnPriority::Stop in a traffic signal"),
|
TurnPriority::Stop => panic!("Can't have TurnPriority::Stop in a traffic signal"),
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -47,7 +47,7 @@ impl Plugin for DiffAllState {
|
|||||||
fn draw(&self, g: &mut GfxCtx, ctx: &mut Ctx) {
|
fn draw(&self, g: &mut GfxCtx, ctx: &mut Ctx) {
|
||||||
for line in &self.lines {
|
for line in &self.lines {
|
||||||
g.draw_line(
|
g.draw_line(
|
||||||
ctx.cs.get("diff agents line", Color::YELLOW),
|
ctx.cs.get_def("diff agents line", Color::YELLOW),
|
||||||
LANE_THICKNESS,
|
LANE_THICKNESS,
|
||||||
line,
|
line,
|
||||||
);
|
);
|
||||||
|
@ -50,7 +50,7 @@ impl Plugin for DiffTripState {
|
|||||||
fn draw(&self, g: &mut GfxCtx, ctx: &mut Ctx) {
|
fn draw(&self, g: &mut GfxCtx, ctx: &mut Ctx) {
|
||||||
if let Some(l) = &self.line {
|
if let Some(l) = &self.line {
|
||||||
g.draw_line(
|
g.draw_line(
|
||||||
ctx.cs.get("diff agents line", Color::YELLOW),
|
ctx.cs.get_def("diff agents line", Color::YELLOW),
|
||||||
LANE_THICKNESS,
|
LANE_THICKNESS,
|
||||||
l,
|
l,
|
||||||
);
|
);
|
||||||
@ -58,14 +58,14 @@ impl Plugin for DiffTripState {
|
|||||||
if let Some(t) = &self.primary_route {
|
if let Some(t) = &self.primary_route {
|
||||||
g.draw_polygon(
|
g.draw_polygon(
|
||||||
ctx.cs
|
ctx.cs
|
||||||
.get("primary agent route", Color::rgba(255, 0, 0, 0.5)),
|
.get_def("primary agent route", Color::rgba(255, 0, 0, 0.5)),
|
||||||
&t.make_polygons_blindly(LANE_THICKNESS),
|
&t.make_polygons_blindly(LANE_THICKNESS),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
if let Some(t) = &self.secondary_route {
|
if let Some(t) = &self.secondary_route {
|
||||||
g.draw_polygon(
|
g.draw_polygon(
|
||||||
ctx.cs
|
ctx.cs
|
||||||
.get("secondary agent route", Color::rgba(0, 0, 255, 0.5)),
|
.get_def("secondary agent route", Color::rgba(0, 0, 255, 0.5)),
|
||||||
&t.make_polygons_blindly(LANE_THICKNESS),
|
&t.make_polygons_blindly(LANE_THICKNESS),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -71,7 +71,7 @@ impl Plugin for SearchState {
|
|||||||
};
|
};
|
||||||
for (k, v) in osm_tags {
|
for (k, v) in osm_tags {
|
||||||
if format!("{}={}", k, v).contains(filter) {
|
if format!("{}={}", k, v).contains(filter) {
|
||||||
return Some(ctx.cs.get("search result", Color::RED));
|
return Some(ctx.cs.get_def("search result", Color::RED));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -65,7 +65,7 @@ impl Plugin for ShowOwnerState {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fn color_for(&self, obj: ID, ctx: &mut Ctx) -> Option<Color> {
|
fn color_for(&self, obj: ID, ctx: &mut Ctx) -> Option<Color> {
|
||||||
let color = ctx.cs.get("car/building owner", Color::PURPLE);
|
let color = ctx.cs.get_def("car/building owner", Color::PURPLE);
|
||||||
match (self, obj) {
|
match (self, obj) {
|
||||||
(ShowOwnerState::BuildingSelected(_, cars), ID::Car(id)) => {
|
(ShowOwnerState::BuildingSelected(_, cars), ID::Car(id)) => {
|
||||||
if cars.contains(&id) {
|
if cars.contains(&id) {
|
||||||
|
@ -73,14 +73,14 @@ impl Plugin for ShowRouteState {
|
|||||||
match &self.state {
|
match &self.state {
|
||||||
State::Active(_, _, Some(trace)) => {
|
State::Active(_, _, Some(trace)) => {
|
||||||
g.draw_polygon(
|
g.draw_polygon(
|
||||||
ctx.cs.get("route", Color::rgba(255, 0, 0, 0.8)),
|
ctx.cs.get_def("route", Color::rgba(255, 0, 0, 0.8)),
|
||||||
&trace.make_polygons_blindly(LANE_THICKNESS),
|
&trace.make_polygons_blindly(LANE_THICKNESS),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
State::DebugAllRoutes(_, traces) => {
|
State::DebugAllRoutes(_, traces) => {
|
||||||
for t in traces {
|
for t in traces {
|
||||||
g.draw_polygon(
|
g.draw_polygon(
|
||||||
ctx.cs.get("route", Color::rgba(255, 0, 0, 0.8)),
|
ctx.cs.get_def("route", Color::rgba(255, 0, 0, 0.8)),
|
||||||
&t.make_polygons_blindly(LANE_THICKNESS),
|
&t.make_polygons_blindly(LANE_THICKNESS),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -77,12 +77,12 @@ impl Plugin for TurnCyclerState {
|
|||||||
for turn in &ctx.map.get_turns_from_lane(l) {
|
for turn in &ctx.map.get_turns_from_lane(l) {
|
||||||
let color = match turn.turn_type {
|
let color = match turn.turn_type {
|
||||||
TurnType::SharedSidewalkCorner => {
|
TurnType::SharedSidewalkCorner => {
|
||||||
ctx.cs.get("shared sidewalk corner turn", Color::BLACK)
|
ctx.cs.get_def("shared sidewalk corner turn", Color::BLACK)
|
||||||
}
|
}
|
||||||
TurnType::Crosswalk => ctx.cs.get("crosswalk turn", Color::WHITE),
|
TurnType::Crosswalk => ctx.cs.get_def("crosswalk turn", Color::WHITE),
|
||||||
TurnType::Straight => ctx.cs.get("straight turn", Color::BLUE),
|
TurnType::Straight => ctx.cs.get_def("straight turn", Color::BLUE),
|
||||||
TurnType::Right => ctx.cs.get("right turn", Color::GREEN),
|
TurnType::Right => ctx.cs.get_def("right turn", Color::GREEN),
|
||||||
TurnType::Left => ctx.cs.get("left turn", Color::RED),
|
TurnType::Left => ctx.cs.get_def("left turn", Color::RED),
|
||||||
}
|
}
|
||||||
.alpha(0.5);
|
.alpha(0.5);
|
||||||
DrawTurn::draw_full(turn, g, color);
|
DrawTurn::draw_full(turn, g, color);
|
||||||
@ -94,7 +94,7 @@ impl Plugin for TurnCyclerState {
|
|||||||
DrawTurn::draw_full(
|
DrawTurn::draw_full(
|
||||||
turns[idx % turns.len()],
|
turns[idx % turns.len()],
|
||||||
g,
|
g,
|
||||||
ctx.cs.get("current selected turn", Color::RED),
|
ctx.cs.get_def("current selected turn", Color::RED),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -119,11 +119,11 @@ impl Plugin for TurnCyclerState {
|
|||||||
let width = 50.0;
|
let width = 50.0;
|
||||||
let height = 100.0;
|
let height = 100.0;
|
||||||
g.draw_polygon(
|
g.draw_polygon(
|
||||||
ctx.cs.get("timer foreground", Color::RED),
|
ctx.cs.get_def("timer foreground", Color::RED),
|
||||||
&Polygon::rectangle_topleft(Pt2D::new(10.0, 10.0), width, height),
|
&Polygon::rectangle_topleft(Pt2D::new(10.0, 10.0), width, height),
|
||||||
);
|
);
|
||||||
g.draw_polygon(
|
g.draw_polygon(
|
||||||
ctx.cs.get("timer background", Color::BLACK),
|
ctx.cs.get_def("timer background", Color::BLACK),
|
||||||
&Polygon::rectangle_topleft(
|
&Polygon::rectangle_topleft(
|
||||||
Pt2D::new(10.0, 10.0),
|
Pt2D::new(10.0, 10.0),
|
||||||
width,
|
width,
|
||||||
|
@ -28,9 +28,9 @@ impl Renderable for DrawArea {
|
|||||||
|
|
||||||
fn draw(&self, g: &mut GfxCtx, opts: RenderOptions, ctx: &mut Ctx) {
|
fn draw(&self, g: &mut GfxCtx, opts: RenderOptions, ctx: &mut Ctx) {
|
||||||
let color = match self.area_type {
|
let color = match self.area_type {
|
||||||
AreaType::Park => ctx.cs.get("park area", Color::GREEN),
|
AreaType::Park => ctx.cs.get_def("park area", Color::GREEN),
|
||||||
AreaType::Swamp => ctx.cs.get("swamp area", Color::rgb_f(0.0, 1.0, 0.6)),
|
AreaType::Swamp => ctx.cs.get_def("swamp area", Color::rgb_f(0.0, 1.0, 0.6)),
|
||||||
AreaType::Water => ctx.cs.get("water area", Color::BLUE),
|
AreaType::Water => ctx.cs.get_def("water area", Color::BLUE),
|
||||||
};
|
};
|
||||||
g.draw_polygon(opts.color.unwrap_or(color), &self.fill_polygon);
|
g.draw_polygon(opts.color.unwrap_or(color), &self.fill_polygon);
|
||||||
}
|
}
|
||||||
|
@ -46,11 +46,11 @@ impl Renderable for DrawBike {
|
|||||||
match self.state {
|
match self.state {
|
||||||
CarState::Debug => ctx
|
CarState::Debug => ctx
|
||||||
.cs
|
.cs
|
||||||
.get("debug bike", Color::rgba(0, 0, 255, 0.8))
|
.get_def("debug bike", Color::rgba(0, 0, 255, 0.8))
|
||||||
.shift(self.id.0),
|
.shift(self.id.0),
|
||||||
// TODO Hard to see on the greenish bike lanes? :P
|
// TODO Hard to see on the greenish bike lanes? :P
|
||||||
CarState::Moving => ctx.cs.get("moving bike", Color::GREEN).shift(self.id.0),
|
CarState::Moving => ctx.cs.get_def("moving bike", Color::GREEN).shift(self.id.0),
|
||||||
CarState::Stuck => ctx.cs.get("stuck bike", Color::RED).shift(self.id.0),
|
CarState::Stuck => ctx.cs.get_def("stuck bike", Color::RED).shift(self.id.0),
|
||||||
CarState::Parked => panic!("Can't have a parked bike"),
|
CarState::Parked => panic!("Can't have a parked bike"),
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -59,7 +59,7 @@ impl Renderable for DrawBike {
|
|||||||
if let Some(ref t) = self.stopping_buffer {
|
if let Some(ref t) = self.stopping_buffer {
|
||||||
g.draw_polygon(
|
g.draw_polygon(
|
||||||
ctx.cs
|
ctx.cs
|
||||||
.get("bike stopping buffer", Color::rgba(255, 0, 0, 0.7)),
|
.get_def("bike stopping buffer", Color::rgba(255, 0, 0, 0.7)),
|
||||||
t,
|
t,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -39,15 +39,17 @@ impl Renderable for DrawBuilding {
|
|||||||
|
|
||||||
fn draw(&self, g: &mut GfxCtx, opts: RenderOptions, ctx: &mut Ctx) {
|
fn draw(&self, g: &mut GfxCtx, opts: RenderOptions, ctx: &mut Ctx) {
|
||||||
// Buildings look better without boundaries, actually
|
// Buildings look better without boundaries, actually
|
||||||
//g.draw_polygon(ctx.cs.get("building boundary", Color::rgb(0, 100, 0)), &self.boundary_polygon);
|
//g.draw_polygon(ctx.cs.get_def("building boundary", Color::rgb(0, 100, 0)), &self.boundary_polygon);
|
||||||
g.draw_polygon(
|
g.draw_polygon(
|
||||||
opts.color
|
opts.color.unwrap_or_else(|| {
|
||||||
.unwrap_or_else(|| ctx.cs.get("building", Color::rgba_f(0.7, 0.7, 0.7, 0.8))),
|
ctx.cs
|
||||||
|
.get_def("building", Color::rgba_f(0.7, 0.7, 0.7, 0.8))
|
||||||
|
}),
|
||||||
&self.fill_polygon,
|
&self.fill_polygon,
|
||||||
);
|
);
|
||||||
|
|
||||||
g.draw_line(
|
g.draw_line(
|
||||||
ctx.cs.get("building path", Color::grey(0.6)),
|
ctx.cs.get_def("building path", Color::grey(0.6)),
|
||||||
1.0,
|
1.0,
|
||||||
&self.front_path,
|
&self.front_path,
|
||||||
);
|
);
|
||||||
|
@ -44,7 +44,7 @@ impl Renderable for DrawBusStop {
|
|||||||
g.draw_polygon(
|
g.draw_polygon(
|
||||||
opts.color.unwrap_or_else(|| {
|
opts.color.unwrap_or_else(|| {
|
||||||
ctx.cs
|
ctx.cs
|
||||||
.get("bus stop marking", Color::rgba(220, 160, 220, 0.8))
|
.get_def("bus stop marking", Color::rgba(220, 160, 220, 0.8))
|
||||||
}),
|
}),
|
||||||
&self.polygon,
|
&self.polygon,
|
||||||
);
|
);
|
||||||
|
@ -95,30 +95,30 @@ impl Renderable for DrawCar {
|
|||||||
match self.state {
|
match self.state {
|
||||||
CarState::Debug => ctx
|
CarState::Debug => ctx
|
||||||
.cs
|
.cs
|
||||||
.get("debug car", Color::rgba(0, 0, 255, 0.8))
|
.get_def("debug car", Color::rgba(0, 0, 255, 0.8))
|
||||||
.shift(self.id.0),
|
.shift(self.id.0),
|
||||||
CarState::Moving => ctx.cs.get("moving car", Color::CYAN).shift(self.id.0),
|
CarState::Moving => ctx.cs.get_def("moving car", Color::CYAN).shift(self.id.0),
|
||||||
CarState::Stuck => ctx.cs.get("stuck car", Color::RED).shift(self.id.0),
|
CarState::Stuck => ctx.cs.get_def("stuck car", Color::RED).shift(self.id.0),
|
||||||
CarState::Parked => ctx
|
CarState::Parked => ctx
|
||||||
.cs
|
.cs
|
||||||
.get("parked car", Color::rgb(180, 233, 76))
|
.get_def("parked car", Color::rgb(180, 233, 76))
|
||||||
.shift(self.id.0),
|
.shift(self.id.0),
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
g.draw_polygon(color, &self.body_polygon);
|
g.draw_polygon(color, &self.body_polygon);
|
||||||
for p in &self.window_polygons {
|
for p in &self.window_polygons {
|
||||||
g.draw_polygon(ctx.cs.get("car window", Color::BLACK), p);
|
g.draw_polygon(ctx.cs.get_def("car window", Color::BLACK), p);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO tune color, sizes
|
// TODO tune color, sizes
|
||||||
if let Some(ref a) = self.turn_arrow {
|
if let Some(ref a) = self.turn_arrow {
|
||||||
g.draw_arrow(ctx.cs.get("car turn arrow", Color::CYAN), 0.25, 1.0, a);
|
g.draw_arrow(ctx.cs.get_def("car turn arrow", Color::CYAN), 0.25, 1.0, a);
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Some(ref t) = self.stopping_buffer {
|
if let Some(ref t) = self.stopping_buffer {
|
||||||
g.draw_polygon(
|
g.draw_polygon(
|
||||||
ctx.cs
|
ctx.cs
|
||||||
.get("car stopping buffer", Color::rgba(255, 0, 0, 0.7)),
|
.get_def("car stopping buffer", Color::rgba(255, 0, 0, 0.7)),
|
||||||
t,
|
t,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -95,7 +95,7 @@ impl Renderable for DrawExtraShape {
|
|||||||
fn draw(&self, g: &mut GfxCtx, opts: RenderOptions, ctx: &mut Ctx) {
|
fn draw(&self, g: &mut GfxCtx, opts: RenderOptions, ctx: &mut Ctx) {
|
||||||
let color = opts
|
let color = opts
|
||||||
.color
|
.color
|
||||||
.unwrap_or_else(|| ctx.cs.get("extra shape", Color::CYAN));
|
.unwrap_or_else(|| ctx.cs.get_def("extra shape", Color::CYAN));
|
||||||
match self.shape {
|
match self.shape {
|
||||||
Shape::Polygon(ref p) => g.draw_polygon(color, &p),
|
Shape::Polygon(ref p) => g.draw_polygon(color, &p),
|
||||||
Shape::Circle(ref c) => g.draw_circle(color, c),
|
Shape::Circle(ref c) => g.draw_circle(color, c),
|
||||||
|
@ -41,7 +41,7 @@ impl DrawIntersection {
|
|||||||
|
|
||||||
fn draw_stop_sign(&self, g: &mut GfxCtx, ctx: &mut Ctx) {
|
fn draw_stop_sign(&self, g: &mut GfxCtx, ctx: &mut Ctx) {
|
||||||
g.draw_polygon(
|
g.draw_polygon(
|
||||||
ctx.cs.get("stop sign background", Color::RED),
|
ctx.cs.get_def("stop sign background", Color::RED),
|
||||||
&Polygon::regular_polygon(self.center, 8, 1.5, Angle::new_degs(360.0 / 16.0)),
|
&Polygon::regular_polygon(self.center, 8, 1.5, Angle::new_degs(360.0 / 16.0)),
|
||||||
);
|
);
|
||||||
// TODO draw "STOP"
|
// TODO draw "STOP"
|
||||||
@ -51,22 +51,22 @@ impl DrawIntersection {
|
|||||||
let radius = 0.5;
|
let radius = 0.5;
|
||||||
|
|
||||||
g.draw_polygon(
|
g.draw_polygon(
|
||||||
ctx.cs.get("traffic signal box", Color::BLACK),
|
ctx.cs.get_def("traffic signal box", Color::BLACK),
|
||||||
&Polygon::rectangle(self.center, 4.0 * radius, 8.0 * radius),
|
&Polygon::rectangle(self.center, 4.0 * radius, 8.0 * radius),
|
||||||
);
|
);
|
||||||
|
|
||||||
g.draw_circle(
|
g.draw_circle(
|
||||||
ctx.cs.get("traffic signal yellow", Color::YELLOW),
|
ctx.cs.get_def("traffic signal yellow", Color::YELLOW),
|
||||||
&Circle::new(self.center, radius),
|
&Circle::new(self.center, radius),
|
||||||
);
|
);
|
||||||
|
|
||||||
g.draw_circle(
|
g.draw_circle(
|
||||||
ctx.cs.get("traffic signal green", Color::GREEN),
|
ctx.cs.get_def("traffic signal green", Color::GREEN),
|
||||||
&Circle::new(self.center.offset(0.0, radius * 2.0), radius),
|
&Circle::new(self.center.offset(0.0, radius * 2.0), radius),
|
||||||
);
|
);
|
||||||
|
|
||||||
g.draw_circle(
|
g.draw_circle(
|
||||||
ctx.cs.get("traffic signal red", Color::RED),
|
ctx.cs.get_def("traffic signal red", Color::RED),
|
||||||
&Circle::new(self.center.offset(0.0, radius * -2.0), radius),
|
&Circle::new(self.center.offset(0.0, radius * -2.0), radius),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@ -80,7 +80,9 @@ impl Renderable for DrawIntersection {
|
|||||||
fn draw(&self, g: &mut GfxCtx, opts: RenderOptions, ctx: &mut Ctx) {
|
fn draw(&self, g: &mut GfxCtx, opts: RenderOptions, ctx: &mut Ctx) {
|
||||||
let color = opts.color.unwrap_or_else(|| {
|
let color = opts.color.unwrap_or_else(|| {
|
||||||
if self.intersection_type == IntersectionType::Border {
|
if self.intersection_type == IntersectionType::Border {
|
||||||
return ctx.cs.get("border intersection", Color::rgb(50, 205, 50));
|
return ctx
|
||||||
|
.cs
|
||||||
|
.get_def("border intersection", Color::rgb(50, 205, 50));
|
||||||
}
|
}
|
||||||
|
|
||||||
let _changed = if let Some(s) = ctx.map.maybe_get_traffic_signal(self.id) {
|
let _changed = if let Some(s) = ctx.map.maybe_get_traffic_signal(self.id) {
|
||||||
@ -91,7 +93,7 @@ impl Renderable for DrawIntersection {
|
|||||||
false
|
false
|
||||||
};
|
};
|
||||||
// TODO Make some other way to view map edits. rgb_f(0.8, 0.6, 0.6) was distracting.
|
// TODO Make some other way to view map edits. rgb_f(0.8, 0.6, 0.6) was distracting.
|
||||||
ctx.cs.get("unchanged intersection", Color::grey(0.6))
|
ctx.cs.get_def("unchanged intersection", Color::grey(0.6))
|
||||||
});
|
});
|
||||||
g.draw_polygon(color, &self.polygon);
|
g.draw_polygon(color, &self.polygon);
|
||||||
|
|
||||||
@ -102,13 +104,13 @@ impl Renderable for DrawIntersection {
|
|||||||
*ctx.hints
|
*ctx.hints
|
||||||
.color_crosswalks
|
.color_crosswalks
|
||||||
.get(&crosswalk.id1)
|
.get(&crosswalk.id1)
|
||||||
.unwrap_or(&ctx.cs.get("crosswalk", Color::WHITE)),
|
.unwrap_or(&ctx.cs.get_def("crosswalk", Color::WHITE)),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for corner in &self.sidewalk_corners {
|
for corner in &self.sidewalk_corners {
|
||||||
g.draw_polygon(ctx.cs.get("sidewalk corner", Color::grey(0.7)), corner);
|
g.draw_polygon(ctx.cs.get_def("sidewalk corner", Color::grey(0.7)), corner);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ctx.hints.suppress_intersection_icon != Some(self.id) {
|
if ctx.hints.suppress_intersection_icon != Some(self.id) {
|
||||||
@ -173,15 +175,15 @@ pub fn draw_signal_cycle(
|
|||||||
draw_map: &DrawMap,
|
draw_map: &DrawMap,
|
||||||
hide_crosswalks: &HashSet<TurnID>,
|
hide_crosswalks: &HashSet<TurnID>,
|
||||||
) {
|
) {
|
||||||
let priority_color = cs.get("turns protected by traffic signal right now", Color::GREEN);
|
let priority_color = cs.get_def("turns protected by traffic signal right now", Color::GREEN);
|
||||||
let yield_color = cs.get(
|
let yield_color = cs.get_def(
|
||||||
"turns allowed with yielding by traffic signal right now",
|
"turns allowed with yielding by traffic signal right now",
|
||||||
Color::rgba(255, 105, 180, 0.8),
|
Color::rgba(255, 105, 180, 0.8),
|
||||||
);
|
);
|
||||||
|
|
||||||
for crosswalk in &draw_map.get_i(cycle.parent).crosswalks {
|
for crosswalk in &draw_map.get_i(cycle.parent).crosswalks {
|
||||||
if !hide_crosswalks.contains(&crosswalk.id1) {
|
if !hide_crosswalks.contains(&crosswalk.id1) {
|
||||||
crosswalk.draw(g, cs.get("crosswalk", Color::WHITE));
|
crosswalk.draw(g, cs.get_def("crosswalk", Color::WHITE));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for t in &cycle.priority_turns {
|
for t in &cycle.priority_turns {
|
||||||
@ -199,10 +201,10 @@ pub fn draw_signal_cycle(
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub fn draw_stop_sign(sign: &ControlStopSign, g: &mut GfxCtx, cs: &mut ColorScheme, map: &Map) {
|
pub fn draw_stop_sign(sign: &ControlStopSign, g: &mut GfxCtx, cs: &mut ColorScheme, map: &Map) {
|
||||||
let priority_color = cs.get("stop sign priority turns", Color::GREEN);
|
let priority_color = cs.get_def("stop sign priority turns", Color::GREEN);
|
||||||
// TODO pink yield color from traffic signals is nice, but it's too close to red for stop...
|
// TODO pink yield color from traffic signals is nice, but it's too close to red for stop...
|
||||||
let yield_color = cs.get("stop sign yield turns", Color::YELLOW.alpha(0.8));
|
let yield_color = cs.get_def("stop sign yield turns", Color::YELLOW.alpha(0.8));
|
||||||
let stop_color = cs.get("stop sign stop turns", Color::RED.alpha(0.8));
|
let stop_color = cs.get_def("stop sign stop turns", Color::RED.alpha(0.8));
|
||||||
|
|
||||||
// TODO first crosswalks... actually, give rendering hints to override the color. dont do that
|
// TODO first crosswalks... actually, give rendering hints to override the color. dont do that
|
||||||
// here.
|
// here.
|
||||||
@ -251,12 +253,12 @@ pub fn stop_sign_rendering_hints(
|
|||||||
TurnPriority::Yield => {
|
TurnPriority::Yield => {
|
||||||
hints
|
hints
|
||||||
.color_crosswalks
|
.color_crosswalks
|
||||||
.insert(*t, cs.get("stop sign yield crosswalk", Color::YELLOW));
|
.insert(*t, cs.get_def("stop sign yield crosswalk", Color::YELLOW));
|
||||||
}
|
}
|
||||||
TurnPriority::Stop => {
|
TurnPriority::Stop => {
|
||||||
hints
|
hints
|
||||||
.color_crosswalks
|
.color_crosswalks
|
||||||
.insert(*t, cs.get("stop sign stop crosswalk", Color::RED));
|
.insert(*t, cs.get_def("stop sign stop crosswalk", Color::RED));
|
||||||
}
|
}
|
||||||
TurnPriority::Banned => {
|
TurnPriority::Banned => {
|
||||||
hints.hide_crosswalks.insert(*t);
|
hints.hide_crosswalks.insert(*t);
|
||||||
|
@ -35,7 +35,7 @@ impl DrawLane {
|
|||||||
markings.push(Box::new(move |g, cs| {
|
markings.push(Box::new(move |g, cs| {
|
||||||
for line in &lines {
|
for line in &lines {
|
||||||
g.draw_rounded_line(
|
g.draw_rounded_line(
|
||||||
cs.get("road center line", Color::YELLOW),
|
cs.get_def("road center line", Color::YELLOW),
|
||||||
BIG_ARROW_THICKNESS,
|
BIG_ARROW_THICKNESS,
|
||||||
line,
|
line,
|
||||||
);
|
);
|
||||||
@ -78,11 +78,11 @@ impl DrawLane {
|
|||||||
fn draw_debug(&self, g: &mut GfxCtx, ctx: &mut Ctx) {
|
fn draw_debug(&self, g: &mut GfxCtx, ctx: &mut Ctx) {
|
||||||
let circle_color = ctx
|
let circle_color = ctx
|
||||||
.cs
|
.cs
|
||||||
.get("debug line endpoint", Color::rgb_f(0.8, 0.1, 0.1));
|
.get_def("debug line endpoint", Color::rgb_f(0.8, 0.1, 0.1));
|
||||||
|
|
||||||
for l in ctx.map.get_l(self.id).lane_center_pts.lines() {
|
for l in ctx.map.get_l(self.id).lane_center_pts.lines() {
|
||||||
g.draw_line(
|
g.draw_line(
|
||||||
ctx.cs.get("debug line", Color::RED),
|
ctx.cs.get_def("debug line", Color::RED),
|
||||||
PARCEL_BOUNDARY_THICKNESS / 2.0,
|
PARCEL_BOUNDARY_THICKNESS / 2.0,
|
||||||
&l,
|
&l,
|
||||||
);
|
);
|
||||||
@ -107,12 +107,14 @@ impl Renderable for DrawLane {
|
|||||||
let color = opts.color.unwrap_or_else(|| {
|
let color = opts.color.unwrap_or_else(|| {
|
||||||
let l = ctx.map.get_l(self.id);
|
let l = ctx.map.get_l(self.id);
|
||||||
match l.lane_type {
|
match l.lane_type {
|
||||||
_ if l.probably_broken => ctx.cs.get("broken lane", Color::rgb_f(1.0, 0.0, 0.565)),
|
_ if l.probably_broken => {
|
||||||
LaneType::Driving => ctx.cs.get("driving lane", Color::BLACK),
|
ctx.cs.get_def("broken lane", Color::rgb_f(1.0, 0.0, 0.565))
|
||||||
LaneType::Bus => ctx.cs.get("bus lane", Color::rgb(190, 74, 76)),
|
}
|
||||||
LaneType::Parking => ctx.cs.get("parking lane", Color::grey(0.2)),
|
LaneType::Driving => ctx.cs.get_def("driving lane", Color::BLACK),
|
||||||
LaneType::Sidewalk => ctx.cs.get("sidewalk", Color::grey(0.8)),
|
LaneType::Bus => ctx.cs.get_def("bus lane", Color::rgb(190, 74, 76)),
|
||||||
LaneType::Biking => ctx.cs.get("bike lane", Color::rgb(15, 125, 75)),
|
LaneType::Parking => ctx.cs.get_def("parking lane", Color::grey(0.2)),
|
||||||
|
LaneType::Sidewalk => ctx.cs.get_def("sidewalk", Color::grey(0.8)),
|
||||||
|
LaneType::Biking => ctx.cs.get_def("bike lane", Color::rgb(15, 125, 75)),
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
g.draw_polygon(color, &self.polygon);
|
g.draw_polygon(color, &self.polygon);
|
||||||
@ -162,7 +164,7 @@ fn calculate_sidewalk_lines(lane: &Lane) -> Marking {
|
|||||||
|
|
||||||
Box::new(move |g, cs| {
|
Box::new(move |g, cs| {
|
||||||
for line in &lines {
|
for line in &lines {
|
||||||
g.draw_line(cs.get("sidewalk lines", Color::grey(0.7)), 0.25, line);
|
g.draw_line(cs.get_def("sidewalk lines", Color::grey(0.7)), 0.25, line);
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@ -195,7 +197,7 @@ fn calculate_parking_lines(lane: &Lane) -> Marking {
|
|||||||
|
|
||||||
Box::new(move |g, cs| {
|
Box::new(move |g, cs| {
|
||||||
for line in &lines {
|
for line in &lines {
|
||||||
g.draw_line(cs.get("parking line", Color::WHITE), 0.25, line);
|
g.draw_line(cs.get_def("parking line", Color::WHITE), 0.25, line);
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@ -225,7 +227,7 @@ fn calculate_driving_lines(lane: &Lane, parent: &Road) -> Option<Marking> {
|
|||||||
|
|
||||||
Some(Box::new(move |g, cs| {
|
Some(Box::new(move |g, cs| {
|
||||||
for p in &polygons {
|
for p in &polygons {
|
||||||
g.draw_polygon(cs.get("dashed lane line", Color::WHITE), p);
|
g.draw_polygon(cs.get_def("dashed lane line", Color::WHITE), p);
|
||||||
}
|
}
|
||||||
}))
|
}))
|
||||||
}
|
}
|
||||||
@ -243,7 +245,7 @@ fn calculate_stop_sign_line(lane: &Lane, map: &Map) -> Option<Marking> {
|
|||||||
let line = perp_line(Line::new(pt1, pt2), LANE_THICKNESS);
|
let line = perp_line(Line::new(pt1, pt2), LANE_THICKNESS);
|
||||||
|
|
||||||
Some(Box::new(move |g, cs| {
|
Some(Box::new(move |g, cs| {
|
||||||
g.draw_rounded_line(cs.get("stop line for lane", Color::RED), 0.45, &line);
|
g.draw_rounded_line(cs.get_def("stop line for lane", Color::RED), 0.45, &line);
|
||||||
}))
|
}))
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -296,7 +298,9 @@ fn turn_markings(turn: &Turn, map: &Map) -> Option<Marking> {
|
|||||||
);
|
);
|
||||||
|
|
||||||
Some(Box::new(move |g, cs| {
|
Some(Box::new(move |g, cs| {
|
||||||
let color = cs.get("turn restrictions on lane", Color::WHITE).alpha(0.8);
|
let color = cs
|
||||||
|
.get_def("turn restrictions on lane", Color::WHITE)
|
||||||
|
.alpha(0.8);
|
||||||
g.draw_polygon(color, &base_polygon);
|
g.draw_polygon(color, &base_polygon);
|
||||||
g.draw_rounded_arrow(color, 0.05, 0.5, &turn_line);
|
g.draw_rounded_arrow(color, 0.05, 0.5, &turn_line);
|
||||||
}))
|
}))
|
||||||
|
@ -57,7 +57,7 @@ impl Renderable for DrawParcel {
|
|||||||
g.draw_polygon(color, &self.fill_polygon);
|
g.draw_polygon(color, &self.fill_polygon);
|
||||||
|
|
||||||
g.draw_polygon(
|
g.draw_polygon(
|
||||||
ctx.cs.get("parcel boundary", Color::grey(0.3)),
|
ctx.cs.get_def("parcel boundary", Color::grey(0.3)),
|
||||||
&self.boundary_polygon,
|
&self.boundary_polygon,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -43,11 +43,11 @@ impl Renderable for DrawPedestrian {
|
|||||||
let color = opts.color.unwrap_or_else(|| {
|
let color = opts.color.unwrap_or_else(|| {
|
||||||
if self.preparing_bike {
|
if self.preparing_bike {
|
||||||
ctx.cs
|
ctx.cs
|
||||||
.get("pedestrian preparing bike", Color::rgb(255, 0, 144))
|
.get_def("pedestrian preparing bike", Color::rgb(255, 0, 144))
|
||||||
.shift(self.id.0)
|
.shift(self.id.0)
|
||||||
} else {
|
} else {
|
||||||
ctx.cs
|
ctx.cs
|
||||||
.get("pedestrian", Color::rgb_f(0.2, 0.7, 0.7))
|
.get_def("pedestrian", Color::rgb_f(0.2, 0.7, 0.7))
|
||||||
.shift(self.id.0)
|
.shift(self.id.0)
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -56,7 +56,7 @@ impl Renderable for DrawPedestrian {
|
|||||||
// TODO tune color, sizes
|
// TODO tune color, sizes
|
||||||
if let Some(ref a) = self.turn_arrow {
|
if let Some(ref a) = self.turn_arrow {
|
||||||
g.draw_rounded_arrow(
|
g.draw_rounded_arrow(
|
||||||
ctx.cs.get("pedestrian turn arrow", Color::CYAN),
|
ctx.cs.get_def("pedestrian turn arrow", Color::CYAN),
|
||||||
0.25,
|
0.25,
|
||||||
0.3,
|
0.3,
|
||||||
a,
|
a,
|
||||||
|
@ -96,13 +96,13 @@ impl Renderable for DrawTurn {
|
|||||||
}
|
}
|
||||||
|
|
||||||
g.draw_circle(
|
g.draw_circle(
|
||||||
ctx.cs.get("turn icon circle", Color::grey(0.3)),
|
ctx.cs.get_def("turn icon circle", Color::grey(0.3)),
|
||||||
&self.icon_circle,
|
&self.icon_circle,
|
||||||
);
|
);
|
||||||
|
|
||||||
g.draw_arrow(
|
g.draw_arrow(
|
||||||
opts.color
|
opts.color
|
||||||
.unwrap_or_else(|| ctx.cs.get("inactive turn icon", Color::grey(0.7))),
|
.unwrap_or_else(|| ctx.cs.get_def("inactive turn icon", Color::grey(0.7))),
|
||||||
TURN_ICON_ARROW_THICKNESS,
|
TURN_ICON_ARROW_THICKNESS,
|
||||||
TURN_ICON_ARROW_TIP_LENGTH,
|
TURN_ICON_ARROW_TIP_LENGTH,
|
||||||
&self.icon_arrow,
|
&self.icon_arrow,
|
||||||
|
@ -108,7 +108,7 @@ impl GUI<RenderingHints> for UI {
|
|||||||
g.clear(
|
g.clear(
|
||||||
self.cs
|
self.cs
|
||||||
.borrow_mut()
|
.borrow_mut()
|
||||||
.get("map background", Color::rgb(242, 239, 233)),
|
.get_def("map background", Color::rgb(242, 239, 233)),
|
||||||
);
|
);
|
||||||
|
|
||||||
let mut ctx = Ctx {
|
let mut ctx = Ctx {
|
||||||
@ -294,7 +294,7 @@ impl UI {
|
|||||||
|
|
||||||
fn color_obj(&self, id: ID, ctx: &mut Ctx) -> Option<Color> {
|
fn color_obj(&self, id: ID, ctx: &mut Ctx) -> Option<Color> {
|
||||||
if Some(id) == self.primary.current_selection {
|
if Some(id) == self.primary.current_selection {
|
||||||
return Some(ctx.cs.get("selected", Color::BLUE));
|
return Some(ctx.cs.get_def("selected", Color::BLUE));
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Some(p) = self.get_active_plugin() {
|
if let Some(p) = self.get_active_plugin() {
|
||||||
|
Loading…
Reference in New Issue
Block a user