A repository for testing purposes.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

351 lines
17 KiB

4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
  1. {
  2. "type": "overpass",
  3. "name": {
  4. "en": "Lanes"
  5. },
  6. "query": {
  7. "17": [
  8. "(",
  9. "way[lanes];",
  10. "way['parking:lane:left'];",
  11. "way['parking:lane:right'];",
  12. "way['parking:lane:both'];",
  13. ")"
  14. ]
  15. },
  16. "feature": {
  17. "pre": [
  18. "{% set oneway = tags.oneway in ['yes','1'] %}",
  19. "{% set parking_left_type = attribute(tags, 'parking:lane:left')|default(attribute(tags, 'parking:lane:both')) %}",
  20. "{% set parking_left = parking_left_type ? const.parking[parking_left_type]|default(const.parking.other) : const.parking.no %}",
  21. "{% set parking_right_type = attribute(tags, 'parking:lane:right')|default(attribute(tags, 'parking:lane:both')) %}",
  22. "{% set parking_right = parking_right_type ? const.parking[parking_right_type]|default(const.parking.other) : const.parking.no %}",
  23. "{% set cyclelane_left = attribute(tags, 'cycleway:left') == 'lane' ? 2 : ('opposite_lane' in tags.cycleway|split(';') ? 2 : (('lane' in tags.cycleway|split(';')) and not oneway ? 2 : 0)) %}",
  24. "{% set cyclelane_right = attribute(tags, 'cycleway:right') == 'lane' ? 2 : ('lane' in tags.cycleway|split(';') ? 2 : 0) %}",
  25. "{% set cycletrack_left = attribute(tags, 'cycleway:left') == 'track' ? 2 : ('opposite_track' in tags.cycleway|split(';') ? 2 : (('track' in tags.cycleway|split(';')) and not oneway ? 2 : 0)) %}",
  26. "{% set cycletrack_right = attribute(tags, 'cycleway:right') == 'track' ? 2 : ('track' in tags.cycleway|split(';') ? 2 : 0) %}",
  27. "{% set sidewalk_left = tags.sidewalk in ['both', 'left'] ? 2 : 0 %}",
  28. "{% set sidewalk_right = tags.sidewalk in ['both', 'right'] ? 2 : 0 %}",
  29. "{% set lanes = tags.lanes|default(oneway ? 1 : 2) %}",
  30. "{% set lanes_width = lanes * 3 %}",
  31. "{% set forward_lanes = attribute(tags, 'lanes:forward')|default(oneway ? lanes : lanes // 2) %}",
  32. "{% set backward_lanes = attribute(tags, 'lanes:backward')|default(oneway ? 0 : lanes // 2) %}"
  33. ],
  34. "description": "{{ keyTrans('lanes') }}: {% if tags.lanes %}{{ tags.lanes }}{% else %}{{ lanes }}?{% endif %} {% if attribute(tags, 'lanes:forward') or attribute(tags, 'lanes:backward') %}(↑{{ forward_lanes }} ↓{{ backward_lanes }}){% endif %}",
  35. "body": [
  36. "{{ tagTrans('railway', tags.railway) }}<br/>",
  37. "{% if tags.operator %}{{ keyTrans('operator') }}: {{ localizedTag(tags, 'operator') }}<br>{% endif %}",
  38. "{% if tags.usage %}{{ keyTrans('usage') }}: {{ tagTrans('usage', tags.usage)|default(trans('unknown')) }}<br/>{% endif %}",
  39. "{% if tags.service %}{{ keyTrans('service') }}: {{ tagTrans('service', tags.service ) }}<br/>{% endif %}",
  40. "{{ keyTrans('gauge') }}: {{ tags.gauge|default(trans('unknown'))|enumerate }}<br/>",
  41. "{% if tags.electrified == 'no' %}{{ keyTrans('electrified') }}: {{ tagTrans('electrified', 'no') }}{% elseif tags.electrified %}{{ keyTrans('electrified') }}: {{ tagTrans('electrified', tags.electrified) }}, {{ keyTrans('voltage') }}: {{ tags.voltage|default(trans('unknown')) }}, {{ keyTrans('frequency') }}: {{ tags.frequency|default(trans('unknown')) }}<br/>{% endif %}"
  42. ],
  43. "markerSymbol": null,
  44. "listMarkerSymbol": "line",
  45. "styles": "{% if sidewalk_left %}sidewalk_left,{% endif %}{% if cycletrack_left %}cycletrack_left,{% endif %}{% if parking_left.width %}parking_left,{% if parking_left.dashDistance %}parking_left_dash,{% if parking_left_type == 'diagonal' %}parking_left_dash_diag,{% endif %}{% endif %}{% endif %}{% if cyclelane_left %}cyclelane_left,{% endif %}{% if lanes == 1 %}lane1{% else %}{% for i in 1..lanes - 1 %}lane{{ i }},mark{{ i }},{% endfor %}lane{{ lanes }}{% endif %}{% if cyclelane_right %},cyclelane_right{% endif %}{% if parking_right.width %},parking_right{% if parking_right.dashDistance %},parking_right_dash{% if parking_right_type == 'diagonal' %},parking_right_dash_diag{% endif %}{% endif %}{% endif %}{% if cycletrack_right %},cycletrack_right{% endif %}{% if sidewalk_right %},sidewalk_right{% endif %}",
  46. "style": {
  47. "width": "{{ width }}",
  48. "pane": "casing",
  49. "color": "{% if tags.gauge %}{% if not tags.gauge|matches('^\\d+$') %}#ff0000{% else %}{{ colorInterpolate([ '#00ff00', '#0000ff' ], tags.gauge / 2000) }}{% endif %}{% else %}#404040{% endif %}"
  50. },
  51. "style:sidewalk_left": {
  52. "width": "2m",
  53. "color": "#4f4fbf",
  54. "offset": "{{ lanes_width / -2 - cyclelane_left - parking_left.width - cycletrack_left - 1 }}m",
  55. "pane": "casing"
  56. },
  57. "style:parking_left": {
  58. "width": "{{ parking_left.width }}m",
  59. "color": "{{ parking_left.color }}",
  60. "offset": "{{ lanes_width / -2 - cyclelane_left - parking_left.width / 2 }}m",
  61. "pane": "casing"
  62. },
  63. "style:parking_left_dash": {
  64. "width": "{{ parking_left.width / (parking_left_type == 'diagonal' ? 2 : 1) }}m",
  65. "color": "{{ parking_left.dashColor }}",
  66. "offset": "{{ lanes_width / -2 - cyclelane_left - parking_left.width / 2 - (parking_left_type == 'diagonal' ? parking_left.width / 4 : 0) }}m",
  67. "lineCap": "butt",
  68. "dashArray": "1,{{ parking_left.dashDistance / map.metersPerPixel }}"
  69. },
  70. "style:parking_left_dash_diag": {
  71. "width": "{{ parking_left.width / 2 }}m",
  72. "color": "{{ parking_left.dashColor }}",
  73. "offset": "{{ lanes_width / -2 - cyclelane_left - parking_left.width / 4 }}m",
  74. "lineCap": "butt",
  75. "dashArray": "1,{{ parking_left.dashDistance / map.metersPerPixel }}",
  76. "dashOffset": "{{ 0.5 / map.metersPerPixel }}"
  77. },
  78. "style:cyclelane_left": {
  79. "width": "2m",
  80. "color": "#af3f3f",
  81. "offset": "{{ lanes_width / -2 - 1 }}m",
  82. "pane": "casing"
  83. },
  84. "style:cyclelane_right": {
  85. "width": "2m",
  86. "color": "#af3f3f",
  87. "offset": "{{ lanes_width / 2 + 1 }}m",
  88. "pane": "casing"
  89. },
  90. "style:cycletrack_left": {
  91. "width": "2m",
  92. "color": "#bf5f3f",
  93. "offset": "{{ lanes_width / -2 - cyclelane_left - parking_left.width - 1 }}m",
  94. "pane": "casing"
  95. },
  96. "style:cycletrack_right": {
  97. "width": "2m",
  98. "color": "#bf5f3f",
  99. "offset": "{{ lanes_width / 2 + cyclelane_right + parking_right.width + 1 }}m",
  100. "pane": "casing"
  101. },
  102. "style:parking_right": {
  103. "width": "{{ parking_left.width }}m",
  104. "color": "{{ parking_left.color }}",
  105. "offset": "{{ lanes_width / 2 + cyclelane_right + parking_right.width / 2 }}m",
  106. "pane": "casing"
  107. },
  108. "style:parking_right_dash": {
  109. "width": "{{ parking_right.width / (parking_right_type == 'diagonal' ? 2 : 1) }}m",
  110. "color": "{{ parking_right.dashColor }}",
  111. "offset": "{{ lanes_width / 2 + cyclelane_right + parking_right.width / 2 + (parking_right_type == 'diagonal' ? parking_right.width / 4 : 0) }}m",
  112. "lineCap": "butt",
  113. "dashArray": "1,{{ parking_right.dashDistance / map.metersPerPixel }}"
  114. },
  115. "style:parking_right_dash_diag": {
  116. "width": "{{ parking_right.width / 2 }}m",
  117. "color": "{{ parking_right.dashColor }}",
  118. "offset": "{{ lanes_width / 2 + cyclelane_right + parking_right.width / 4 }}m",
  119. "lineCap": "butt",
  120. "dashArray": "1,{{ parking_right.dashDistance / map.metersPerPixel }}",
  121. "dashOffset": "{{ 0.5 / map.metersPerPixel }}"
  122. },
  123. "style:sidewalk_right": {
  124. "width": "2m",
  125. "color": "#4f4fbf",
  126. "offset": "{{ lanes_width / 2 + cyclelane_right + parking_right.width + cycletrack_right + 1 }}m",
  127. "pane": "casing"
  128. },
  129. "style:lane1": {
  130. "width": "3.1m",
  131. "offset": "{{ lanes_width / -2 + 1.5 }}m",
  132. "color": "grey",
  133. "pane": "casing"
  134. },
  135. "style:lane2": {
  136. "width": "3.1m",
  137. "offset": "{{ lanes_width / -2 + 4.5 }}m",
  138. "color": "grey",
  139. "pane": "casing"
  140. },
  141. "style:lane3": {
  142. "width": "3.1m",
  143. "offset": "{{ lanes_width / -2 + 7.5 }}m",
  144. "color": "grey",
  145. "pane": "casing"
  146. },
  147. "style:lane4": {
  148. "width": "3.1m",
  149. "offset": "{{ lanes_width / -2 + 10.5 }}m",
  150. "color": "grey",
  151. "pane": "casing"
  152. },
  153. "style:lane5": {
  154. "width": "3.1m",
  155. "offset": "{{ lanes_width / -2 + 13.5 }}m",
  156. "color": "grey",
  157. "pane": "casing"
  158. },
  159. "style:lane6": {
  160. "width": "3.1m",
  161. "offset": "{{ lanes_width / -2 + 16.5 }}m",
  162. "color": "grey",
  163. "pane": "casing"
  164. },
  165. "style:lane7": {
  166. "width": "3.1m",
  167. "offset": "{{ lanes_width / -2 + 19.5 }}m",
  168. "color": "grey",
  169. "pane": "casing"
  170. },
  171. "style:lane8": {
  172. "width": "3.1m",
  173. "offset": "{{ lanes_width / -2 + 22.5 }}m",
  174. "color": "grey",
  175. "pane": "casing"
  176. },
  177. "style:lane9": {
  178. "width": "3.1m",
  179. "offset": "{{ lanes_width / -2 + 25.5 }}m",
  180. "color": "grey",
  181. "pane": "casing"
  182. },
  183. "style:lane10": {
  184. "width": "3.1m",
  185. "offset": "{{ lanes_width / -2 + 28.5 }}m",
  186. "color": "grey",
  187. "pane": "casing"
  188. },
  189. "style:lane11": {
  190. "width": "3.1m",
  191. "offset": "{{ lanes_width / -2 + 31.5 }}m",
  192. "color": "grey",
  193. "pane": "casing"
  194. },
  195. "style:lane12": {
  196. "width": "3.1m",
  197. "offset": "{{ lanes_width / -2 + 34.5 }}m",
  198. "color": "grey",
  199. "pane": "casing"
  200. },
  201. "style:mark1": {
  202. "width": "1",
  203. "offset": "{{ lanes_width / -2 + 3 }}m",
  204. "dashArray": "{% if lanes - forward_lanes != 1 and backward_lanes != 1 %}2,8{% else %}5,5{% endif %}",
  205. "color": "white"
  206. },
  207. "style:mark2": {
  208. "width": "1",
  209. "offset": "{{ lanes_width / -2 + 6 }}m",
  210. "dashArray": "{% if lanes - forward_lanes != 2 and backward_lanes != 2 %}2,8{% else %}5,5{% endif %}",
  211. "color": "white"
  212. },
  213. "style:mark3": {
  214. "width": "1",
  215. "offset": "{{ lanes_width / -2 + 9 }}m",
  216. "dashArray": "{% if lanes - forward_lanes != 3 and backward_lanes != 3 %}2,8{% else %}5,5{% endif %}",
  217. "color": "white"
  218. },
  219. "style:mark4": {
  220. "width": "1",
  221. "offset": "{{ lanes_width / -2 + 12 }}m",
  222. "dashArray": "{% if lanes - forward_lanes != 4 and backward_lanes != 4 %}2,8{% else %}5,5{% endif %}",
  223. "color": "white"
  224. },
  225. "style:mark5": {
  226. "width": "1",
  227. "offset": "{{ lanes_width / -2 + 15 }}m",
  228. "dashArray": "{% if lanes - forward_lanes != 5 and backward_lanes != 5 %}2,8{% else %}5,5{% endif %}",
  229. "color": "white"
  230. },
  231. "style:mark6": {
  232. "width": "1",
  233. "offset": "{{ lanes_width / -2 + 18 }}m",
  234. "dashArray": "{% if lanes - forward_lanes != 6 and backward_lanes != 6 %}2,8{% else %}5,5{% endif %}",
  235. "color": "white"
  236. },
  237. "style:mark7": {
  238. "width": "1",
  239. "offset": "{{ lanes_width / -2 + 18 }}m",
  240. "dashArray": "{% if lanes - forward_lanes != 7 and backward_lanes != 7 %}2,8{% else %}5,5{% endif %}",
  241. "color": "white"
  242. },
  243. "style:mark8": {
  244. "width": "1",
  245. "offset": "{{ lanes_width / -2 + 18 }}m",
  246. "dashArray": "{% if lanes - forward_lanes != 8 and backward_lanes != 8 %}2,8{% else %}5,5{% endif %}",
  247. "color": "white"
  248. },
  249. "style:mark9": {
  250. "width": "1",
  251. "offset": "{{ lanes_width / -2 + 18 }}m",
  252. "dashArray": "{% if lanes - forward_lanes != 9 and backward_lanes != 9 %}2,8{% else %}5,5{% endif %}",
  253. "color": "white"
  254. },
  255. "style:mark10": {
  256. "width": "1",
  257. "offset": "{{ lanes_width / -2 + 18 }}m",
  258. "dashArray": "{% if lanes - forward_lanes != 10 and backward_lanes != 10 %}2,8{% else %}5,5{% endif %}",
  259. "color": "white"
  260. },
  261. "style:mark11": {
  262. "width": "1",
  263. "offset": "{{ lanes_width / -2 + 18 }}m",
  264. "dashArray": "{% if lanes - forward_lanes != 11 and backward_lanes != 11 %}2,8{% else %}5,5{% endif %}",
  265. "color": "white"
  266. }
  267. },
  268. "info": [
  269. "<table>",
  270. " <tr>",
  271. " <td>{{ markerLine({'styles':'left,right,mark', 'style:left': { 'width': 3, 'color': 'grey', 'offset': -1.5 },'style:right': { 'width': 3, 'color': 'grey', 'offset': 1.5 },'style:mark': { 'width': 1, 'color': 'white'} })|raw }}</td>",
  272. " <td>{{ keyTrans('lanes') }}</td>",
  273. " </tr>",
  274. " <tr>",
  275. " <td>{{ markerLine({'styles':'left,right,mark', 'style:left': { 'width': 3, 'color': 'grey', 'offset': -1.5 },'style:right': { 'width': 3, 'color': 'grey', 'offset': 1.5 },'style:mark': { 'width': 1, 'color': 'white', 'dashArray': '5,5'} })|raw }}</td>",
  276. " <td>{{ keyTrans('lanes') }}</td>",
  277. " </tr>",
  278. " <tr>",
  279. " <td>{{ markerLine({ 'width': 5, 'color': 'orange' })|raw }}</td>",
  280. " <td>{{ keyTrans('parking:lane') }}</td>",
  281. " </tr>",
  282. " <tr>",
  283. " <td>{{ markerLine({ 'styles':'lane,mark', 'style:lane': { 'width': 5, 'color': 'orange' }, 'style:mark': { 'width': 5, 'color': const.parking.parallel.dashColor, 'dashArray': '1,10' } })|raw }}</td>",
  284. " <td>{{ keyTrans('parking:lane') }}: {{ tagTrans('parking:lane', 'parallel') }}</td>",
  285. " </tr>",
  286. " <tr>",
  287. " <td>{{ markerLine({ 'styles':'lane,mark1,mark2', 'style:lane': { 'width': 5, 'color': 'orange' }, 'style:mark1': { 'width': 2.5, 'color': const.parking.diagonal.dashColor, 'dashArray': '1,7', 'offset': 1.25 }, 'style:mark2': { 'width': 2.5, 'color': const.parking.diagonal.dashColor, 'dashArray': '1,7', 'dashOffset': '2', 'offset': -1.25 } })|raw }}</td>",
  288. " <td>{{ keyTrans('parking:lane') }}: {{ tagTrans('parking:lane', 'diagonal') }}</td>",
  289. " </tr>",
  290. " <tr>",
  291. " <td>{{ markerLine({ 'styles':'lane,mark', 'style:lane': { 'width': 5, 'color': 'orange' }, 'style:mark': { 'width': 5, 'color': const.parking.perpendicular.dashColor, 'dashArray': '1,6' } })|raw }}</td>",
  292. " <td>{{ keyTrans('parking:lane') }}: {{ tagTrans('parking:lane', 'perpendicular') }}</td>",
  293. " </tr>",
  294. " <tr>",
  295. " <td>{{ markerLine({ 'width': 5, 'color': '#af3f3f' })|raw }}</td>",
  296. " <td>{{ tagTrans('cycleway', 'lane') }}</td>",
  297. " </tr>",
  298. " <tr>",
  299. " <td>{{ markerLine({ 'width': 5, 'color': '#bf5f3f' })|raw }}</td>",
  300. " <td>{{ tagTrans('cycleway', 'track') }}</td>",
  301. " </tr>",
  302. " <tr>",
  303. " <td>{{ markerLine({ 'width': 5, 'color': '#4f4fbf' })|raw }}</td>",
  304. " <td>{{ keyTrans('sidewalk') }}</td>",
  305. " </tr>",
  306. "</table>"
  307. ],
  308. "const": {
  309. "parking": {
  310. "parallel": {
  311. "width": "2",
  312. "color": "orange",
  313. "dashColor": "blue",
  314. "dashDistance": "4"
  315. },
  316. "diagonal": {
  317. "width": "2.5",
  318. "color": "orange",
  319. "dashColor": "magenta",
  320. "dashDistance": "3",
  321. "dashType": "diagonal"
  322. },
  323. "perpendicular": {
  324. "width": "3",
  325. "color": "orange",
  326. "dashColor": "red",
  327. "dashDistance": "2.5"
  328. },
  329. "no_parking": {
  330. "width": "0.5",
  331. "color": "#7f0000"
  332. },
  333. "no_stopping": {
  334. "width": "0.5",
  335. "color": "#7f0000"
  336. },
  337. "fire_lane": {
  338. "width": "2",
  339. "color": "#ff0000"
  340. },
  341. "other": {
  342. "width": "2",
  343. "color": "#ff0000"
  344. },
  345. "no": {
  346. "width": "0",
  347. "color": "#000000"
  348. }
  349. }
  350. }
  351. }