我有一系列的大纲和要点。对于大纲,调用 outline.geometry.coordinates
会生成一个多维坐标数组:
[[[-72.68639118392117,41.66733032827929],[-72.68630366033922,41.667449647115724], ...]]
对于一个点,调用 point.geometry.coordinates
会生成坐标的一维数组:
[-72.78630766033722,41.767349642115724]
点和轮廓都保存在一个数组中。 我想最终得到一个包含所有坐标对的数组,例如:
[[[-72.68639118392117,41.66733032827929],[-72.68630366033922,41.667449647115724],[-72.78630766033722,41.767349642115724], ...]]
我尝试过什么
首先,我尝试获取所有坐标,其中geometries
是我的轮廓和点数组:
var coordinates = geometries.map(function(outline) {return outline.geometry.coordinates});
毫不奇怪,这将创建以下数组:
[[[[-72.68639118392117,41.66733032827929],[-72.68630366033922,41.667449647115724], ...]], [-72.78630766033722,41.767349642115724]]
扁平化此数组会导致配对的坐标对丢失,因此我不完全确定如何做到这一点。 有什么想法吗?
这个怎么样?
var geometries = [
// point
{
geometry: {
coordinates: [1, 2],
},
},
// outline
{
geometry: {
coordinates: [
[
[3, 4],
[5, 6],
],
],
},
},
];
var coordinates = geometries.map(function(outline) {
var coords = outline.geometry.coordinates;
if (typeof coords[0] === 'number') {
return [coords];
} else {
return coords[0];
}
}).reduce(function (prev, next) {
return prev.concat(next);
}, []);
console.log(coordinates);
// Output:
// [ [ 1, 2 ], [ 3, 4 ], [ 5, 6 ] ]
一种方法是标准化坐标输出。 如果 outline
s 给你一个配对坐标数组,你可以让 point
s通过将其包装为单个元素数组来做同样的事情。
大纲
[[a, b], [c, d], [e, f], ...]
点
[[a, b]]
这样,当您将它们组合在一起时,它们都具有相同的形状/维度。 此时,您可以使用@dandavis'技术展平一次。
如果您能够使用instanceof
来确定对象是轮廓还是点,则可以使用以下方法。
var coordinates = geometries.map(function(outline_or_point) {
return outline_or_point instanceof outline ? outline.geometry.coordinates : [point.geometry.coordinates];
});
如果无法instanceof
,您可以进行一些鸭子键入,例如,通过检查outline_or_point
是数组还是数字。
var coordinates = geometries.map(function(outline_or_point) {
return typeof outline_or_point[0] == 'number' ? [point.geometry.coordinates] : outline.geometry.coordinates;
});