百度地图开发入门(2):控件与个性化地图

控件

这个控件的概念类似echarts中的组件,例如地图里面控制放大缩小的图表、标尺等等工具。

1. 缩放控件

首先我们添加一个控制zoom的组件:

<body>

    <div id="map"></div>

    <script>

        // 地图对象初始化

        let map = new BMapGL.Map('map', {

            // 传入初始化参数(具体可以官方文档)

            minZoom: 8,

            maxZoom: 12

        });

        // 地图中心坐标 - 后续地图绘制都需要这种坐标

        let point = new BMapGL.Point(116.404, 39.915);

        // 可以展示地图了

        map.centerAndZoom(point, 10);

        // 允许鼠标滚轮滚动放大缩小

        map.enableScrollWheelZoom(true);

        map.setHeading(0);

        map.setTilt(70);

        // 设置缩放范围 - 但是这个API在实际map对象原型上没有,官方文档有,这也是一个坑

        map.setMinZoom(8);

        map.setMaxZoom(12)

        let zoomCtrl = new BMapGL.ZoomControl({

            // 初始位置

            anchor: BMAP_ANCHOR_BOTTOM_LEFT,

            // 进行位移

            offset: new BMapGL.Size(100, 0)

        });

        map.addControl(zoomCtrl);



    </script>

</body>

注意百度文档不一定百分百可信,出现问题还是要打印对象看

2. 标尺控件

这个控件用于描述地图上一段距离代表的实际长度,他会根据你的实际缩放比例调整文案:

 // 添加事件

        map.addEventListener('zoomstart', function(){

            console.log(map.getZoom());

        })



        let scaleCtrl = new BMapGL.ScaleControl({

            anchor: BMAP_ANCHOR_TOP_LEFT

        })

        map.addControl(scaleCtrl)

个性化地图

即可以自定义百度地图的部分样式,例如地图上面区域换一个颜色,路径换一个颜色等等。

这里我们可以前往百度的个性化地图中编辑,通过一些样式模板以及二次操作来生成最后的地图样式:

https://lbsyun.baidu.com/index.php?title=open/custom

最后配置好了之后可以发布样式,同时获取一个样式ID,在我们的代码中新增:

map.setMapStyleV2({

    styleId:'xxxxx'

})

就可以生效新的样式了!

另外也可以获取配置的JSON文件,然后复制到本地:

map.setMapStyleV2({

    styleJson:{...}

})
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值