85 lines
3.0 KiB
Markdown
85 lines
3.0 KiB
Markdown
|
## 百度地图扩展
|
|||
|
|
|||
|
ECharts 百度地图扩展,可以在百度地图上展现 [点图](https://echarts.apache.org/zh/option.html#series-scatter),[线图](https://echarts.apache.org/zh/option.html#series-lines),[热力图](https://echarts.apache.org/zh/option.html#series-heatmap) 等可视化。
|
|||
|
|
|||
|
|
|||
|
### 示例
|
|||
|
|
|||
|
[全国主要城市空气质量](https://echarts.apache.org/examples/zh/editor.html?c=effectScatter-bmap)
|
|||
|
|
|||
|
[北京公交路线](https://echarts.apache.org/examples/zh/editor.html?c=lines-bmap-bus)
|
|||
|
|
|||
|
[北京公交路线特效](https://echarts.apache.org/examples/zh/editor.html?c=lines-bmap-effect)
|
|||
|
|
|||
|
[杭州热门步行路线](https://echarts.apache.org/examples/zh/editor.html?c=heatmap-bmap)
|
|||
|
|
|||
|
[在地图上显示分箱图](https://echarts.apache.org/examples/zh/editor.html?c=map-bin)
|
|||
|
|
|||
|
|
|||
|
### 引入
|
|||
|
|
|||
|
可以直接引入打包好的扩展文件和百度地图的 jssdk
|
|||
|
|
|||
|
```html
|
|||
|
<!-- 引入百度地图的 JS SDK,这里需要使用你在百度地图开发者平台申请的 ak -->
|
|||
|
<!-- 如需使用百度地图 2.0 版本,请将 `v=3.0` 改为 `v=2.0` -->
|
|||
|
<script src="https://api.map.baidu.com/api?v=3.0&ak="></script>
|
|||
|
<!-- 引入 ECharts -->
|
|||
|
<script src="dist/echarts.min.js"></script>
|
|||
|
<!-- 引入百度地图扩展 -->
|
|||
|
<script src="dist/extension/bmap.min.js"></script>
|
|||
|
```
|
|||
|
|
|||
|
如果是 webpack 打包,也可以 require 引入
|
|||
|
|
|||
|
```js
|
|||
|
require('echarts');
|
|||
|
require('echarts/extension/bmap/bmap');
|
|||
|
```
|
|||
|
|
|||
|
插件会自动注册相应的组件。
|
|||
|
|
|||
|
### 使用
|
|||
|
|
|||
|
扩展主要提供了跟 geo 一样的坐标系和底图的绘制,因此配置方式非常简单,如下
|
|||
|
|
|||
|
```js
|
|||
|
option = {
|
|||
|
// 加载 bmap 组件
|
|||
|
bmap: {
|
|||
|
// 百度地图中心经纬度。默认为 [104.114129, 37.550339]。
|
|||
|
center: [120.13066322374, 30.240018034923],
|
|||
|
// 百度地图缩放级别。默认为 5。
|
|||
|
zoom: 14,
|
|||
|
// 是否开启拖拽缩放,可以只设置 'scale' 或者 'move'。默认关闭。
|
|||
|
roam: true,
|
|||
|
// 百度地图的旧版自定义样式,见 https://lbsyun.baidu.com/custom/index.htm
|
|||
|
mapStyle: {},
|
|||
|
// 百度地图 3.0 之后的新版自定义样式,见 https://lbsyun.baidu.com/index.php?title=open/custom
|
|||
|
mapStyleV2: {},
|
|||
|
// 百度地图的初始化配置,见 https://lbsyun.baidu.com/cms/jsapi/reference/jsapi_reference.html#a0b1
|
|||
|
mapOptions: {
|
|||
|
// 禁用百度地图自带的底图可点功能
|
|||
|
enableMapClick: false
|
|||
|
}
|
|||
|
},
|
|||
|
series: [{
|
|||
|
type: 'scatter',
|
|||
|
// 使用百度地图坐标系
|
|||
|
coordinateSystem: 'bmap',
|
|||
|
// 数据格式跟在 geo 坐标系上一样,每一项都是 [经度,纬度,数值大小,其它维度...]
|
|||
|
data: [ [120, 30, 1] ],
|
|||
|
// 编码数据项中第三个元素作为 value 维度
|
|||
|
encode: {
|
|||
|
value: 2
|
|||
|
}
|
|||
|
}]
|
|||
|
}
|
|||
|
|
|||
|
// 获取百度地图实例,使用百度地图自带的控件
|
|||
|
var bmap = chart.getModel().getComponent('bmap').getBMap();
|
|||
|
bmap.addControl(new BMap.MapTypeControl());
|
|||
|
```
|
|||
|
|
|||
|
|