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.

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