From 6b24a3c693a4553446b378f145781e10e3b70885 Mon Sep 17 00:00:00 2001 From: Pieter Vander Vennet Date: Tue, 27 Sep 2022 19:30:46 +0200 Subject: [PATCH] Add streetwidth theme again --- assets/themes/width/icon.svg | 49 +++++ assets/themes/width/license_info.json | 8 + assets/themes/width/width.json | 271 ++++++++++++++++++++++++++ 3 files changed, 328 insertions(+) create mode 100644 assets/themes/width/icon.svg create mode 100644 assets/themes/width/license_info.json create mode 100644 assets/themes/width/width.json diff --git a/assets/themes/width/icon.svg b/assets/themes/width/icon.svg new file mode 100644 index 000000000..7cf01e27b --- /dev/null +++ b/assets/themes/width/icon.svg @@ -0,0 +1,49 @@ + + + + + + + + diff --git a/assets/themes/width/license_info.json b/assets/themes/width/license_info.json new file mode 100644 index 000000000..20cd90555 --- /dev/null +++ b/assets/themes/width/license_info.json @@ -0,0 +1,8 @@ +[ + { + "path": "icon.svg", + "license": "CC0; trivial", + "authors": [], + "sources": [] + } +] \ No newline at end of file diff --git a/assets/themes/width/width.json b/assets/themes/width/width.json new file mode 100644 index 000000000..38d18a58d --- /dev/null +++ b/assets/themes/width/width.json @@ -0,0 +1,271 @@ +{ + "id": "width", + "description": { + "nl": "

De straat is opgebruikt

Er is steeds meer druk op de openbare ruimte. Voetgangers, fietsers, steps, auto's, bussen, bestelwagens, buggies, cargobikes, ... willen allemaal hun deel van de openbare ruimte en de straat.

In deze studie nemen we Brugge onder de loep en kijken we hoe breed elke straat is én hoe breed elke straat zou moeten zijn voor een veilig én vlot verkeer.

Legende

    Straat te smal voor veilig verkeer
    Straat is breed genoeg veilig verkeer
    Straat zonder voetpad, te smal als ook voetgangers plaats krijgen
    Autoluw, autoloos of enkel plaatselijk verkeer


Een gestippelde lijn is een straat waar ook voor fietsers éénrichtingsverkeer geldt.
Klik op een straat om meer informatie te zien." + }, + "title": { + "nl": "Straatbreedtes" + }, + "mustHaveLanguage": [ + "nl" + ], + "hideFromOverview": true, + "enableUserBadge": false, + "enableShareScreen": false, + "enableLayers": false, + "enableMoreQuests": false, + "enableSearch": false, + "enableBackgroundLayerSelection": false, + "icon": "./assets/themes/width/icon.svg", + "startLat": 51.20875, + "startLon": 3.22435, + "startZoom": 14, + "widenFactor": 0.05, + "clustering": false, + "lockLocation": [ + [ + 3.2006263732910156, + 51.22699040520305 + ], + [ + 3.2529830932617188, + 51.190748429411705 + ] + ], + "defaultBackgroundId": "Stadia.AlidadeSmoothDark", + "layers": [ + { + "id": "street_with_width", + "description": "A layer showing street with corresponding widths + an analysis of what this width is used for", + "name": { + "nl": "Straten met een breedte" + }, + "calculatedTags": [ + "_car_width:=2 /* The width that a single car needs */", + "_cyclistWidth:=1.5 /* The width a single cyclist needs to be safely overtaken */", + "_pedestrianWidth:=0.75 /* The width a pedestrian needs if sidewalks are missing */", + "_has_left_parking=(feat.properties['parking:lane:left'] ?? feat.properties['parking:lane:both']) === 'parallel'", + "_has_right_parking=(feat.properties['parking:lane:right'] ?? feat.properties['parking:lane:both']) === 'parallel'", + "_has_other_parking= ['parking:lane:left','parking:lane:right','parking:lane:both'].some(key => ['perpendicular','diagonal'].indexOf(feat.properties[key]) >= 0)", + "_parallel_parking_count=feat.get('_has_right_parking') + feat.get('_has_left_parking') /* in javascript logic: true + true == 2*/", + "_width:needed:parking=feat.get('_parallel_parking_count') * feat.get('_car_width')", + "_has_sidewalk_left=['left','both'].indexOf(feat.properties['sidewalk']) >= 0", + "_has_sidewalk_right=['right','both'].indexOf(feat.properties['sidewalk']) >= 0", + "_pedestrian_flows_in_carriageway= 2 - feat.get('_has_sidewalk_left') - feat.get('_has_sidewalk_right')", + "_width:needed:pedestrians=feat.get('_pedestrianWidth') * feat.get('_pedestrian_flows_in_carriageway')", + "_oneway_car=(feat.properties['oneway:motor_vehicle'] ?? feat.properties['oneway']) == 'yes'", + "_width:needed:cars=feat.get('_car_width') * (2 - feat.get('_oneway_car'))", + "_cycling_allowed=feat.properties.bicycle != 'use_sidepath' && feat.properties.bicycle!='no'", + "_oneway_bicycle=((feat.properties['oneway:bicycle'] ?? feat.properties['oneway']) == 'yes') && feat.properties['cycleway'] != 'opposite'", + "_width:needed:cyclists=feat.get('_cycling_allowed') ? (feat.get('_cyclistWidth') * (2 - feat.get('_oneway_bicycle'))) : 0", + "_width:needed:total:=feat.get('_width:needed:cars') + feat.get('_width:needed:parking') + feat.get('_width:needed:cyclists') + feat.get('_width:needed:pedestrians')", + "_width:difference:=feat.get('_width:needed:total') - feat.get('width:carriageway')", + "_width:difference:no_pedestrians:=feat.get('_width:difference') - feat.get('_width:needed:pedestrians')" + ], + "minzoom": 12, + "source": { + "osmTags": "width:carriageway~*" + }, + "title": { + "render": { + "nl": "{name}" + }, + "mappings": [ + { + "if": "name=", + "then": { + "nl": "Naamloos segment" + } + } + ] + }, + "tagRenderings": [ + { + "id": "carriageway_width", + "render": "Deze straat is {width:carriageway}m breed", + "question": "Hoe breed is deze straat?", + "freeform": { + "key": "width:carriageway", + "type": "distance", + "helperArgs": [ + 21, + "map" + ] + } + }, + { + "id": "too_little_width", + "render": "Deze straat heeft {_width:difference}m te weinig. De ruimte die nodig zou zijn is:", + "mappings": [ + { + "if": { + "or": [ + "_width:difference~-.*", + "_width:difference=0" + ] + }, + "then": "Deze straat is breed genoeg:" + } + ] + }, + { + "id": "needed_for_cars", + "render": "{_width:needed:cars}m voor het autoverkeer", + "mappings": [ + { + "if": "oneway=yes", + "then": "{_width:needed:cars}m voor het éénrichtings-autoverkeer" + }, + { + "if": "oneway=no", + "then": "{_width:needed:cars}m voor het tweerichtings-autoverkeer" + } + ] + }, + { + "id": "needed_for_parking", + "render": "{_width:needed:parking}m voor het geparkeerde wagens", + "condition": "_width:needed:parking!=0" + }, + { + "id": "needed_for_cyclists", + "render": "{_width:needed:cyclists}m voor fietsers", + "mappings": [ + { + "if": "bicycle=use_sidepath", + "then": "Fietsers hebben hier een vrijliggend fietspad en worden dus niet meegerekend" + }, + { + "if": "oneway:bicycle=yes", + "then": "{_width:needed:cyclists}m voor fietsers die met de rijrichting mee moeten" + } + ] + }, + { + "id": "needed_for_pedestrians", + "render": "{_width:needed:pedestrians}m voor voetgangers", + "condition": "_width:needed:pedestrians!=0", + "mappings": [ + { + "if": { + "or": [ + "sidewalk=none", + "sidewalk=no" + ] + }, + "then": "{_width:needed:pedestrians}m voor voetgangers: er zijn hier geen voetpaden" + }, + { + "if": { + "or": [ + "sidewalk=left", + "sidewalk=right" + ] + }, + "then": "{_width:needed:pedestrians}m voor voetgangers: er is slechts aan één kant een voetpad" + } + ] + }, + { + "id": "total_width_needed", + "render": "{_width:needed:total}m nodig in het totaal" + }, + { + "id": "has_sidewalks", + "condition": "id=disabled", + "question": { + "nl": "Heeft deze straat voetpaden?" + }, + "mappings": [ + { + "if": "sidewalk=both", + "then": { + "nl": "Voetpad aan beide zijden" + } + },{ + "if": "sidewalk=none", + "then": { + "nl": "Heeft géén voetpaden" + } + },{ + "if": "sidewalk=left", + "then": { + "nl": "Voetpad aan de linkerkant" + } + }, + { + "if": "sidewalk=right", + "then": { + "nl": "Voetpad aan de rechterzijde" + } + } + ] + } + ], + "mapRendering": [ + { + "location": [ + "point" + ], + "icon": "./assets/themes/width/icon.svg", + "iconSize": "40,40,center" + }, + { + "width": "4", + "color": { + "render": "#00f", + "mappings": [ + { + "if": { + "or": [ + "access=destination", + "highway=pedestrian", + "motor_vehicle=no", + "motor_vehicle=destination" + ] + }, + "then": "lightgrey" + }, + { + "if": { + "and": [ + "_width:difference!~-.*", + "_width:difference:no_pedestrians~-.*" + ] + }, + "then": "orange" + }, + { + "if": "_width:difference~-.*", + "then": "#0f0" + }, + { + "if": "_width:difference!~-.*", + "then": "#f00" + } + ] + }, + "dashArray": { + "render": "", + "mappings": [ + { + "if": { + "and": [ + "oneway=yes", + { + "or": [ + "oneway:bicycle=yes", + "oneway:bicycle=" + ] + } + ] + }, + "then": "5 6" + } + ] + } + } + ] + } + ] +}