Leaflet加载百度瓦片到WGS84坐标系下

Leaflet加载百度瓦片到WGS84坐标系下

百度技术真的很好,但还是忍不住吐槽,bd09坐标系、bd09mc投影、百度地图瓦片,真是诡异的存在。

下面的代码能实现,将leaflet中加载的百度地图瓦片纠正到WGS84坐标系下。

<!DOCTYPE html>

<html>

<head>

    <title>加载百度地图-WGS84坐标系</title>

    <meta charset="utf-8">

    <style type="text/css">

    body {

        padding: 0;

        margin: 0;

    }

    html,

    body,

    #map {

        height: 100%;

    }

    </style>

    <link rel="stylesheet" href="https://unpkg.com/leaflet@1.6.0/dist/leaflet.css" />

    <script src="https://unpkg.com/leaflet@1.6.0/dist/leaflet.js"></script>

    <script src="https://cdn.bootcss.com/proj4js/2.4.3/proj4.js"></script>

    <script src="https://cdn.bootcss.com/proj4leaflet/1.0.1/proj4leaflet.min.js"></script>

</head>

<body>

    <div id='map'></div>

</body>

<script type="text/javascript">

var baiduCRS = new L.Proj.CRS('EPSG:900913', '+proj=merc +a=6378206 +b=6356584.314245179 +lat_ts=0.0 +lon_0=0.0 +x_0=0 +y_0=0 +k=1.0 +units=m +nadgrids=@null +wktext  +no_defs', {

    resolutions: function () {

        var level = 21

        var res = [];

        res[0] = Math.pow(2, 18);

        for (var i = 1; i < level; i++) {

            res[i] = Math.pow(2, (18 - i))

        }

        return res;

    }(),

    origin: [0, 0],

    bounds: L.bounds([20037508.342789244, 0], [0, 20037508.342789244])

});

var normalMapUrl = 'http://online{s}.map.bdimg.com/onlinelabel/?qt=tile&x={x}&y={y}&z={z}&styles=pl&scaler=1&p=1',

    satelliteMapUrl = 'http://shangetu{s}.map.bdimg.com/it/u=x={x};y={y};z={z};v=009;type=sate&fm=46',

    annotionMapUrl = 'http://online{s}.map.bdimg.com/til
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值