我有一个GeoJSON简单数据,我需要使用L.CRS.Simple crs在小叶地图上显示,因为它是反定线数据,有时,坐标可以是450,389
这是非常简单的GeoJSON:
{
"type": "FeatureCollection",
"name": "entities",
"features": [
{
"type": "Feature",
"properties": {
"Layer": "0",
"SubClasses": "AcDbEntity:AcDbPolyline",
"EntityHandle": "1F9",
"style": "PEN(c:#FF0000)"
},
"geometry": {
"type": "LineString",
"coordinates": [
[
0,
0
],
[
0,
150
],
[
150,
150
],
[
150,
0
],
[
0,
0
]
]
}
}
]
}
使用geojson-vt (演示页面),我得到了这个矩形:
我对geojson-vt lib做了一些修改:
投影函数:
function projectX(x, simple, projectionFactor) {
return x / 256 + 1;
}
function projectY(y, simple, projectionFactor) {
return - y / 256 + 0.5;
}
我在GeoJSONVT.prototype.getTile
函数中添加了下面这一行:
y = y + (1 << (z - 1)); // xy map
结果是(标记被放置在0,0,150,0,150,150,0,150):
有什么建议吗?为什么我在这里丢了瓷砖?
发布于 2018-12-26 01:16:29
我建议你阅读这个:https://macwright.org/2016/09/26/the-180th-meridian.html
引用GeoJSON规范推荐的解决方案:
在表示跨越反方向的特征时,通过修改它们的几何形状来提高互操作性。任何穿过反分割线的几何形状都应该通过将其一分为二来表示,使得任何部分的表示都不会与反分割线交叉。-- GeoJSON Spec, 3.1.9
https://stackoverflow.com/questions/53837326
复制相似问题