leaflet实现地图层级能到18以上

leaflet-zoom-to19: leaflet地图放大到18层级以上,并且能切换地图图层皮肤 

script中引用的脚本可自行在cdn中下载或引入在线链接,或者点击上方链接即可下载源码 

<!DOCTYPE html>
<html>

<head>
    <title>leaflet demo</title>
    <meta charset="utf-8">
    <style type="text/css">
        body {
            padding: 0;
            margin: 0;
        }

        html,
        body,
        #map {
            height: 100%;
        }
    </style>
    <link rel="stylesheet" href="./lib/leaflet.css" />
    <link rel="stylesheet" href="./lib/L.Control.Zoominfo.css" />
    <script src="./lib/leaflet.js"></script>
    <script src="./lib/proj4.min.js"></script>
    <script src="./lib/proj4leaflet.min.js"></script>
    <script src="./lib/L.Control.Zoominfo.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 = 19
                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 =
        // 'https://maponline2.bdimg.com/tile/?qt=vtile&x={x}&y={y}&z={z}&styles=pl&scaler=1&customid=midnight&udt=20231230&from=jsapi2_0',
        var normalMapUrl = 'http://api.map.baidu.com/customimage/tile?x={x}&y={y}&z={z}',
        // var normalMapUrl = 'http://api0.map.bdimg.com/customimage/tile?&x={x}&y={y}&z={z}&udt=20231205&scale=1&ak=5ieMMexWmzB9jivTq6oCRX9j',
        // var normalMapUrl = 'http://online{s}.map.bdimg.com/tile/?qt=tile&x={x}&y={y}&z={z}',
        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/tile/?qt=tile&x={x}&y={y}&z={z}&styles=sl'

        var normalMap = L.tileLayer(normalMapUrl, {
            maxZoom: 19,
            minZoom: 3,
            maxNativeZoom: 19,
            tms: true
        });

    normalMapOp = L.tileLayer(normalMapUrl, {
        subdomains: '0123456789',
        maxZoom: 19,
        maxNativeZoom: 19,
        minZoom: 18,
        opacity: 0.5,
        tms: true
    });
    satelliteMap = L.tileLayer(satelliteMapUrl, {
            subdomains: '0123456789',
            maxZoom: 21,
            minZoom: 3,
            tms: true
        }),
        annotionMap = L.tileLayer(annotionMapUrl, {
            subdomains: '0123456789',
            maxZoom: 21,
            minZoom: 3,
            tms: true
        });

    var map = L.map("map", {
        crs: baiduCRS,
        center: [28.47, 119.92],
        zoom: 18,
        maxZoom: 19,
        // layers: [satelliteMap, annotionMap],
        layers: [normalMap],
        zoomControl: true,
        zoominfoControl: true,
    });
</script>

</html>

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值