mirror of
https://github.com/FoggedLens/iD.git
synced 2026-02-16 10:43:18 +00:00
68 lines
1.7 KiB
JavaScript
68 lines
1.7 KiB
JavaScript
iD.Style = {};
|
|
|
|
// all styling that is done outside of CSS in iD.
|
|
//
|
|
// Since SVG does not support z-index, we sort roads manually with d3's `sort`
|
|
// and the `waystack` fn.
|
|
//
|
|
// This also chooses kosher CSS classes for ways, and marker images for POIs
|
|
|
|
iD.Style.highway_stack = {
|
|
motorway: 0,
|
|
motorway_link: 1,
|
|
trunk: 2,
|
|
trunk_link: 3,
|
|
primary: 4,
|
|
primary_link: 5,
|
|
secondary: 6,
|
|
tertiary: 7,
|
|
unclassified: 8,
|
|
residential: 9,
|
|
service: 10,
|
|
footway: 11
|
|
};
|
|
|
|
iD.Style.waystack = function(a, b) {
|
|
if (!a || !b) return 0;
|
|
if (a.tags.layer !== undefined && b.tags.layer !== undefined) {
|
|
return a.tags.layer - b.tags.layer;
|
|
}
|
|
if (a.tags.bridge) return 1;
|
|
if (b.tags.bridge) return -1;
|
|
var as = 0, bs = 0;
|
|
if (a.tags.highway && b.tags.highway) {
|
|
as -= iD.Style.highway_stack[a.tags.highway];
|
|
bs -= iD.Style.highway_stack[b.tags.highway];
|
|
}
|
|
return as - bs;
|
|
};
|
|
|
|
iD.Style.markerimage = function(d) {
|
|
// TODO: optimize
|
|
for (var k in d.tags) {
|
|
var key = k + '=' + d.tags[k];
|
|
if (iD._markertable[key]) {
|
|
return 'icons/' + iD._markertable[key] + '.png';
|
|
}
|
|
}
|
|
return 'icons/unknown.png';
|
|
};
|
|
|
|
iD.Style.TAG_CLASSES = iD.util.trueObj([
|
|
'highway', 'railway', 'motorway', 'amenity', 'natural',
|
|
'landuse', 'building', 'oneway', 'bridge'
|
|
]);
|
|
|
|
iD.Style.styleClasses = function(pre) {
|
|
return function(d) {
|
|
var tags = d.tags;
|
|
var c = [pre];
|
|
for (var k in tags) {
|
|
if (!iD.Style.TAG_CLASSES[k]) continue;
|
|
c.push(k + '-' + tags[k]);
|
|
c.push(k);
|
|
}
|
|
return c.join(' ');
|
|
};
|
|
};
|