首页 > 解决方案 > 如何从 PostGIS 坐标中居中 openlayers 地图?

问题描述

我正在尝试使用从我的数据库中获得的坐标与 PostGIS 函数居中我的 openlayers 地图:ST_AsGeoJSON(ST_SetSRID(ST_Centroid(geom),3857)). 我的数据库中的几何图形投影在 EPSG:25830 中,我的 openlayers 地图投影在 EPSG:3857 中。

一旦我调用服务器,我在客户端得到的坐标是这样的:

613056.633587271 4738175.03852526

然后我对 openlayers 地图的视图和接收到的坐标执行以下操作:

view.animate({
    center: coordinatefromserver,
    duration: 500
});

我的地图移动到一个完全不同的位置。

我知道工作正常的那种坐标是这个:

-180099.9705826787,5279777.85057039

我错过了什么?PostGIS功能?任何类型转换?预测?对不起,但我在这方面很菜鸟!

谢谢。

标签: postgresqlgisopenlayerspostgis

解决方案


当从 EPSG:25830 转换为 EPSG:3857 时,这些坐标会产生 [-180081.82283603796, 5279725.360517778] 因此服务器返回 EPSG:25830 尽管 SetSRID 为 3857。

您可以在 OpenLayers 中进行转换:

proj4.defs('EPSG:25830', '+proj=utm +zone=30 +ellps=GRS80 +units=m +no_defs ');

if (ol.proj.proj4 && ol.proj.proj4.register) { ol.proj.proj4.register(proj4); }  // only needed for OL5

view.animate({
    center: ol.proj.transform(coordinatefromserver, 'EPSG:25830', view.getProjection())
    duration: 500
});

推荐阅读