2019-11-21 13:06:13 +08:00
|
|
|
|
---
|
|
|
|
|
title: 场景 Scene
|
2019-11-26 11:59:39 +08:00
|
|
|
|
order: 2
|
2019-11-21 13:06:13 +08:00
|
|
|
|
---
|
2020-11-17 10:59:32 +08:00
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
`markdown:docs/common/style.md`
|
2020-11-17 10:59:32 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
# 简介
|
|
|
|
|
|
2019-11-26 17:51:29 +08:00
|
|
|
|
```javascript
|
|
|
|
|
// Module 引用
|
|
|
|
|
import { Scene } from '@antv/l7';
|
2019-11-27 14:54:53 +08:00
|
|
|
|
import { GaodeMap } from '@antv/l7-maps';
|
2019-11-26 17:51:29 +08:00
|
|
|
|
const scene = new Scene({
|
|
|
|
|
id: 'map',
|
2019-11-27 14:54:53 +08:00
|
|
|
|
map: new GaodeMap({
|
2019-11-26 17:51:29 +08:00
|
|
|
|
style: 'dark',
|
2019-12-18 22:47:51 +08:00
|
|
|
|
center: [110.770672, 34.159869],
|
2019-11-26 17:51:29 +08:00
|
|
|
|
pitch: 45,
|
|
|
|
|
}),
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// CDN 使用方法
|
|
|
|
|
const scene = new L7.Scene({
|
|
|
|
|
id: 'map',
|
2019-11-27 14:54:53 +08:00
|
|
|
|
map: new L7.GaodeMap({
|
2019-11-26 17:51:29 +08:00
|
|
|
|
style: 'dark',
|
2019-12-18 22:47:51 +08:00
|
|
|
|
center: [110.770672, 34.159869],
|
2019-11-26 17:51:29 +08:00
|
|
|
|
pitch: 45,
|
|
|
|
|
}),
|
|
|
|
|
});
|
|
|
|
|
```
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
|
|
|
|
## Map
|
|
|
|
|
|
2019-12-18 22:47:51 +08:00
|
|
|
|
L7 地理可视化侧重于地理数据的可视化表达,地图层需要依赖第三方地图,第三方地图通过 Scene 统一创建,创建管理
|
|
|
|
|
只需要通过 Scene 传入地图配置项即可。
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2019-12-18 22:47:51 +08:00
|
|
|
|
目前 L7 支持两种地图底图
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
|
|
|
|
- 高德地图 国内业务场景 合规中国地图
|
|
|
|
|
- MapBox 国际业务,或者内网离线部署场景
|
|
|
|
|
|
2019-12-18 22:47:51 +08:00
|
|
|
|
### map
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2019-12-18 22:47:51 +08:00
|
|
|
|
可以通过 scene map 属性获取 map 实例
|
2019-11-21 17:52:18 +08:00
|
|
|
|
|
|
|
|
|
```javascript
|
2019-12-18 22:47:51 +08:00
|
|
|
|
const map = scene.map;
|
2019-11-21 17:52:18 +08:00
|
|
|
|
```
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
|
|
|
|
为了统一不同底图之前的接口差异 L7 在 scene 层对 map 的方法做了统一,因此一些地图的操作方法可以通过 scene 调用这样,切换不同底图时保证表现一致。
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
|
|
|
|
示例代码
|
|
|
|
|
|
|
|
|
|
```javascript
|
2019-12-18 22:47:51 +08:00
|
|
|
|
const scene = new L7.Scene({
|
2019-11-25 15:27:56 +08:00
|
|
|
|
id: 'map',
|
2019-11-27 14:54:53 +08:00
|
|
|
|
map: new L7.GaodeMap({
|
2019-11-26 17:51:29 +08:00
|
|
|
|
style: 'dark',
|
2019-12-18 22:47:51 +08:00
|
|
|
|
center: [110.770672, 34.159869],
|
2019-11-26 17:51:29 +08:00
|
|
|
|
pitch: 45,
|
|
|
|
|
}),
|
2019-12-18 22:47:51 +08:00
|
|
|
|
});
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### 构造函数
|
|
|
|
|
|
2019-12-18 22:47:51 +08:00
|
|
|
|
**Scene**
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
|
|
|
|
## 配置项
|
|
|
|
|
|
|
|
|
|
### 地图配置项
|
|
|
|
|
|
|
|
|
|
### id
|
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
<description> _string | HTMLElement_ **必选** </description>
|
|
|
|
|
|
|
|
|
|
需传入 dom 容器或者容器 id
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2020-02-04 22:37:11 +08:00
|
|
|
|
### logoPosition
|
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
<description> _bottomleft_ **可选** </description>
|
|
|
|
|
|
2020-02-05 10:13:59 +08:00
|
|
|
|
L7 Logo 的显示位置 默认左下角
|
2020-02-04 22:37:11 +08:00
|
|
|
|
|
|
|
|
|
- bottomright
|
|
|
|
|
- topright
|
|
|
|
|
- bottomleft,
|
|
|
|
|
- topleft`
|
|
|
|
|
|
2020-11-17 10:59:32 +08:00
|
|
|
|
### logoVisible logo 是否可见
|
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
<description> _bottomleft_ **可选** _default: true_ </description>
|
2020-02-04 22:37:11 +08:00
|
|
|
|
|
2020-02-05 10:13:59 +08:00
|
|
|
|
是否显示 L7 的 Logo {boolean} true
|
2020-02-04 22:37:11 +08:00
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### antialias 是否开启抗锯齿
|
|
|
|
|
|
|
|
|
|
<description> _boolean_ **可选** _default: true_ </description>
|
2020-03-08 14:48:52 +08:00
|
|
|
|
|
2020-03-08 15:19:21 +08:00
|
|
|
|
是否开始前抗锯齿 `boolean` `true`
|
2020-03-08 14:48:52 +08:00
|
|
|
|
|
|
|
|
|
### preserveDrawingBuffer
|
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
<description> _boolean_ **可选** _default: false_ </description>
|
|
|
|
|
|
2020-03-08 15:19:21 +08:00
|
|
|
|
是否保留缓冲区数据 `boolean` `false`
|
2020-03-08 14:48:52 +08:00
|
|
|
|
|
|
|
|
|
## Map 配置项
|
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### zoom 初始化缩放等级
|
|
|
|
|
|
2020-11-17 10:59:32 +08:00
|
|
|
|
<description> _number_ </description>
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
地图初始显示级别 {number} Mapbox (0-24) 高德 (2-19)
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### center 地图中心
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
地图初始中心经纬度 {Lnglat}
|
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### pitch 地图倾角
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
地图初始俯仰角度 {number} default 0
|
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### style 地图图样式
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2019-11-21 17:52:18 +08:00
|
|
|
|
简化地图样式设置,L7 内置了三种主题默认样式 高德,mapbox 都可以使用
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
- dark
|
|
|
|
|
- light
|
|
|
|
|
- normal
|
2019-12-14 22:15:28 +08:00
|
|
|
|
- blank 无底图
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2019-11-21 17:52:18 +08:00
|
|
|
|
除了内置的样式,你也可以传入自定义的其他属性。
|
|
|
|
|
|
|
|
|
|
比如高德地图
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2020-03-08 14:48:52 +08:00
|
|
|
|
⚠️ 高德地图样式 增加 `isPublic=true` 参数
|
|
|
|
|
|
2019-11-21 17:52:18 +08:00
|
|
|
|
```javascript
|
2019-12-18 22:47:51 +08:00
|
|
|
|
{
|
|
|
|
|
style: 'amap://styles/2a09079c3daac9420ee53b67307a8006?isPublic=true'; // 设置方法和高德地图一致
|
|
|
|
|
}
|
2019-11-21 17:52:18 +08:00
|
|
|
|
```
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### minZoom 最小缩放等级
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
地图最小缩放等级 {number} default 0 Mapbox 0-24) 高德 (2-19)
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### maxZoom 最大缩放等级
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
地图最大缩放等级 {number} default 22 Mapbox(0-24) 高德 (2-19)
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### rotateEnable 是否允许旋转
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2019-12-18 22:47:51 +08:00
|
|
|
|
地图是否可旋转 {Boolean} default true
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2020-12-21 15:06:29 +08:00
|
|
|
|
## 实验参数
|
2020-12-21 15:14:40 +08:00
|
|
|
|
|
2020-12-21 15:06:29 +08:00
|
|
|
|
参数可能会废弃
|
2020-12-21 15:14:40 +08:00
|
|
|
|
|
2020-12-21 15:06:29 +08:00
|
|
|
|
### offsetCoordinate
|
|
|
|
|
|
|
|
|
|
{ boolean } default true
|
|
|
|
|
|
2020-12-21 15:14:40 +08:00
|
|
|
|
高德地图适用,是否关闭偏移坐标系
|
2020-12-21 15:06:29 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
## Layer 方法
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
### addLayer(layer) 增加图层对象
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
增加图层对象
|
|
|
|
|
|
|
|
|
|
参数 :
|
2021-05-27 19:55:06 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
- `layer` {ILayer} 图层对象
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
|
|
|
|
```javascript
|
2021-05-27 19:53:22 +08:00
|
|
|
|
scene.addLayer(layer);
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```
|
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
### getLayer(id) 获取对应的图层对象
|
|
|
|
|
|
|
|
|
|
获取对应的图层对象
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
参数 :
|
2021-05-27 19:55:06 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
- `id` {string}
|
2021-05-27 19:55:06 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
```javascript
|
|
|
|
|
scene.getLayer('layerID');
|
|
|
|
|
```
|
2021-05-27 19:55:06 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
### getLayers() 获取所有的地图图层
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
获取所有的地图图层
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```javascript
|
|
|
|
|
scene.getLayers();
|
|
|
|
|
```
|
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
### getLayerByName(name) 根据图层名称获取图层
|
2020-02-08 01:51:17 +08:00
|
|
|
|
|
|
|
|
|
根据图层名称获取图层
|
|
|
|
|
|
|
|
|
|
参数
|
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
- `name` {string} layer 初始化可配置图层 name
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
scene.getLayerByName(name); // return Layer 图层对象
|
|
|
|
|
```
|
|
|
|
|
|
2021-05-27 19:55:06 +08:00
|
|
|
|
### removeLayer 移除 layer 图层
|
2021-05-27 19:53:22 +08:00
|
|
|
|
|
|
|
|
|
移除 layer 图层
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
scene.removeLayer(layer);
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
参数 :
|
|
|
|
|
|
|
|
|
|
- `layer` {Layer}
|
|
|
|
|
|
|
|
|
|
### removeAllLayer() 移除所有的图层对象
|
|
|
|
|
|
|
|
|
|
移除所有的图层对象
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
scene.removeAllLayer();
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
## 控制组件方法
|
|
|
|
|
|
|
|
|
|
### addControl(ctl) 添加组件控件
|
|
|
|
|
|
|
|
|
|
添加组件控件
|
|
|
|
|
|
|
|
|
|
参数 :
|
|
|
|
|
|
|
|
|
|
- `crl` { IControl } 用户创建的控件对象
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
scene.addControl(ctl);
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### removeControl(ctr) 移除用户添加的组件控件
|
|
|
|
|
|
|
|
|
|
移除用户添加的组件控件
|
|
|
|
|
|
|
|
|
|
参数 :
|
|
|
|
|
|
|
|
|
|
- `ctl` { IControl } 用户创建的控件对象
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
scene.removeControl(ctl);
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### getControlByName(name) 根据控件的名称来获取控件
|
|
|
|
|
|
|
|
|
|
根据控件的名称来获取控件
|
|
|
|
|
|
|
|
|
|
- `name` { string }
|
|
|
|
|
|
|
|
|
|
```javascript
|
2021-05-27 19:55:06 +08:00
|
|
|
|
const zoomControl = new Zoom({
|
|
|
|
|
// zoom 控件
|
2021-05-27 19:53:22 +08:00
|
|
|
|
name: 'z1', // 用户传入的控件名称(也可以不传入,该控件默认名称为 zoom)
|
2021-05-27 19:55:06 +08:00
|
|
|
|
position: 'topright',
|
2021-05-27 19:53:22 +08:00
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
scene.getControlByName('z1');
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
## 标记方法
|
|
|
|
|
|
|
|
|
|
### addMarker(maker) 添加标记
|
|
|
|
|
|
|
|
|
|
往场景中添加标记对象
|
|
|
|
|
|
|
|
|
|
参数 :
|
|
|
|
|
|
|
|
|
|
- `maker` { IMarker } Marker 实例
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
const marker = new Marker({
|
2021-05-27 19:55:06 +08:00
|
|
|
|
element: el,
|
2021-05-27 19:53:22 +08:00
|
|
|
|
}).setLnglat({ lng: nodes[i].x * 1, lat: nodes[i].y });
|
|
|
|
|
scene.addMarker(marker);
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### addMarkerLayer(layer) 添加 Marker 统一管理图层
|
2021-05-27 19:55:06 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
当用户需要添加许多个 Marker 实例时,为了方便管理可以使用 markerLayer 对象统一管理
|
|
|
|
|
|
|
|
|
|
参数 :
|
|
|
|
|
|
2021-05-27 19:55:06 +08:00
|
|
|
|
- `layer` { IMarkerLayer } 标记图层对象
|
2021-05-27 19:53:22 +08:00
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
const markerLayer = new MarkerLayer();
|
|
|
|
|
scene.addMarkerLayer(markerLayer);
|
|
|
|
|
```
|
2021-05-27 19:55:06 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
[示例地址](/zh/examples/point/marker#markerlayer)
|
|
|
|
|
|
|
|
|
|
### removeMarkerLayer(layer) 移除标签图层
|
|
|
|
|
|
|
|
|
|
移除标签图层
|
|
|
|
|
|
|
|
|
|
参数 :
|
|
|
|
|
|
|
|
|
|
- `layer` { IMarkerLayer } 标记图层对象
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
scene.removeMarkerLayer(markerLayer);
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### removeAllMakers() 移除场景中所有的标签对象
|
|
|
|
|
|
|
|
|
|
移除场景中所有的标签对象
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
scene.removeAllMakers();
|
|
|
|
|
```
|
2020-02-08 01:51:17 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
## 地图方法
|
|
|
|
|
|
|
|
|
|
### getZoom 获取缩放等级
|
|
|
|
|
|
|
|
|
|
获取当前缩放等级
|
2020-02-08 01:51:17 +08:00
|
|
|
|
|
|
|
|
|
```javascript
|
2021-05-27 19:53:22 +08:00
|
|
|
|
scene.getZoom();
|
2020-02-08 01:51:17 +08:00
|
|
|
|
```
|
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
return {float} 当前缩放等级
|
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### getCenter() 获取地图中心
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
获取地图中心点
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```javascript
|
2019-12-18 22:47:51 +08:00
|
|
|
|
scene.getCenter();
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
return {Lnglat} :地图中心点
|
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### getSize() 获取地图容器大小
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
获取地图容器大小
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```javascript
|
2019-12-18 22:47:51 +08:00
|
|
|
|
scene.getSize();
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
return { Object } 地图容器的 width,height
|
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### getPitch() 获取地图倾角
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
获取地图俯仰角
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```javascript
|
|
|
|
|
scene.getPitch();
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
return {number} pitch
|
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### getContainer 获取地图容器
|
2020-03-20 15:02:46 +08:00
|
|
|
|
|
|
|
|
|
获取地图容器 return htmlElement
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
scene.getContainer();
|
|
|
|
|
```
|
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### setMapStyle 设置地图样式
|
2019-11-28 13:37:42 +08:00
|
|
|
|
|
2019-12-18 22:47:51 +08:00
|
|
|
|
参数:`style` {string} 地图样式 具体样式格式和各底图设置方法一致
|
2019-11-28 13:37:42 +08:00
|
|
|
|
|
2019-12-18 22:47:51 +08:00
|
|
|
|
L7 内置了三种地图样式,AMAP 和 MapBox 都适用
|
2019-11-28 13:37:42 +08:00
|
|
|
|
|
|
|
|
|
- light
|
|
|
|
|
- dark
|
|
|
|
|
- normal
|
|
|
|
|
|
|
|
|
|
设置地图底图样式的方法
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
// 快捷名称设置
|
|
|
|
|
|
|
|
|
|
scene.setMapStyle('light');
|
|
|
|
|
|
|
|
|
|
// mapbox 主题设置
|
2019-12-18 22:47:51 +08:00
|
|
|
|
scene.setMapStyle('mapbox://styles/mapbox/streets-v11');
|
2019-11-28 13:37:42 +08:00
|
|
|
|
|
2019-12-18 22:47:51 +08:00
|
|
|
|
// AMap
|
|
|
|
|
scene.setMapStyle(
|
|
|
|
|
'amap://styles/2a09079c3daac9420ee53b67307a8006?isPublic=true',
|
|
|
|
|
);
|
2019-11-28 13:37:42 +08:00
|
|
|
|
```
|
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### setCenter() 设置地图中心点
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
设置地图中心点坐标
|
|
|
|
|
|
|
|
|
|
```javascript
|
2019-12-18 22:47:51 +08:00
|
|
|
|
scene.setCenter([lng, lat]);
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```
|
|
|
|
|
|
2019-12-18 22:47:51 +08:00
|
|
|
|
参数:`center` {LngLat} 地图中心点
|
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### setZoomAndCenter 设置地图缩放等级和中心点
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
设置地图等级和中心
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```javascript
|
2019-12-18 22:47:51 +08:00
|
|
|
|
scene.setZoomAndCenter(zoom, center);
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```
|
|
|
|
|
|
2019-11-28 13:37:42 +08:00
|
|
|
|
参数:
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-28 13:37:42 +08:00
|
|
|
|
- zoom {number}
|
|
|
|
|
- center {LngLat}
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### setRotation 设置地图旋转
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
设置地图顺时针旋转角度,旋转原点为地图容器中心点,取值范围 [0-360]
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```javascript
|
2019-12-18 22:47:51 +08:00
|
|
|
|
scene.setRotation(rotation);
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```
|
|
|
|
|
|
2019-12-18 22:47:51 +08:00
|
|
|
|
参数: `rotation` {number}
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### zoomIn 地图放大一级
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
地图放大一级
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```javascript
|
2019-12-18 22:47:51 +08:00
|
|
|
|
scene.zoomIn();
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```
|
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### zoomOut 地图缩小一级
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
地图缩小一级
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```javascript
|
2019-12-18 22:47:51 +08:00
|
|
|
|
scene.ZoomOUt();
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```
|
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### panTo 地图移动到
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
地图平移到指定的位置
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```javascript
|
2019-12-18 22:47:51 +08:00
|
|
|
|
scene.panTo(LngLat);
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```
|
|
|
|
|
|
2019-11-28 13:37:42 +08:00
|
|
|
|
参数:
|
|
|
|
|
|
2019-12-18 22:47:51 +08:00
|
|
|
|
- `center` LngLat 中心位置坐标
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### panBy 地图平移
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
|
|
|
|
以像素为单位沿 X 方向和 Y 方向移动地图
|
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```javascript
|
2019-12-18 22:47:51 +08:00
|
|
|
|
scene.panBy(x, y);
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-28 13:37:42 +08:00
|
|
|
|
参数:
|
|
|
|
|
|
|
|
|
|
- `x` {number} 水平方向移动像素 向右为正方向
|
|
|
|
|
|
2019-12-18 22:47:51 +08:00
|
|
|
|
- `y` {number} 垂直方向移动像素 向下为正方向
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### setPitch 设置地图倾角
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
设置地图仰俯角度
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```javascript
|
2019-12-18 22:47:51 +08:00
|
|
|
|
scene.setPitch(pitch);
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```
|
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### setMapStatus 设置地图状态
|
2020-08-11 12:01:56 +08:00
|
|
|
|
|
2019-11-28 13:37:42 +08:00
|
|
|
|
参数 :
|
2020-08-11 12:01:56 +08:00
|
|
|
|
|
|
|
|
|
```javascript
|
2020-08-11 11:11:52 +08:00
|
|
|
|
IStatusOptions {
|
|
|
|
|
showIndoorMap: boolean;
|
|
|
|
|
resizeEnable: boolean;
|
|
|
|
|
dragEnable: boolean;
|
|
|
|
|
keyboardEnable: boolean;
|
|
|
|
|
doubleClickZoom: boolean;
|
|
|
|
|
zoomEnable: boolean;
|
|
|
|
|
rotateEnable: boolean;
|
|
|
|
|
```
|
|
|
|
|
|
2020-08-11 12:01:56 +08:00
|
|
|
|
```javascript
|
|
|
|
|
scene.setMapStatus({ dragEnable: false });
|
2020-08-11 11:11:52 +08:00
|
|
|
|
```
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2019-12-18 22:47:51 +08:00
|
|
|
|
- `pitch` {number}
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### fitBounds 设置地图缩放范围
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-28 13:37:42 +08:00
|
|
|
|
地图缩放到某个范围内
|
|
|
|
|
|
|
|
|
|
参数 :
|
|
|
|
|
|
2020-07-20 11:12:49 +08:00
|
|
|
|
- `extent` { array} 经纬度范围 [[minlng,minlat],[maxlng,maxlat]]
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
|
|
|
|
```javascript
|
2020-07-20 11:35:40 +08:00
|
|
|
|
scene.fitBounds([
|
|
|
|
|
[112, 32],
|
|
|
|
|
[114, 35],
|
|
|
|
|
]);
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```
|
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### exportMap 导出地图图片
|
2020-03-12 16:06:26 +08:00
|
|
|
|
|
|
|
|
|
导出地图,目前仅支持导出可视化层,不支持底图导出
|
|
|
|
|
|
|
|
|
|
- 参数 type `png|jpg` 默认 png
|
|
|
|
|
|
2020-04-22 17:09:24 +08:00
|
|
|
|
```javascript
|
|
|
|
|
scene.exportMap('png');
|
|
|
|
|
```
|
2020-03-12 16:06:26 +08:00
|
|
|
|
|
2020-11-16 15:19:41 +08:00
|
|
|
|
### destroy 场景销毁
|
2020-04-29 12:03:06 +08:00
|
|
|
|
|
|
|
|
|
scene 销毁方法,离开页面,或者不需要使用地图可以调用
|
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
```javascript
|
2020-04-29 12:03:06 +08:00
|
|
|
|
scene.destroy();
|
|
|
|
|
```
|
2021-05-27 19:55:06 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
## iconfont 映射支持
|
|
|
|
|
|
|
|
|
|
### addIconFont(name, fontUnicode) 增加对数据中 unicode 的映射支持
|
|
|
|
|
|
|
|
|
|
支持对用户传入的数据进行 unicode 的映射,在内部维护一组名称和对应 key 的键值对
|
|
|
|
|
|
|
|
|
|
参数 :
|
|
|
|
|
|
|
|
|
|
- `name` {string}
|
|
|
|
|
- `fontUnicode` {string}
|
|
|
|
|
|
|
|
|
|
```javascript
|
2021-05-27 19:55:06 +08:00
|
|
|
|
scene.addIconFont('icon1', '');
|
|
|
|
|
scene.addIconFont('icon2', '');
|
|
|
|
|
scene.addFontFace(fontFamily, fontPath);
|
|
|
|
|
const pointIconFontLayer = new PointLayer({})
|
|
|
|
|
.source(
|
|
|
|
|
[
|
|
|
|
|
{
|
|
|
|
|
j: 140,
|
|
|
|
|
w: 34,
|
|
|
|
|
m: 'icon1',
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
j: 140,
|
|
|
|
|
w: 36,
|
|
|
|
|
m: 'icon2',
|
|
|
|
|
},
|
|
|
|
|
],
|
|
|
|
|
{
|
|
|
|
|
parser: {
|
|
|
|
|
type: 'json',
|
|
|
|
|
x: 'j',
|
|
|
|
|
y: 'w',
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
)
|
|
|
|
|
.shape('m', 'text')
|
|
|
|
|
.size(12)
|
|
|
|
|
.color('w', ['#f00', '#f00', '#0f0'])
|
|
|
|
|
.style({
|
|
|
|
|
fontFamily,
|
|
|
|
|
iconfont: true,
|
|
|
|
|
textAllowOverlap: true,
|
|
|
|
|
});
|
|
|
|
|
scene.addLayer(pointIconFontLayer);
|
2021-05-27 19:53:22 +08:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### addIconFonts(options) 同时传入多组 name - unicode 的键值对
|
|
|
|
|
|
|
|
|
|
同时传入多组 name - unicode 的键值对
|
|
|
|
|
|
|
|
|
|
参数 :
|
2021-05-27 19:55:06 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
- `options` { Array<[name, unicode]> }
|
|
|
|
|
|
|
|
|
|
```javascript
|
2021-05-27 19:55:06 +08:00
|
|
|
|
scene.addIconFonts([
|
|
|
|
|
['icon1', ''],
|
|
|
|
|
['icon2', ''],
|
|
|
|
|
]);
|
2021-05-27 19:53:22 +08:00
|
|
|
|
```
|
2021-05-27 19:55:06 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
## 全局资源
|
|
|
|
|
|
|
|
|
|
### addImage(id, img) 全局中添加的图片资源
|
|
|
|
|
|
|
|
|
|
在 L7 的图层对象可以使用在 scene 全局中添加的图片资源
|
|
|
|
|
|
|
|
|
|
参数 :
|
2021-05-27 19:55:06 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
- `id` {string}
|
|
|
|
|
- `img` {HTMLImageElement | File | string}
|
2021-05-27 19:55:06 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
```javascript
|
2021-05-27 19:55:06 +08:00
|
|
|
|
scene.addImage(
|
|
|
|
|
'02',
|
|
|
|
|
'https://gw.alipayobjects.com/zos/bmw-prod/ce83fc30-701f-415b-9750-4b146f4b3dd6.svg',
|
|
|
|
|
);
|
2021-05-27 19:53:22 +08:00
|
|
|
|
```
|
2021-05-27 19:55:06 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
[示例地址](/zh/examples/gallery/animate#animate_path_texture)
|
|
|
|
|
|
|
|
|
|
### hasImage(id) 判断全局图片资源
|
|
|
|
|
|
|
|
|
|
判断是否已经在全局添加过相应的图片资源
|
|
|
|
|
|
|
|
|
|
参数 :
|
2021-05-27 19:55:06 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
- `id` {string}
|
2021-05-27 19:55:06 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
```javascript
|
2021-05-27 19:55:06 +08:00
|
|
|
|
scene.hasImage('imageID');
|
2021-05-27 19:53:22 +08:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### removeImage(id) 全局删除图片资源
|
|
|
|
|
|
|
|
|
|
从全局删除对应的图片资源
|
|
|
|
|
|
|
|
|
|
参数 :
|
2021-05-27 19:55:06 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
- `id` {string}
|
2021-05-27 19:55:06 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
```javascript
|
2021-05-27 19:55:06 +08:00
|
|
|
|
scene.removeImage('imageID');
|
2021-05-27 19:53:22 +08:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
### addFontFace(fontFamily, fontPath) 添加字体文件
|
|
|
|
|
|
|
|
|
|
添加字体文件
|
|
|
|
|
|
|
|
|
|
参数 :
|
2021-05-27 19:55:06 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
- `fontFamily` {string} 用户为自己定义的字体名称
|
|
|
|
|
- `fontPath` {string} 导入的文件地址
|
2021-05-27 19:55:06 +08:00
|
|
|
|
|
2021-05-27 19:53:22 +08:00
|
|
|
|
```javascript
|
|
|
|
|
let fontFamily = 'iconfont';
|
2021-05-27 19:55:06 +08:00
|
|
|
|
let fontPath =
|
|
|
|
|
'//at.alicdn.com/t/font_2534097_iiet9d3nekn.woff2?t=1620444089776';
|
2021-05-27 19:53:22 +08:00
|
|
|
|
scene.addFontFace(fontFamily, fontPath);
|
|
|
|
|
```
|
2020-04-29 12:03:06 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
## 事件
|
|
|
|
|
|
|
|
|
|
### on
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
事件监听
|
|
|
|
|
|
|
|
|
|
#### 参数
|
|
|
|
|
|
2020-01-30 23:43:27 +08:00
|
|
|
|
`eventName` {string} 事件名
|
|
|
|
|
`handler` {function } 事件回调函数
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
|
|
|
|
### off
|
|
|
|
|
|
2020-01-30 23:43:27 +08:00
|
|
|
|
移除事件监听
|
|
|
|
|
`eventName` {string} 事件名
|
|
|
|
|
`handler` {function } 事件回调函数
|
2019-11-21 13:06:13 +08:00
|
|
|
|
|
2020-01-10 22:52:48 +08:00
|
|
|
|
### 场景事件
|
|
|
|
|
|
|
|
|
|
#### loaded
|
|
|
|
|
|
|
|
|
|
scene 初始化完成事件,scene 初始化完成添加 Layer
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
scene.on('loaded', () => {});
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
#### resize
|
|
|
|
|
|
|
|
|
|
地图容器变化事件
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
scene.on('resize', () => {}); // 地图容器大小改变事件
|
|
|
|
|
```
|
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
### 地图事件
|
2019-12-18 22:47:51 +08:00
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```javascript
|
2019-12-18 22:47:51 +08:00
|
|
|
|
scene.on('loaded', () => {}); //地图加载完成触发
|
|
|
|
|
scene.on('mapmove', () => {}); // 地图平移时触发事件
|
|
|
|
|
scene.on('movestart', () => {}); // 地图平移开始时触发
|
|
|
|
|
scene.on('moveend', () => {}); // 地图移动结束后触发,包括平移,以及中心点变化的缩放。如地图有拖拽缓动效果,则在缓动结束后触发
|
|
|
|
|
scene.on('zoomchange', () => {}); // 地图缩放级别更改后触发
|
|
|
|
|
scene.on('zoomstart', () => {}); // 缩放开始时触发
|
|
|
|
|
scene.on('zoomend', () => {}); // 缩放停止时触发
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```
|
|
|
|
|
|
2020-03-15 20:09:16 +08:00
|
|
|
|
其他地图事件可以查看相应底图的事件文档,地图事件也可以通过 Scene.map 进行设置
|
|
|
|
|
|
|
|
|
|
[Mapbox](https://docs.mapbox.com/mapbox-gl-js/api/#map.event)
|
|
|
|
|
[高德](https://lbs.amap.com/api/javascript-api/reference/map)
|
|
|
|
|
|
2019-11-21 13:06:13 +08:00
|
|
|
|
### 鼠标事件
|
|
|
|
|
|
|
|
|
|
```javascript
|
2019-12-18 22:47:51 +08:00
|
|
|
|
scene.on('click', (ev) => {}); // 鼠标左键点击事件
|
|
|
|
|
scene.on('dblclick', (ev) => {}); // 鼠标左键双击事件
|
|
|
|
|
scene.on('mousemove', (ev) => {}); // 鼠标在地图上移动时触发
|
|
|
|
|
scene.on('mousewheel', (ev) => {}); // 鼠标滚轮开始缩放地图时触发
|
|
|
|
|
scene.on('mouseover', (ev) => {}); // 鼠标移入地图容器内时触发
|
|
|
|
|
scene.on('mouseout', (ev) => {}); // 鼠标移出地图容器时触发
|
|
|
|
|
scene.on('mouseup', (ev) => {}); // 鼠标在地图上单击抬起时触发
|
|
|
|
|
scene.on('mousedown', (ev) => {}); // 鼠标在地图上单击按下时触发
|
2020-01-30 23:43:27 +08:00
|
|
|
|
scene.on('contextmenu', (ev) => {}); // 鼠标右键单击事件
|
2019-12-18 22:47:51 +08:00
|
|
|
|
scene.on('dragstart', (ev) => {}); //开始拖拽地图时触发
|
|
|
|
|
scene.on('dragging', (ev) => {}); // 拖拽地图过程中触发
|
|
|
|
|
scene.on('dragend', (ev) => {}); //停止拖拽地图时触发。如地图有拖拽缓动效果,则在拽停止,缓动开始前触发
|
2019-11-21 13:06:13 +08:00
|
|
|
|
```
|
2020-04-22 17:09:24 +08:00
|
|
|
|
|
|
|
|
|
## FAQ
|
|
|
|
|
|
|
|
|
|
### 禁止地图交互
|
|
|
|
|
|
|
|
|
|
1. 初始化的时候可以在 map 配置项设置
|
|
|
|
|
|
|
|
|
|
- 高德地图可查看 https://lbs.amap.com/api/javascript-api/reference/map
|
|
|
|
|
- mapbox https://docs.mapbox.com/mapbox-gl-js/api/#map
|
|
|
|
|
|
|
|
|
|
2. 加载完成后设置
|
2020-08-11 11:11:52 +08:00
|
|
|
|
调用 scene 的 [setMapStatus](./scene/#setmapstatus) 方法
|