超图坐标系转换为高德坐标系

超图坐标和高德坐标都是采用的火星坐标系(GCJ-02),但是由于火星坐标系是一套自定义的坐标系,不同系统和平台对火星坐标系的实现可能会有所不同,因此在转换时需要注意。

以下是一个将超图坐标转换为高德坐标的示例代码:

function convertToGCJ02(lng, lat) {
 var a = 6378245.0;
 var ee = 0.00669342162296594323;
 var pi = Math.PI;
 var x = lng - 105.0;
 var y = lat - 35.0;
 var dLng = (-100.0 + 2.0 * x + 3.0 * y + 0.2 * y * y + 0.1 * x * y + 0.2 * Math.sqrt(Math.abs(x))) / 180.0 * pi;
 var dLat = (-100.0 + 2.0 * x + 3.0 * y + 0.2 * y * y + 0.1 * x * y + 0.2 * Math.sqrt(Math.abs(x))) / 180.0 * pi;
 var radLat = lat / 180.0 * pi;
 var magic = Math.sin(radLat);
 magic = 1 - ee * magic * magic;
 var sqrtMagic = Math.sqrt(magic);
 dLng = (dLng * 180.0) / (a / sqrtMagic * Math.cos(radLat) * pi);
 dLat = (dLat * 180.0) / ((a * (1 - ee)) / (magic * sqrtMagic) * pi);
 var ggLng = lng + dLng;
 var ggLat = lat + dLat;
 return [ggLng, ggLat];
}

var superMapLngLat = [116.407526, 39.90403]; // 超图坐标
var gaodeLngLat = convertToGCJ02(superMapLngLat[0], superMapLngLat[1]); // 超图坐标转高德坐标

请注意,这个示例代码仅适用于超图坐标系的火星坐标系(GCJ-02),对于其他坐标系可能需要进行相应的调整。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在前端代码中实现将高德地图替换为超图地图,您需要先了解使用的前端技术栈和地图API的使用方法。以下是一个使用JavaScript超图API实现地图切换的示例代码: ```javascript // 初始化超图地图 var map = new SuperMap.Map("map", { controls: [ new SuperMap.Control.ScaleLine(), new SuperMap.Control.Zoom(), new SuperMap.Control.LayerSwitcher(), new SuperMap.Control.MousePosition() ] }); var layer = new SuperMap.Layer.TiledDynamicRESTLayer("World", "http://localhost:8090/iserver/services/map-world/rest/maps/World"); layer.events.on({"layerInitialized":addLayer}); function addLayer() { map.addLayer(layer); map.setCenter(new SuperMap.LonLat(0, 0), 0); } // 使用高德地图的代码 // var map = new AMap.Map('map', { // zoom: 10, // center: [116.39, 39.9] // }); ``` 在上面的代码中,我们通过调用超图API的`SuperMap.Map`类和`SuperMap.Layer.TiledDynamicRESTLayer`类,来初始化一个超图地图,并设置地图的一些基本属性。同时,我们注释掉了原本调用高德地图的代码,以防止两个地图同时显示。 需要注意的是,在实际使用中,您需要根据您的具体情况,调整地图的服务地址、地图的中心点和缩放级别等属性。同时,您也需要在HTML中添加一个地图容器元素,例如: ```html <div id="map" style="height: 600px;"></div> ``` 这样,当您运行上述代码时,就可以在页面上看到一个使用超图地图的地图实例了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值