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

584 lines
10 KiB
Markdown
Raw Normal View History

2019-11-21 13:06:13 +08:00
---
2020-03-14 12:31:09 +08:00
title: 图层基类
2019-11-21 13:06:13 +08:00
order: 0
---
## 简介
2019-12-02 15:16:45 +08:00
2020-03-14 12:31:09 +08:00
L7 Layer 接口设计遵循图形语法,所有图层都继承于该基类。
2019-11-21 13:06:13 +08:00
语法示例
```javascript
2020-01-08 00:17:58 +08:00
const layer = new Layer(option)
2019-12-02 15:16:45 +08:00
.source()
.color()
.size()
.shape()
.style();
2020-01-07 21:15:23 +08:00
2020-01-08 00:17:58 +08:00
scene.addLayer(layer);
2019-11-21 13:06:13 +08:00
```
## 构造函数
## 配置项
### name
设置图层名称,可根据 name 获取 layer;
2020-01-31 11:41:49 +08:00
### visible
2019-12-02 15:16:45 +08:00
图层是否可见   {bool } default true
2019-11-21 13:06:13 +08:00
### zIndex
2019-12-02 15:16:45 +08:00
2020-02-08 01:51:17 +08:00
图层绘制顺序,数值大绘制在上层,可以控制图层绘制的上下层级 {int}   default 0
2019-12-02 15:16:45 +08:00
2019-11-21 13:06:13 +08:00
### minZoom
2019-12-02 15:16:45 +08:00
2020-03-15 20:09:16 +08:00
图层显示最小缩放等级0-18   {number}  Mapbox 0-24 高德 3-18
2019-11-21 13:06:13 +08:00
### maxZoom
2020-03-15 20:09:16 +08:00
图层显示最大缩放等级 0-18   {number}  Mapbox 0-24 高德 3-18
### autoFit
layer 初始化完成之后,是否自动缩放到图层范围 {bool } default false
2019-11-21 13:06:13 +08:00
### blend
图层元素混合效果
- normal 正常效果 默认
- additive 叠加模式
- subtractive 相减模式
- max 最大值
2019-12-18 14:32:11 +08:00
# 方法
2019-11-21 13:06:13 +08:00
### source
2019-12-02 15:16:45 +08:00
数据源为 layer 设置数据 source(data,config)
2019-11-21 13:06:13 +08:00
2019-12-02 15:16:45 +08:00
- data {geojson|json|csv}
2019-11-21 13:06:13 +08:00
2019-12-02 15:16:45 +08:00
源数据
2019-11-21 13:06:13 +08:00
2019-12-02 15:16:45 +08:00
- config   可选   数据源配置项
- parser 数据解析,默认是解析层 geojson
2019-11-21 13:06:13 +08:00
- transforms [transformtransform ]  数据处理转换 可设置多个
2020-03-08 14:48:52 +08:00
parser 和  transforms [见 source 文档](../source/source)
2019-11-21 13:06:13 +08:00
```javascript
layer.source(data, {
2019-12-02 15:16:45 +08:00
parser: {
type: 'csv',
x: 'lng',
y: 'lat',
},
transforms: [
{
type: 'map',
callback: function(item) {
const [x, y] = item.coordinates;
item.lat = item.lat * 1;
item.lng = item.lng * 1;
item.v = item.v * 1;
item.coordinates = [x * 1, y * 1];
return item;
2019-11-21 13:06:13 +08:00
},
2019-12-02 15:16:45 +08:00
},
{
type: 'hexagon',
size: 6000,
field: 'v',
method: 'sum',
},
],
});
2019-11-21 13:06:13 +08:00
```
### scale
2020-03-09 01:04:27 +08:00
设置数据字段映射方法
2019-11-21 13:06:13 +08:00
- `field` 字段名。
- `scaleConfig` 列定义配置,对象类型,可配置的属性如下:
2020-03-09 01:04:27 +08:00
#### scale 类型
**连续型**
- linear 线性
- log
- pow 指数型
**连续分类型**
- quantile 等分位
- quantize 等间距
**枚举型**
- cat 枚举
2019-11-21 13:06:13 +08:00
```javascript
layer.scale('name', {
type: 'cat',
});
2020-03-09 01:04:27 +08:00
// 设置多个scale
// 字段名为 key, value 为scale配置项
2020-03-09 01:04:27 +08:00
layer.scale({
name: {
type: 'cat',
2020-03-09 01:04:27 +08:00
},
value: {
type: 'linear',
},
});
2019-11-21 13:06:13 +08:00
```
2019-12-18 14:32:11 +08:00
## 视觉编码方法
2019-11-21 13:06:13 +08:00
可视化编码是将数据转换为可视形式的过程L7 目前支持形状,大小,颜色 3 种视觉通道,你可以指定数据字段,为不同要素设置不同的图形属性。
2019-11-21 13:06:13 +08:00
2019-12-18 14:32:11 +08:00
### size
2019-11-21 13:06:13 +08:00
2019-12-18 14:32:11 +08:00
将数据值映射到图形的大小上的方法,具体 size 的表示具体意义可以查看对应图层的文档
2019-11-21 13:06:13 +08:00
2020-03-09 01:04:27 +08:00
```javascript
2019-11-21 13:06:13 +08:00
pointLayer.size(10); // 常量
pointLayer.size('type'); // 使用字段映射到大小
2019-12-02 15:16:45 +08:00
pointLayer.size('type', [0, 10]); // 使用字段映射到大小,并指定最大值和最小值
pointLayer.size('type', (type) => {
// 回调函数
if (type === 'a') {
2019-11-21 13:06:13 +08:00
return 10;
}
return 5;
});
```
#### size(value
2019-12-02 15:16:45 +08:00
传入数字常量,如  `pointLayer.size(20)`
2019-11-21 13:06:13 +08:00
#### size(field)
2019-12-02 15:16:45 +08:00
根据 field 字段的值映射大小,使用默认的`最大值 max:10`  和`最小值 min: 1`。
2019-11-21 13:06:13 +08:00
#### size(field, callback)
2019-12-02 15:16:45 +08:00
2019-11-21 13:06:13 +08:00
使用回调函数控制图形大小。
- `callback`: function 回调函数。
```javascript
pointLayer.size('age', (value) => {
2019-12-02 15:16:45 +08:00
if (value === 1) {
2019-11-21 13:06:13 +08:00
return 5;
}
return 10;
});
```
### color
将数据值映射到图形的颜色上的方法。
```javascript
layer.color('red'); // 常量颜色
layer.color('type'); // 对 type 字段进行映射,使用内置的颜色
2019-12-02 15:16:45 +08:00
layer.color('type', ['red', 'blue']); // 指定颜色
layer.color('type', (type) => {
// 通过回调函数
2019-11-21 13:06:13 +08:00
if (type === 'a') {
return 'red';
}
return 'blue';
});
2019-12-02 15:16:45 +08:00
layer.color('type*value', (type, value) => {
//多个参数,通过回调函数
2019-11-21 13:06:13 +08:00
if (type === 'a' && value > 100) {
return 'red';
}
return 'blue';
});
```
#### color(value)
参数:`value` string
只支持接收一个参数value 可以是:
- 映射至颜色属性的数据源字段名,如果数据源中不存在这个字段名的话,则按照常量进行解析,这个时候会使用 L7 默认提供的颜色。
- 也可以直接指定某一个具体的颜色值 color如 '#fff', 'white','rgba(255,0,0,0.5)' ,rgb(255,0,1) 等。
示例
2019-12-02 15:16:45 +08:00
2019-11-21 13:06:13 +08:00
```javascript
2019-12-02 15:16:45 +08:00
layer.color('name'); // 映射数据字段
layer.color('white'); // 指定颜色
2019-11-21 13:06:13 +08:00
```
#### color(field, colors)
参数:
- `field`: stringfield 为映射至颜色属性的数据源字段名,也支持指定多个参数。
2019-12-02 15:16:45 +08:00
- `colors`: string | array | function
2019-11-21 13:06:13 +08:00
2020-03-30 20:54:28 +08:00
colors 的参数有以下情况:  如果为空,即未指定颜色的数组,那么使用内置的全局的颜色;如果需要指定颜色,则需要以数组格式传入,那么分类的颜色按照数组中的颜色确定。
2019-11-21 13:06:13 +08:00
```javascript
layer.color('name'); // 使用默认的颜色
2019-12-02 15:16:45 +08:00
layer.color('name', ['red', 'blue']); // 使用传入的指定颜色
2019-11-21 13:06:13 +08:00
```
- colors 如果是回调函数,则该回调函数的参数为对应字段的数值,具体使用如下,当 color 映射为多个字段时,参数按照字段声明的顺序传入:
```javascript
layer.color('gender', (value) => {
2019-12-02 15:16:45 +08:00
if (value === 1) {
return 'red';
2019-11-21 13:06:13 +08:00
}
return 'blue';
});
layer.color('gender*age', (gender, age) => {
2019-12-02 15:16:45 +08:00
if (age === 20 && gender == ' 男') {
return 'red';
2019-11-21 13:06:13 +08:00
}
return 'blue';
});
```
### shape
2019-12-02 15:16:45 +08:00
2019-11-21 13:06:13 +08:00
将数据值映射到图形的形状上的方法。
**shape(shape)**
参数`shape` string
只支持接收一个参数,指定几何图像对象绘制的形状。下表列出了不同的 图层 几何图形对象支持的 shape 形状
2019-12-02 15:16:45 +08:00
| layer 类型 | shape 类型 | 备注 |
| ---------- | -------------------------------------------------------------------------------------- | ---- |
| point | 2d:point,circle, square, triangle,hexagon,image,text 3d:circle,triangle,hexagon,square | |
| line | line,arc, arc3d, greatcircle | |
| polygon | fill,line, extrude | |
2019-11-21 13:06:13 +08:00
**shape(field, shapes)**
**shape(field, callback)**
### style
2019-12-18 14:32:11 +08:00
全局设置图形显示属性
2019-11-21 13:06:13 +08:00
2019-12-02 15:16:45 +08:00
- opacity   设置透明度
2019-11-21 13:06:13 +08:00
2019-12-18 14:32:11 +08:00
- stroke 线填充颜色 仅点图层支持
2019-11-21 13:06:13 +08:00
2019-12-18 14:32:11 +08:00
- strokeWidth 线的宽度 仅点图层支持
2019-11-21 13:06:13 +08:00
```javascript
layer.style({
2019-12-02 15:16:45 +08:00
opacity: 0.8,
stroke: 'white',
});
2019-11-21 13:06:13 +08:00
```
2019-12-18 14:32:11 +08:00
## 图层更新方法
如果已经添加了图层,需要修改图层显示样式可以再次调用图形映射方法,然后调用 `scene.render()`更新渲染即可
### 样式更新
```javascript
layer.color('blue');
layer.size(10);
layer.style({});
scene.render();
```
### setData
更新 Source 数据
参数:
- data 数据
- option 默认和初始配置项一致,如果数据格式相同可不设置
调用 setData 方法会自动更新图层渲染
```javascript
layer.setData(data);
```
### setBlend(type)
设置图层叠加方法
参数:
- type blend 类型
2019-12-18 14:32:11 +08:00
## 图层控制方法
2019-11-21 13:06:13 +08:00
### show
2019-12-02 15:16:45 +08:00
2019-11-21 13:06:13 +08:00
图层显示
```javascript
layer.show();
```
### hide
图层隐藏
```javascript
layer.hide();
```
### isVisible
2019-12-18 14:32:11 +08:00
图层是否可见
return `true | false`
### setIndex
设置图层绘制顺序
2019-11-21 13:06:13 +08:00
### fitBounds
缩放到图层范围
```javascript
2019-12-02 15:16:45 +08:00
layer.fitBounds();
2019-11-28 17:49:04 +08:00
```
2019-12-18 14:32:11 +08:00
### setMinZoom
2020-02-08 01:51:17 +08:00
设置图层最小缩放等级
参数
- zoom {number}
```javascript
layer.setMinZoom(zoom);
```
2019-12-18 14:32:11 +08:00
### setMaxZoom
2020-02-08 01:51:17 +08:00
设置图层最大缩放等级
2020-02-08 20:09:14 +08:00
参数
- zoom {number}
```javascript
layer.setMinZoom(zoom);
```
2020-02-08 01:51:17 +08:00
设置图层最大缩放等级
2020-02-08 01:51:17 +08:00
参数
- zoom {number}
```javascript
layer.setMinZoom(zoom);
```
2019-12-18 14:32:11 +08:00
## 图层交互方法
### active
开启或者关闭 mousehover 元素高亮效果
2020-01-16 12:02:06 +08:00
参数: activeOption | boolean
activeOption
-color 填充颜色
```javascript
// 开启 Active 使用默认高亮颜色
layer.active(true);
// 开启 Active 自定义高亮颜色
layer.active({
color: 'red',
});
// 关闭高亮效果
layer.active(false);
```
2019-12-18 14:32:11 +08:00
### setActive
根据元素 ID 设置指定元素 hover 高亮
2020-01-16 12:02:06 +08:00
```javascript
layer.setActive(id);
```
2019-12-18 14:32:11 +08:00
### select
开启或者关闭 mouseclick 元素选中高亮效果
2020-01-16 12:02:06 +08:00
参数: selectOption | boolean
selectOption
-color 填充颜色
```javascript
// 开启 Active 使用默认高亮颜色
layer.select(true);
// 开启 Active 自定义高亮颜色
layer.select({
color: 'red',
});
// 关闭高亮效果
layer.select(false);
```
2019-12-18 14:32:11 +08:00
### setSelect
根据元素 ID 设置指定元素 click 选中 高亮
2020-01-16 12:02:06 +08:00
```javascript
layer.setSelect(id);
```
2019-12-18 14:32:11 +08:00
## 鼠标事件
鼠标事件回调参数 target
```typescript
```
- x: number 鼠标  在地图位置 x 坐标
- y: number 鼠标  在地图位置 y 坐标
- type: string 鼠标事件类型
- lngLat: 经度度对象 {lng:number, lat: number }; 鼠标所在位置经纬度
2019-12-18 14:32:11 +08:00
- feature: any; 数据选中的地理要素信息
- featureId: number | null; 数据选中的地理要素的 ID
### click
点击事件
### mousemove
鼠标移动事件
### mouseout
鼠标移除
### mouseup
鼠标按下
### mousedown
鼠标向下
### contextmenu
鼠标右键
### unclick
点击未拾取到元素
### unmousemove
鼠标移动未拾取到元素
### unmouseup
鼠标抬起未拾取到元素
### unmousedown
鼠标按下未拾取到元素
### uncontextmenu
鼠标右键位拾取到元素
### unpick
所有鼠标事件未拾取到
使用示例
```javascript
layer.on('click', (ev) => {}); // 鼠标左键点击图层事件
layer.on('mousemove', (ev) => {}); // 鼠标在图层上移动时触发
layer.on('mouseout', (ev) => {}); // 鼠标移出图层要素时触发
layer.on('mouseup', (ev) => {}); // 鼠标在图层上单击抬起时触发
layer.on('mousedown', (ev) => {}); // 鼠标在图层上单击按下时触发
layer.on('contextmenu', (ev) => {}); // 图层要素点击右键菜单
// 鼠标在图层外的事件
layer.on('unclick', (ev) => {}); // 图层外点击
layer.on('unmousemove', (ev) => {}); // 图层外移动
layer.on('unmouseup', (ev) => {}); // 图层外鼠标抬起
layer.on('unmousedown', (ev) => {}); // 图层外单击按下时触发
layer.on('uncontextmenu', (ev) => {}); // 图层外点击右键
layer.on('unpick', (ev) => {}); // 图层外的操作的所有事件
```
## 图层事件
### inited
2020-01-19 20:45:21 +08:00
参数 option
2020-01-19 20:22:30 +08:00
- target 当前 layer
2020-01-19 20:45:21 +08:00
- type 事件类型
图层初始化完成后触发
```javascript
layer.on('inited', (option) => {});
```
2020-01-19 20:22:30 +08:00
### add
2020-01-19 20:45:21 +08:00
图层添加到 scene
2020-01-19 20:22:30 +08:00
参数 option
2020-01-19 20:22:30 +08:00
- target 当前 layer
2020-01-19 20:45:21 +08:00
- type 事件类型
2020-01-19 20:22:30 +08:00
### remove
图层移除时触发
2020-01-19 20:22:30 +08:00
参数 option
2020-01-19 20:45:21 +08:00
- target 当前 layer
2020-01-19 20:45:21 +08:00
- type 事件类型