mirror of
https://github.com/FoggedLens/iD.git
synced 2026-05-12 20:42:37 +02:00
114 lines
3.3 KiB
JavaScript
114 lines
3.3 KiB
JavaScript
iD.svg.Lines = function(projection) {
|
|
|
|
var 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
|
|
};
|
|
|
|
function waystack(a, b) {
|
|
if (!a || !b || !a.tags || !b.tags) 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;
|
|
if (a.tags.tunnel) return -1;
|
|
if (b.tags.tunnel) return 1;
|
|
var as = 0, bs = 0;
|
|
if (a.tags.highway && b.tags.highway) {
|
|
as -= highway_stack[a.tags.highway];
|
|
bs -= highway_stack[b.tags.highway];
|
|
}
|
|
return as - bs;
|
|
}
|
|
|
|
return function drawLines(surface, graph, entities, filter) {
|
|
function drawPaths(group, lines, filter, klass, lineString) {
|
|
lines = lines.filter(function(line) {
|
|
return lineString(line);
|
|
});
|
|
|
|
var tagClasses = iD.svg.TagClasses();
|
|
|
|
if (klass === 'stroke') {
|
|
tagClasses.tags(iD.svg.MultipolygonMemberTags(graph));
|
|
}
|
|
|
|
var paths = group.selectAll('path.line')
|
|
.filter(filter)
|
|
.data(lines, iD.Entity.key);
|
|
|
|
paths.enter()
|
|
.append('path')
|
|
.attr('class', 'way line ' + klass);
|
|
|
|
paths
|
|
.order()
|
|
.attr('d', lineString)
|
|
.call(tagClasses)
|
|
.call(iD.svg.MemberClasses(graph));
|
|
|
|
paths.exit()
|
|
.remove();
|
|
|
|
return paths;
|
|
}
|
|
|
|
var lines = [];
|
|
|
|
for (var i = 0; i < entities.length; i++) {
|
|
var entity = entities[i],
|
|
outer = iD.geo.simpleMultipolygonOuterMember(entity, graph);
|
|
if (outer) {
|
|
lines.push(entity.mergeTags(outer.tags));
|
|
} else if (entity.geometry(graph) === 'line') {
|
|
lines.push(entity);
|
|
}
|
|
}
|
|
|
|
lines.sort(waystack);
|
|
|
|
var lineString = iD.svg.LineString(projection, graph);
|
|
|
|
var shadow = surface.select('.layer-shadow'),
|
|
casing = surface.select('.layer-casing'),
|
|
stroke = surface.select('.layer-stroke'),
|
|
defs = surface.select('defs'),
|
|
oneway = surface.select('.layer-oneway');
|
|
|
|
drawPaths(shadow, lines, filter, 'shadow', lineString);
|
|
drawPaths(casing, lines, filter, 'casing', lineString);
|
|
drawPaths(stroke, lines, filter, 'stroke', lineString);
|
|
|
|
var segments = _.flatten(lines
|
|
.filter(function(d) { return d.isOneWay(); })
|
|
.map(iD.svg.OneWaySegments(projection, graph, 35)));
|
|
|
|
var oneways = oneway.selectAll('path.oneway')
|
|
.filter(filter)
|
|
.data(segments, function(d) { return [d.id, d.index]; });
|
|
|
|
oneways.enter()
|
|
.append('path')
|
|
.attr('class', 'oneway')
|
|
.attr('marker-mid', 'url(#oneway-marker)');
|
|
|
|
oneways
|
|
.order()
|
|
.attr('d', function(d) { return d.d; });
|
|
|
|
oneways.exit()
|
|
.remove();
|
|
};
|
|
};
|