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.

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