antv-l7/docs/api/scene.zh.md

474 lines
8.3 KiB
Markdown
Raw Normal View History

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
---
# 简介
```javascript
// Module 引用
import { Scene } from '@antv/l7';
import { GaodeMap } from '@antv/l7-maps';
const scene = new Scene({
id: 'map',
map: new GaodeMap({
style: 'dark',
2019-12-18 22:47:51 +08:00
center: [110.770672, 34.159869],
pitch: 45,
}),
});
// CDN 使用方法
const scene = new L7.Scene({
id: 'map',
map: new L7.GaodeMap({
style: 'dark',
2019-12-18 22:47:51 +08:00
center: [110.770672, 34.159869],
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({
id: 'map',
map: new L7.GaodeMap({
style: 'dark',
2019-12-18 22:47:51 +08:00
center: [110.770672, 34.159869],
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
2019-12-18 22:47:51 +08:00
需传入 dom 容器或者容器 id  {domObject || string} [必选]
2019-11-21 13:06:13 +08:00
### logoPosition
2020-02-05 10:13:59 +08:00
L7 Logo 的显示位置 默认左下角
- bottomright
- topright
- bottomleft,
- topleft`
2020-02-05 10:13:59 +08:00
### logoVisible
2020-02-05 10:13:59 +08:00
是否显示 L7 的 Logo {boolean} true
2020-03-08 14:48:52 +08:00
### antialias
2020-03-08 15:19:21 +08:00
是否开始前抗锯齿 `boolean` `true`
2020-03-08 14:48:52 +08:00
### preserveDrawingBuffer
2020-03-08 15:19:21 +08:00
是否保留缓冲区数据 `boolean` `false`
2020-03-08 14:48:52 +08:00
## Map 配置项
2019-11-21 13:06:13 +08:00
### zoom
2019-12-18 22:47:51 +08:00
2020-03-15 20:09:16 +08:00
地图初始显示级别 {number} Mapbox 0-24 高德 3-18
2019-11-21 13:06:13 +08:00
### center
2019-12-18 22:47:51 +08:00
2019-11-21 13:06:13 +08:00
地图初始中心经纬度 {Lnglat}
### pitch
2019-12-18 22:47:51 +08:00
2019-11-21 13:06:13 +08:00
地图初始俯仰角度 {number}  default 0
2019-11-21 17:52:18 +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
### minZoom
2020-03-15 20:09:16 +08:00
地图最小缩放等级 {number}  default 0 Mapbox 0-24 高德 3-18
2019-11-21 13:06:13 +08:00
2019-12-18 22:47:51 +08:00
### maxZoom
2019-11-21 13:06:13 +08:00
2020-03-15 20:09:16 +08:00
地图最大缩放等级 {number}  default 22 Mapbox0-24 高德 3-18
2019-11-21 13:06:13 +08:00
2019-12-18 22:47:51 +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
## 方法
### getZoom
2019-12-18 22:47:51 +08:00
2019-11-21 13:06:13 +08:00
获取当前缩放等级
```javascript
scene.getZoom();
```
2019-12-18 22:47:51 +08:00
return {float}   当前缩放等级
2019-11-21 13:06:13 +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();
```
2020-02-08 01:51:17 +08:00
### getLayerByName(name)
根据图层名称获取图层
参数
2020-02-08 20:09:14 +08:00
- name {string}
2020-02-08 01:51:17 +08:00
layer 初始化可配置图层 name
```javascript
scene.getLayerByName(name);
```
return Layer 图层对象
2019-11-21 13:06:13 +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} :地图中心点
### 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
### 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-03-20 15:02:46 +08:00
### getContainer
获取地图容器 return htmlElement
```javascript
scene.getContainer();
```
### setMapStyle
2019-12-18 22:47:51 +08:00
参数:`style` {string} 地图样式 具体样式格式和各底图设置方法一致
2019-12-18 22:47:51 +08:00
L7 内置了三种地图样式AMAP 和 MapBox 都适用
- light
- dark
- normal
设置地图底图样式的方法
```javascript
// 快捷名称设置
scene.setMapStyle('light');
// mapbox 主题设置
2019-12-18 22:47:51 +08:00
scene.setMapStyle('mapbox://styles/mapbox/streets-v11');
2019-12-18 22:47:51 +08:00
// AMap
scene.setMapStyle(
'amap://styles/2a09079c3daac9420ee53b67307a8006?isPublic=true',
);
```
2019-11-21 13:06:13 +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} 地图中心点
2019-11-21 13:06:13 +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-12-18 22:47:51 +08:00
- zoom {number}
- center {LngLat}
2019-11-21 13:06:13 +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
### 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
```
### 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
```
### 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-12-18 22:47:51 +08:00
- `center` LngLat 中心位置坐标
2019-11-21 13:06:13 +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
参数:
- `x` {number} 水平方向移动像素 向右为正方向
2019-12-18 22:47:51 +08:00
- `y` {number} 垂直方向移动像素 向下为正方向
2019-11-21 13:06:13 +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-08-11 11:11:52 +08:00
### setMapStatus
2020-08-11 12:01:56 +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
### fitBounds
2019-12-18 22:47:51 +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
```
### removeLayer
2019-12-18 22:47:51 +08:00
移除 layer
2019-11-21 13:06:13 +08:00
```javascript
2019-12-18 22:47:51 +08:00
scene.removeLayer(layer);
2019-11-21 13:06:13 +08:00
```
2019-12-18 22:47:51 +08:00
参数
2019-12-18 22:47:51 +08:00
- `layer` {Layer}
2019-11-21 13:06:13 +08:00
2020-03-12 16:06:26 +08:00
### exportMap
导出地图,目前仅支持导出可视化层,不支持底图导出
- 参数 type `png|jpg` 默认 png
2020-04-22 17:09:24 +08:00
```javascript
scene.exportMap('png');
```
2020-03-12 16:06:26 +08:00
### destroy
scene 销毁方法,离开页面,或者不需要使用地图可以调用
```
scene.destroy();
```
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
事件监听
#### 参数
`eventName` {string} 事件名
`handler` {function } 事件回调函数
2019-11-21 13:06:13 +08:00
### off
移除事件监听
`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) => {}); // 鼠标在地图上单击按下时触发
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) 方法