快速上手

注意:本篇文章代码是基于 百度地图 JavaScript API v3.0 的条件下编写,GL版本可能稍有变化。

地图嘛,很重要的一部分就是坐标经纬度了:

经度: 英文 longitude 缩写 lng;纬度:英文 latitude 缩写 lat

基本使用

在使用百度地图的API之前,首先要有一个先密钥(ak)才能开始使用。没有的话可以免费申请

1.引入js(该ak是mapv中示例的ak,需要测试的朋友可以使用)

<script src="//api.map.baidu.com/api?v=3.0&ak=1XjLLEhZhQNUzd93EjU5nOGQ"></script>

或者使用npm

$ npm install vue-baidu-map

import BaiduMap from 'vue-baidu-map'
Vue.use(BaiduMap, {
ak: '你申请的key'
})

2.初始化地图

<template>
<div class="map-box" style="height:100%">
<!-- 准备容器 -->
<div class="baidu-map" id="baiduMap"></div>
</div>
</template> <script>
export default {
data() {
return {
// base64自定义坐标图形
bluePoint:
""
}
},
methods: {
init() {
const map = new BMap.Map('baiduMap', {
// 地图是否可点击
enableMapClick: false,
// 坐标类型 3为gcj02坐标,5为bd0ll坐标,默认为5
// 如确认坐标正确,但是点出不来,或者位置错误。则确认下类型
coordsType: 5
})
// 一个点对象,包含坐标及名称
const center = {
name: '温州市人民政府',
lng: '120.705832',
lat: '28.00032'
}
// 初始化地理坐标 存放地理坐标的对象
const point = new BMap.Point(center.lng, center.lat)
// 初始化地图 将点设置为地图的中心点 设置初始缩放等级
map.centerAndZoom(point, 12) // 其它地图配置
map.enableScrollWheelZoom(true) // 开启鼠标滚轮缩放
map.enableDragging() // 拖拽
}
},
mounted() {
this.init()
}
}
</script>

如此就能看到一个百度地图了,但是除了地图啥都没有。

添加点(标记)

在百度地图中添加的点又叫覆盖物,它可以添加很多的覆盖物:



添加覆盖物使用addOverlay()方法,下面写一个添加单个点的方法:

makePoint(map, data) {
// Point(lng: Number, lat: Number) 经度在前
const MAPPoniter = new BMap.Point(data.lng, data.lat)
// 创建图像标注实例 默认样式是个红点 可进行设置
// 这里设置为data中的一base64蓝色点图片
const blueIcon = new BMap.Icon(this.bluePoint, new BMap.Size(32, 38))
const MAPMarker = new BMap.Marker(MAPPoniter, { icon: blueIcon }) // 设置标签 内容 偏移量
const label = new BMap.Label(data.name, {
offset: new BMap.Size(-27, 32)
})
// 标签样式
label.setStyle({
border: 'none',
background: '#ACACAC',
fontSize: 20,
fontWeight: 'bold',
color: 'red'
})
// 设置标签
MAPMarker.setLabel(label) // 设置 hover 时显示的点的名称
MAPMarker.setTitle(data.name) // 点击事件监听
MAPMarker.addEventListener('click', function (e) {
console.log(e)
}) // 在地图中添加覆盖物
map.addOverlay(MAPMarker)
}

一般设置setLabelsetTitle二选一吧,要直接显示出信息的时候就用setLabel

init()中调用该方法:

init(){
...
this.makePoint(map, center)
}

添加控件

百度地图中还可添加一些辅助的控件,比如比例尺,缩放控件等。

init(){
// ......省略之前代码
// 添加缩放控件
const navigation = new BMap.NavigationControl({
anchor: BMAP_ANCHOR_BOTTOM_RIGHT,
type: BMAP_NAVIGATION_CONTROL_SMALL
})
map.addControl(navigation)
}

注:因为eslint可能会提示BMAP_ANCHOR_BOTTOM_RIGHT需要使用字符串,但这些大写的常量配置不应使用字符串,否则会不生效。

清除地图左下角的图标

使用css即可让图标消失,但注意样式不要放在scoped中:

<style lang="less" scoped>
.baidu-map {
width: 100%;
height: 100%;
}
</style> <style>
.anchorBL a {
display: none;
} .anchorBL img {
display: none;
} .anchorBL span {
display: none !important;
}
</style>

处理大量点的方法

添加几个点,几十个点用上面的方法就完了。但是若是有上千上万个点也这么处理吗?虽然我们可以直接一个for循环,但是,这样做了的话就是添加点是时候浏览器会卡住一段时间。所以添加大量点的时候可以使用如下方法,各自有优缺点依情况选用吧。

这里先定义下点的格式:

[
{
"name": "温州张和堂医药连锁有限公司兴元店",
"lng": "120.763505",
"lat": "27.96839093"
},
{
"name": "温州万康大药房有限公司",
"lng": "120.7530476",
"lat": "27.97953802"
}
]

点聚合

点聚合的效果就是,将密集的多个点聚合在一起显示一个大点并标注数量,点击可以放大,详细见后面效果图。

index.html中引入,百度地图相关的工具库:

<script src="//api.map.baidu.com/library/TextIconOverlay/1.2/src/TextIconOverlay_min.js"></script>
<script src="//api.map.baidu.com/library/MarkerClusterer/1.2/src/MarkerClusterer_min.js"></script>

点聚合的方法实现:

makePolyPoints(map, data) {
const MAPMarkers = []
map.clearOverlays()
data.forEach(point => {
const MAPMarker = new BMap.Marker(new BMap.Point(point.lng, point.lat))
MAPMarker.setTitle(point.name)
MAPMarkers.push(MAPMarker)
// 可以在点对象上添加属性,点击的监听能获取该属性
MAPMarker.zbbm = 'xxxxx'
MAPMarker.addEventListener('click', function (e) {
console.log('坐标编码:', e.target.zbbm)
})
})
if (map.markerClusterer) {
map.markerClusterer.clearMarkers()
}
// 使用点聚合
map.markerClusterer = new BMapLib.MarkerClusterer(map, {
markers: MAPMarkers
})
}

init()调用即可使用,如需要要使用labe和自定义图标icon,与添加单个点的类似。

海量点

海量点就是不把点聚合起来,而是全部显示出来。但使用这种方法的缺点是不能自定义点的图标,只能使用官方提供的预设图形作为点的图标

使用海量点需要引入:

<script src="//api.map.baidu.com/library/TextIconOverlay/1.2/src/TextIconOverlay_min.js"></script>
<script src="//api.map.baidu.com/library/MarkerClusterer/1.2/src/MarkerClusterer_min.js"></script>

海量点方法实现:

makeCollectionPoints(map, data) {
map.clearOverlays()
// 判断是否支持使用 canvas (海量点)
if (document.createElement('canvas').getContext) {
// 坐标点数据数组
var points = []
for (var point of data) {
points.push(new BMap.Point(point.lng, point.lat))
}
// 海量点的配置属性
// 配置图标:大小 形状 颜色
const options = {
size: BMAP_POINT_SIZE_NORMAL,
shape: BMAP_POINT_SHAPE_STAR,
color: 'yellow'
}
// 初始化海量点
const pointCollection = new BMap.PointCollection(points, options)
pointCollection.addEventListener('click', function (e) {
console.log(e)
})
map.addOverlay(pointCollection)
} else {
alert('浏览器不支持,请使用chrome、safari、IE8+以上浏览器')
}
}

ShapeType预设图形:

常量 描述
BMAP_POINT_SHAPE_CIRCLE 圆形,为默认形状
BMAP_POINT_SHAPE_STAR 星形
BMAP_POINT_SHAPE_SQUARE 方形
BMAP_POINT_SHAPE_RHOMBUS 星形
BMAP_POINT_SHAPE_STAR 菱形
BMAP_POINT_SHAPE_WATERDROP 水滴状,该类型无size和color属性

其它具体参数配置参考:百度地图 javascript 3.0 api

使用mapv

mapv是百度地图官方推出的地理信息可视化开源库,借助其也能进行大量坐标点的添加操作。

官方API

它是使用canvas在地图上添加了一层,能保证速度和自定义点图标,首先导入mapv的库$npm install mapv,或者:

<script src="//mapv.baidu.com/build/mapv.min.js"></script>
点的数据格式
[
{
geometry: {
type: 'Point',
coordinates: [123, 23]
},
fillStyle: 'red',
size: 30
},
{
geometry: {
type: 'Point',
coordinates: [121, 33]
},
fillStyle: 'rgba(255, 255, 50, 0.5)',
size: 90
}
]
配置项说明
{
zIndex: 1, // 层级
size: 5, // 大小值
fillStyle: 'rgba(200, 200, 50, 1)', // 填充颜色
strokeStyle: 'rgba(0, 0, 255, 1)', // 描边颜色
lineWidth: 4, // 描边宽度
globalAlpha: 1, // 透明度
globalCompositeOperation: 'lighter', // 颜色叠加方式
shadowColor: 'rgba(255, 255, 255, 1)', // 投影颜色
shadowBlur: 35, // 投影模糊级数
shadowOffsetX: 0,
shadowOffsetY: 0,
lineCap: 'butt',
lineJoin: 'miter',
miterLimit: 10
}
mapv添加大量点的方法:
makeMapvPoints(map, data) {
if (document.createElement('canvas').getContext) {
// 使用自定义坐标点图形
var img = new Image()
img.src = this.bluePoint // 创建mapv配置项
const iconOpt = {
draw: 'icon',
width: 32,
height: 38,
methods: {
click: item => {
if (item) console.log(item)
}
}
} // 在图片加载后再创建图层才能自定义图标
img.onload = function () {
// 点坐标的数组
const dataSet = []
// 构建dataset格式数据
data.forEach(point => {
const geometry = {}
geometry.type = 'Point'
geometry.coordinates = [point.lng, point.lat]
dataSet.push({
geometry,
icon: img,
tag: { name: point.name }
})
}) const mapSet = new mapv.DataSet(dataSet)
// dataSet.set(data) // 修改数据 // 叠加图层
const mapvLayer = new mapv.baiduMapLayer(map, mapSet, iconOpt)
// 显示图层
mapvLayer.show()
// mapvLayer.hide() // 隐藏图层
}
} else {
alert('浏览器不支持,请使用chrome、safari、IE8+以上浏览器')
}
}

注意:

  1. 在使用自定义图标icon时,必须设置widthheight或者size。否则坐标点的点击事件无法触发。
  2. 在使用点击事件回调时,要判断回调的参数是否为null。因为该事件总能触发(在有无坐标点击都能触发),无坐标点点击返回null,有则非空。



补充

地理坐标查询 - 拾取坐标系统

地理坐标查询 - 拾取坐标系统

百度地图API开发的快速使用和大量坐标点操作【点聚合,海量点,mapv】的更多相关文章

  1. 深入浅出百度地图API开发系列(1):前言

    百度地图API目前在地图API领域越来越受到众多开发者的关注,许多应用都使用到了百度地图API服务,包括博主me,我自己使用做的是Javascript API,根据经验,我想整理出一份系列教程,如果能 ...

  2. 深入浅出百度地图API开发系列(2):创建地图

    上一篇文章里,先介绍了一下百度地图API开发所涉及到的一些基础概念,包括投影,坐标系等基础概念,再有了这些基础后,我们可以开始开发自己的web地图了.先来个代码示例(建议大家都是用百度地图API大众版 ...

  3. 基于MFC与第三方类CWebPage的百度地图API开发范例

    在进行百度地图API开发之前你需要到http://developer.baidu.com/map申请密匙 密匙申请之后就可以进行百度地图API的开发了. 下面我们以在visual c++6.0里进行地 ...

  4. 【百度地图API】如何快速创建带有标注的地图?——快速创建地图工具+如何标注商家

    原文:[百度地图API]如何快速创建带有标注的地图?--快速创建地图工具+如何标注商家 摘要: 如果你不会程序,如果你不想写代码. 如果你想拥有一张自己的地图,如果你想在该地图上标注出你商店的位置. ...

  5. 百度地图API开发指南

    简介什么是百度地图API? 百度地图API是一套由JavaScript语言编写的应用程序接口,它能够帮助您在网站中构建功能丰富.交互性强的地图应用.百度地图API包含了构建地图基本功能的各种接口,提供 ...

  6. 深入浅出百度地图API开发系列(3):模块化设计

    在前面两张简单介绍了百度地图API的基础知识和使用之后,我们来分析一下百度地图API的基本架构,了解一下基本架构可以帮助我们更清晰的了解API的功能和调用过程,也就可以帮助我们在实际开发中可以更方便的 ...

  7. 百度地图API开发一——仿照现有测距效果实现测面功能

      最近做了一个百度地图API的开发项目,里面有测量距离和测量面积的功能需求.测量距离百度给出了封装好的javascript包——BMapLib.DistanceTool,效果如下: 这个效果体验很好 ...

  8. 用户Ip地址和百度地图api接口获取用户地理位置(经纬度坐标,城市)

    <?php   //获取用户ip(外网ip 服务器上可以获取用户外网Ip 本机ip地址只能获取127.0.0.1) function getip(){     if(!empty($_SERVE ...

  9. android 基于百度地图api开发定位以及获取详细地址

    一:百度地图开发必须要到百度开发平台android开发api下载相应的库,已经申请百度地图开发key. 二:新建项目baidumaplocation.设计main.xml文件这里注意的是MapView ...

随机推荐

  1. 03 jumpserver用户管理

    3.用户管理: (1)创建用户组: (2)创建用户并加入组: (3)用户通过邮件链接修改密码:

  2. 6、基本数据类型(list)

    6.1.列表: 1.li = [1, 12, 9, "age", ["孙子涵", ["19", 10], "张涵予"], ...

  3. oracle查询用户所在表为空的表名

    1 select * from user_tables where num_rows = 0 查询之后发现查询的不全,查询之后发现num_rows为空 select * from user_table ...

  4. hud 3308 LCIS 线段树 区间合并

    题意: Q a b 查询[a, b]区间的最长连续递增子序列的长度 U a b 将下表为a的元素更新为b 区间合并一般都有3个数组:区间最值,左区间最值和右区间最值 具体详见代码 #include & ...

  5. 通过CRM客户系统改变销售工作模式

    CRM客户管理软件对于企业来说,能够优化销售流程.维护客户关系.销售流程管理等.但是很多销售人员认为企业购买CRM软件,是用来监视他们的武器,自然会受到销售团队的抵触.所以经常会出现管理者辛苦的选型, ...

  6. Springboot:单元测试@FixMethodOrder注解指定测试方法的执行顺序

    我们在写JUnit测试用例时,有时候需要按照定义顺序执行我们的单元测试方法,比如如在测试数据库相关的用例时候要按照测试插入.查询.删除的顺序测试.如果不按照这个顺序测试可能会出现问题,比如删除方法在前 ...

  7. Python 绘制词云

    文本内容:data(包含很多条文本) 1.分词: import jieba data_cut = data.apply(jieba.lcut) 2.去除停用词: stoplist.txt:链接:htt ...

  8. K8S(Kubernetes)学习笔记

    Kubernetes(k8s)是google提供的开源的容器集群管理系统,在Docker技术的基础上,为容器化的应用提供部署运行.资源调度.服务发现和动态伸缩等一系列完整功能,提高了大规模容器集群管理 ...

  9. 【故障公告】redis 服务器宕机引发博客站点故障

    非常抱歉,今天下午 17:10~17:40 左右,由于博客系统所使用的 redis 服务器宕机,造成博客站点无法正常访问,由此给您带来很大的麻烦,请您谅解. 我们会针对这次故障改进 redis 服务器 ...

  10. 「AGC030D」Inversion Sum

    「AGC030D」Inversion Sum 传送门 妙啊. 由于逆序对的个数最多只有 \(O(n^2)\) 对,而对于每一个询问与其相关的逆序对数也最多只有 \(O(n)\) 对,我们可以对于每一对 ...