feat(layer): add blend 效果配置支持 normal,additive

This commit is contained in:
thinkinggis 2019-12-18 21:13:56 +08:00
parent b40f4087b6
commit e0ab4cd386
25 changed files with 247 additions and 54 deletions

View File

@ -24,6 +24,10 @@ new Layer(option)
## 配置项 ## 配置项
### name
设置图层名称,可根据 name 获取 layer;
### visable ### visable
图层是否可见   {bool } default true 图层是否可见   {bool } default true
@ -40,6 +44,15 @@ new Layer(option)
图层显示最大缩放等级 0-18   {number}  default 18 图层显示最大缩放等级 0-18   {number}  default 18
### blend
图层元素混合效果
- normal 正常效果 默认
- additive 叠加模式
- subtractive 相减模式
- max 最大值
# 方法 # 方法
### source ### source
@ -284,6 +297,13 @@ scene.render();
layer.setData(data); layer.setData(data);
``` ```
### setBlend(type)
设置图层叠加方法
参数:
- type blend 类型
## 图层控制方法 ## 图层控制方法
### show ### show
@ -422,3 +442,13 @@ layer.on('unmousedown', (ev) => {}); // 图层外单击按下时触发
layer.on('uncontextmenu', (ev) => {}); // 图层外点击右键 layer.on('uncontextmenu', (ev) => {}); // 图层外点击右键
layer.on('unpick', (ev) => {}); // 图层外的操作的所有事件 layer.on('unpick', (ev) => {}); // 图层外的操作的所有事件
``` ```
## 图层事件
### inited
图层初始化完成后触发
### remove
图层移除时触发

View File

@ -50,6 +50,7 @@ const defaultLayerConfig: Partial<ILayerConfig> = {
visible: true, visible: true,
autoFit: false, autoFit: false,
zIndex: 0, zIndex: 0,
blend: 'normal',
pickedFeatureID: -1, pickedFeatureID: -1,
enableMultiPassRenderer: true, enableMultiPassRenderer: true,
enablePicking: true, enablePicking: true,

View File

@ -3,7 +3,11 @@ import { SyncBailHook, SyncHook, SyncWaterfallHook } from 'tapable';
import Clock from '../../utils/clock'; import Clock from '../../utils/clock';
import { ISceneConfig } from '../config/IConfigService'; import { ISceneConfig } from '../config/IConfigService';
import { IMapService } from '../map/IMapService'; import { IMapService } from '../map/IMapService';
import { IModel, IModelInitializationOptions } from '../renderer/IModel'; import {
IBlendOptions,
IModel,
IModelInitializationOptions,
} from '../renderer/IModel';
import { import {
IMultiPassRenderer, IMultiPassRenderer,
IPass, IPass,
@ -22,6 +26,16 @@ import {
StyleAttributeOption, StyleAttributeOption,
Triangulation, Triangulation,
} from './IStyleAttributeService'; } from './IStyleAttributeService';
export enum BlendType {
normal = 'normal',
additive = 'additive',
subtractive = 'subtractive',
min = 'min',
max = 'max',
}
export interface IBlendTypes {
[key: string]: Partial<IBlendOptions>;
}
export interface IDataState { export interface IDataState {
dataSourceNeedUpdate: boolean; dataSourceNeedUpdate: boolean;
dataMappingNeedUpdate: boolean; dataMappingNeedUpdate: boolean;
@ -38,6 +52,7 @@ export interface ILayerModelInitializationOptions {
export interface ILayerModel { export interface ILayerModel {
render(): void; render(): void;
getUninforms(): IModelUniform; getUninforms(): IModelUniform;
getBlend(): IBlendOptions;
buildModels(): IModel[]; buildModels(): IModel[];
} }
export interface IModelUniform { export interface IModelUniform {
@ -57,7 +72,8 @@ export interface IActiveOption {
export interface ILayer { export interface ILayer {
id: string; // 一个场景中同一类型 Layer 可能存在多个 id: string; // 一个场景中同一类型 Layer 可能存在多个
name: string; // 代表 Layer 的类型 type: string; // 代表 Layer 的类型
name: string; //
inited: boolean; // 是否初始化完成 inited: boolean; // 是否初始化完成
zIndex: number; zIndex: number;
plugins: ILayerPlugin[]; plugins: ILayerPlugin[];
@ -120,6 +136,7 @@ export interface ILayer {
isVisible(): boolean; isVisible(): boolean;
setMaxZoom(min: number): ILayer; setMaxZoom(min: number): ILayer;
setMinZoom(max: number): ILayer; setMinZoom(max: number): ILayer;
setBlend(type: keyof typeof BlendType): void;
// animate(field: string, option: any): ILayer; // animate(field: string, option: any): ILayer;
render(): ILayer; render(): ILayer;
destroy(): void; destroy(): void;
@ -190,6 +207,8 @@ export interface ILayerConfig {
visible: boolean; visible: boolean;
zIndex: number; zIndex: number;
autoFit: boolean; autoFit: boolean;
name: string; //
blend: keyof typeof BlendType;
pickedFeatureID: number; pickedFeatureID: number;
enableMultiPassRenderer: boolean; enableMultiPassRenderer: boolean;
passes: Array<string | [string, { [key: string]: unknown }]>; passes: Array<string | [string, { [key: string]: unknown }]>;

View File

@ -38,8 +38,8 @@ export default class LayerService implements ILayerService {
return this.layers; return this.layers;
} }
public getLayer(id: string): ILayer | undefined { public getLayer(name: string): ILayer | undefined {
return this.layers.find((layer) => layer.id === id); return this.layers.find((layer) => layer.name === name);
} }
public remove(layer: ILayer): void { public remove(layer: ILayer): void {
@ -47,6 +47,7 @@ export default class LayerService implements ILayerService {
if (layerIndex > -1) { if (layerIndex > -1) {
this.layers.splice(layerIndex, 1); this.layers.splice(layerIndex, 1);
} }
layer.emit('remove', null);
layer.destroy(); layer.destroy();
this.renderLayers(); this.renderLayers();
} }

View File

@ -4,7 +4,7 @@ import { ILogService } from './ILogService';
const Logger = new Log({ id: 'L7' }).enable(true); const Logger = new Log({ id: 'L7' }).enable(true);
// // 只输出 debug 级别以上的日志信息 // // 只输出 debug 级别以上的日志信息
Logger.priority = 4; Logger.priority = 5;
@injectable() @injectable()
export default class LogService implements ILogService { export default class LogService implements ILogService {

View File

@ -3,6 +3,30 @@ import { IAttribute } from './IAttribute';
import { IElements } from './IElements'; import { IElements } from './IElements';
import { IUniform } from './IUniform'; import { IUniform } from './IUniform';
export interface IBlendOptions {
// gl.enable(gl.BLEND)
enable: boolean;
// gl.blendFunc
func: BlendingFunctionSeparate;
// gl.blendEquation
equation: {
// TODO: EXT_blend_minmax
rgb:
| gl.FUNC_ADD
| gl.FUNC_SUBTRACT
| gl.FUNC_REVERSE_SUBTRACT
| gl.MIN_EXT
| gl.MAX_EXT;
alpha?:
| gl.FUNC_ADD
| gl.FUNC_SUBTRACT
| gl.FUNC_REVERSE_SUBTRACT
| gl.MIN_EXT
| gl.MAX_EXT;
};
// gl.blendColor
color: [number, number, number, number];
}
type stencilOp = type stencilOp =
| gl.ZERO | gl.ZERO
| gl.KEEP | gl.KEEP
@ -153,20 +177,7 @@ export interface IModelInitializationOptions {
/** /**
* blending * blending
*/ */
blend?: Partial<{ blend?: Partial<IBlendOptions>;
// gl.enable(gl.BLEND)
enable: boolean;
// gl.blendFunc
func: BlendingFunctionSeparate;
// gl.blendEquation
equation: {
// TODO: EXT_blend_minmax
rgb: gl.FUNC_ADD | gl.FUNC_SUBTRACT | gl.FUNC_REVERSE_SUBTRACT;
alpha: gl.FUNC_ADD | gl.FUNC_SUBTRACT | gl.FUNC_REVERSE_SUBTRACT;
};
// gl.blendColor
color: [number, number, number, number];
}>;
/** /**
* stencil * stencil
@ -221,6 +232,8 @@ export interface IModelDrawOptions {
[key: string]: IAttribute; [key: string]: IAttribute;
}; };
elements?: IElements; elements?: IElements;
blend?: IBlendOptions;
} }
/** /**

View File

@ -60,6 +60,10 @@ export enum gl {
FUNC_SUBTRACT = 0x800a, FUNC_SUBTRACT = 0x800a,
FUNC_REVERSE_SUBTRACT = 0x800b, FUNC_REVERSE_SUBTRACT = 0x800b,
/** Blend Min Max */
MAX_EXT = 0x8008,
MIN_EXT = 0x8007,
/* Separate Blend Functions */ /* Separate Blend Functions */
BLEND_DST_RGB = 0x80c8, BLEND_DST_RGB = 0x80c8,
BLEND_SRC_RGB = 0x80c9, BLEND_SRC_RGB = 0x80c9,

View File

@ -1,4 +1,5 @@
import { import {
BlendType,
gl, gl,
IActiveOption, IActiveOption,
IAnimateOption, IAnimateOption,
@ -37,7 +38,6 @@ import {
TYPES, TYPES,
} from '@antv/l7-core'; } from '@antv/l7-core';
import Source from '@antv/l7-source'; import Source from '@antv/l7-source';
import { bindAll } from '@antv/l7-utils';
import { EventEmitter } from 'eventemitter3'; import { EventEmitter } from 'eventemitter3';
import { Container } from 'inversify'; import { Container } from 'inversify';
import { isFunction, isObject } from 'lodash'; import { isFunction, isObject } from 'lodash';
@ -45,6 +45,7 @@ import { isFunction, isObject } from 'lodash';
import mergeJsonSchemas from 'merge-json-schemas'; import mergeJsonSchemas from 'merge-json-schemas';
import { SyncBailHook, SyncHook, SyncWaterfallHook } from 'tapable'; import { SyncBailHook, SyncHook, SyncWaterfallHook } from 'tapable';
import { normalizePasses } from '../plugins/MultiPassRendererPlugin'; import { normalizePasses } from '../plugins/MultiPassRendererPlugin';
import { BlendTypes } from '../utils/blend';
import baseLayerSchema from './schema'; import baseLayerSchema from './schema';
/** /**
* layer id * layer id
@ -55,6 +56,7 @@ export default class BaseLayer<ChildLayerStyleOptions = {}> extends EventEmitter
implements ILayer { implements ILayer {
public id: string = `${layerIdCounter++}`; public id: string = `${layerIdCounter++}`;
public name: string; public name: string;
public type: string;
public visible: boolean = true; public visible: boolean = true;
public zIndex: number = 0; public zIndex: number = 0;
public minZoom: number; public minZoom: number;
@ -165,6 +167,7 @@ export default class BaseLayer<ChildLayerStyleOptions = {}> extends EventEmitter
constructor(config: Partial<ILayerConfig & ChildLayerStyleOptions> = {}) { constructor(config: Partial<ILayerConfig & ChildLayerStyleOptions> = {}) {
super(); super();
this.name = config.name || this.id;
this.rawConfig = config; this.rawConfig = config;
} }
@ -299,6 +302,7 @@ export default class BaseLayer<ChildLayerStyleOptions = {}> extends EventEmitter
this.buildModels(); this.buildModels();
// 触发初始化完成事件; // 触发初始化完成事件;
this.emit('inited'); this.emit('inited');
this.emit('added');
return this; return this;
} }
@ -514,10 +518,18 @@ export default class BaseLayer<ChildLayerStyleOptions = {}> extends EventEmitter
this.interactionService.triggerSelect(id); this.interactionService.triggerSelect(id);
} }
} }
public setBlend(type: keyof typeof BlendType): void {
this.updateLayerConfig({
blend: type,
});
this.layerModelNeedUpdate = true;
this.render();
}
public show(): ILayer { public show(): ILayer {
this.updateLayerConfig({ this.updateLayerConfig({
visible: true, visible: true,
}); });
return this; return this;
} }
@ -685,15 +697,7 @@ export default class BaseLayer<ChildLayerStyleOptions = {}> extends EventEmitter
fs, fs,
vs, vs,
elements, elements,
blend: { blend: BlendTypes[BlendType.normal],
enable: true,
func: {
srcRGB: gl.SRC_ALPHA,
srcAlpha: 1,
dstRGB: gl.ONE_MINUS_SRC_ALPHA,
dstAlpha: 1,
},
},
...rest, ...rest,
}); });
} }

View File

@ -1,5 +1,7 @@
import { import {
BlendType,
IAttribute, IAttribute,
IBlendOptions,
ICameraService, ICameraService,
IElements, IElements,
IFontService, IFontService,
@ -17,7 +19,7 @@ import {
Triangulation, Triangulation,
TYPES, TYPES,
} from '@antv/l7-core'; } from '@antv/l7-core';
import { BlendTypes } from '../utils/blend';
export default class BaseModel implements ILayerModel { export default class BaseModel implements ILayerModel {
public triangulation: Triangulation; public triangulation: Triangulation;
@ -54,7 +56,10 @@ export default class BaseModel implements ILayerModel {
.get<ICameraService>(TYPES.ICameraService); .get<ICameraService>(TYPES.ICameraService);
this.registerBuiltinAttributes(); this.registerBuiltinAttributes();
} }
public getBlend(): IBlendOptions {
const { blend = 'normal' } = this.layer.getLayerConfig();
return BlendTypes[BlendType[blend]] as IBlendOptions;
}
public getUninforms(): IModelUniform { public getUninforms(): IModelUniform {
throw new Error('Method not implemented.'); throw new Error('Method not implemented.');
} }

View File

@ -5,7 +5,7 @@ interface IPointLayerStyleOptions {
opacity: number; opacity: number;
} }
export default class HeatMapLayer extends BaseLayer<IPointLayerStyleOptions> { export default class HeatMapLayer extends BaseLayer<IPointLayerStyleOptions> {
public name: string = 'HeatMapLayer'; public type: string = 'HeatMapLayer';
protected getConfigSchema() { protected getConfigSchema() {
return { return {
properties: { properties: {

View File

@ -10,7 +10,7 @@ interface IDashLineLayerStyleOptions {
export default class DashLineLayer extends BaseLayer< export default class DashLineLayer extends BaseLayer<
IDashLineLayerStyleOptions IDashLineLayerStyleOptions
> { > {
public name: string = 'LineLayer'; public type: string = 'LineLayer';
protected getConfigSchema() { protected getConfigSchema() {
return { return {

View File

@ -4,7 +4,7 @@ interface IPointLayerStyleOptions {
opacity: number; opacity: number;
} }
export default class LineLayer extends BaseLayer<IPointLayerStyleOptions> { export default class LineLayer extends BaseLayer<IPointLayerStyleOptions> {
public name: string = 'LineLayer'; public type: string = 'LineLayer';
private animateStartTime: number = 0; private animateStartTime: number = 0;

View File

@ -7,7 +7,7 @@ interface IPointLayerStyleOptions {
strokeColor: string; strokeColor: string;
} }
export default class PointLayer extends BaseLayer<IPointLayerStyleOptions> { export default class PointLayer extends BaseLayer<IPointLayerStyleOptions> {
public name: string = 'PointLayer'; public type: string = 'PointLayer';
protected getConfigSchema() { protected getConfigSchema() {
return { return {
properties: { properties: {

View File

@ -1,5 +1,6 @@
import { import {
AttributeType, AttributeType,
BlendType,
gl, gl,
IEncodeFeature, IEncodeFeature,
IModel, IModel,
@ -8,9 +9,9 @@ import {
import { rgb2arr } from '@antv/l7-utils'; import { rgb2arr } from '@antv/l7-utils';
import BaseModel from '../../core/BaseModel'; import BaseModel from '../../core/BaseModel';
import { BlendTypes } from '../../utils/blend';
import normalFrag from '../shaders/normal_frag.glsl'; import normalFrag from '../shaders/normal_frag.glsl';
import normalVert from '../shaders/normal_vert.glsl'; import normalVert from '../shaders/normal_vert.glsl';
interface IPointLayerStyleOptions { interface IPointLayerStyleOptions {
opacity: number; opacity: number;
strokeWidth: number; strokeWidth: number;
@ -38,7 +39,6 @@ export default class NormalModel extends BaseModel {
u_stroke_color: rgb2arr(strokeColor), u_stroke_color: rgb2arr(strokeColor),
}; };
} }
public buildModels(): IModel[] { public buildModels(): IModel[] {
return [ return [
this.layer.buildLayerModel({ this.layer.buildLayerModel({
@ -48,15 +48,7 @@ export default class NormalModel extends BaseModel {
triangulation: PointTriangulation, triangulation: PointTriangulation,
depth: { enable: false }, depth: { enable: false },
primitive: gl.POINTS, primitive: gl.POINTS,
blend: { blend: this.getBlend(),
enable: true,
func: {
srcRGB: gl.ONE,
srcAlpha: 1,
dstRGB: gl.ONE,
dstAlpha: 1,
},
},
}), }),
]; ];
} }

View File

@ -26,7 +26,7 @@ export function PointTriangulation(feature: IEncodeFeature) {
}; };
} }
export default class TextLayer extends BaseLayer<IPointTextLayerStyleOptions> { export default class TextLayer extends BaseLayer<IPointTextLayerStyleOptions> {
public name: string = 'PointLayer'; public type: string = 'PointLayer';
protected getConfigSchema() { protected getConfigSchema() {
return { return {

View File

@ -7,7 +7,7 @@ interface IPolygonLayerStyleOptions {
} }
export default class PolygonLayer extends BaseLayer<IPolygonLayerStyleOptions> { export default class PolygonLayer extends BaseLayer<IPolygonLayerStyleOptions> {
public name: string = 'PolygonLayer'; public type: string = 'PolygonLayer';
protected getConfigSchema() { protected getConfigSchema() {
return { return {

View File

@ -14,7 +14,7 @@ interface IPointLayerStyleOptions {
} }
export default class ImageLayer extends BaseLayer<IPointLayerStyleOptions> { export default class ImageLayer extends BaseLayer<IPointLayerStyleOptions> {
public name: string = 'ImageLayer'; public type: string = 'ImageLayer';
protected texture: ITexture2D; protected texture: ITexture2D;
protected getConfigSchema() { protected getConfigSchema() {

View File

@ -26,7 +26,7 @@ interface IRasterLayerStyleOptions {
} }
export default class RasterLayer extends BaseLayer<IRasterLayerStyleOptions> { export default class RasterLayer extends BaseLayer<IRasterLayerStyleOptions> {
public name: string = 'e'; public type: string = 'RasterLayer';
protected texture: ITexture2D; protected texture: ITexture2D;
protected colorTexture: ITexture2D; protected colorTexture: ITexture2D;

View File

@ -12,7 +12,7 @@ interface IRasterLayerStyleOptions {
} }
export default class Raster2dLayer extends BaseLayer<IRasterLayerStyleOptions> { export default class Raster2dLayer extends BaseLayer<IRasterLayerStyleOptions> {
public name: string = 'RasterLayer'; public type: string = 'RasterLayer';
protected texture: ITexture2D; protected texture: ITexture2D;
protected colorTexture: ITexture2D; protected colorTexture: ITexture2D;

View File

@ -0,0 +1,54 @@
import { BlendType, gl, IBlendOptions, IBlendTypes } from '@antv/l7-core';
export const BlendTypes: IBlendTypes = {
[BlendType.additive]: {
enable: true,
func: {
srcRGB: gl.ONE,
dstRGB: gl.ONE,
srcAlpha: 1,
dstAlpha: 1,
},
},
[BlendType.normal]: {
enable: true,
func: {
srcRGB: gl.SRC_ALPHA,
dstRGB: gl.ONE_MINUS_SRC_ALPHA,
srcAlpha: 1,
dstAlpha: 1,
},
},
[BlendType.subtractive]: {
enable: true,
func: {
srcRGB: gl.ONE,
dstRGB: gl.ONE,
srcAlpha: gl.ZERO,
dstAlpha: gl.ONE_MINUS_SRC_COLOR,
},
equation: {
rgb: gl.FUNC_SUBTRACT,
alpha: gl.FUNC_SUBTRACT,
},
},
[BlendType.max]: {
enable: true,
func: {
srcRGB: gl.ONE,
dstRGB: gl.ONE,
},
equation: {
rgb: gl.MAX_EXT,
},
},
[BlendType.min]: {
enable: true,
func: {
srcRGB: gl.ONE,
dstRGB: gl.ONE,
},
equation: {
rgb: gl.MIN_EXT,
},
},
};

View File

@ -204,7 +204,7 @@ export default class MapboxService
*/ */
// 判断全局 mapboxgl 对象的加载 // 判断全局 mapboxgl 对象的加载
if (!('mapInstance' in this.config) && !mapboxgl) { if (!mapInstance && !mapboxgl) {
// 用户有时传递进来的实例是继承于 mapbox 实例化的,不一定是 mapboxgl 对象。 // 用户有时传递进来的实例是继承于 mapbox 实例化的,不一定是 mapboxgl 对象。
this.logger.error(this.configService.getSceneWarninfo('SDK')); this.logger.error(this.configService.getSceneWarninfo('SDK'));
} }
@ -213,13 +213,13 @@ export default class MapboxService
token === MAPBOX_API_KEY && token === MAPBOX_API_KEY &&
style !== 'blank' && style !== 'blank' &&
!mapboxgl.accessToken && !mapboxgl.accessToken &&
!('mapInstance' in this.config) // 如果用户传递了 mapInstance应该不去干预实例的 accessToken。 !mapInstance // 如果用户传递了 mapInstance应该不去干预实例的 accessToken。
) { ) {
this.logger.warn(this.configService.getSceneWarninfo('MapToken')); this.logger.warn(this.configService.getSceneWarninfo('MapToken'));
} }
// 判断是否设置了 accessToken // 判断是否设置了 accessToken
if ('mapInstance' in this.config && !mapboxgl.accessToken) { if (!mapInstance && !mapboxgl.accessToken) {
// 用户有时传递进来的实例是继承于 mapbox 实例化的,不一定是 mapboxgl 对象。 // 用户有时传递进来的实例是继承于 mapbox 实例化的,不一定是 mapboxgl 对象。
mapboxgl.accessToken = token; mapboxgl.accessToken = token;
} }

View File

@ -141,6 +141,8 @@ export const blendEquationMap: {
[key: string]: regl.BlendingEquation; [key: string]: regl.BlendingEquation;
} = { } = {
[gl.FUNC_ADD]: 'add', [gl.FUNC_ADD]: 'add',
[gl.MIN_EXT]: 'min',
[gl.MAX_EXT]: 'max',
[gl.FUNC_SUBTRACT]: 'subtract', [gl.FUNC_SUBTRACT]: 'subtract',
[gl.FUNC_REVERSE_SUBTRACT]: 'reverse subtract', [gl.FUNC_REVERSE_SUBTRACT]: 'reverse subtract',
}; };

View File

@ -53,6 +53,7 @@ export default class ReglRendererService implements IRendererService {
extensions: [ extensions: [
'OES_element_index_uint', 'OES_element_index_uint',
// 'EXT_shader_texture_lod', // IBL 兼容性问题 // 'EXT_shader_texture_lod', // IBL 兼容性问题
'EXT_blend_minmax',
'OES_standard_derivatives', // wireframe 'OES_standard_derivatives', // wireframe
// 'OES_texture_float', // shadow map 兼容性问题 // 'OES_texture_float', // shadow map 兼容性问题
'WEBGL_depth_texture', 'WEBGL_depth_texture',

View File

@ -5,6 +5,7 @@ import ArcLineDemo from './components/Arcline';
import Column from './components/column'; import Column from './components/column';
import DataUpdate from './components/data_update'; import DataUpdate from './components/data_update';
import HeatMapDemo from './components/HeatMap'; import HeatMapDemo from './components/HeatMap';
import LightDemo from './components/light';
import LineLayer from './components/Line'; import LineLayer from './components/Line';
import PointDemo from './components/Point'; import PointDemo from './components/Point';
import Point3D from './components/Point3D'; import Point3D from './components/Point3D';
@ -17,6 +18,7 @@ import RasterLayerDemo from './components/RasterLayer';
storiesOf('图层', module) storiesOf('图层', module)
.add('点图层', () => <PointDemo />) .add('点图层', () => <PointDemo />)
.add('数据更新', () => <DataUpdate />) .add('数据更新', () => <DataUpdate />)
.add('亮度图', () => <LightDemo />)
.add('3D点', () => <Point3D />) .add('3D点', () => <Point3D />)
.add('Column', () => <Column />) .add('Column', () => <Column />)
.add('图片标注', () => <PointImage />) .add('图片标注', () => <PointImage />)

View File

@ -0,0 +1,65 @@
import { PointLayer, Scene } from '@antv/l7';
import { GaodeMap, Mapbox } from '@antv/l7-maps';
import * as React from 'react';
// @ts-ignore
export default class Light extends React.Component {
// @ts-ignore
private scene: Scene;
public componentWillUnmount() {
this.scene.destroy();
}
public async componentDidMount() {
const response = await fetch(
'https://alipay-rmsdeploy-image.cn-hangzhou.alipay.aliyun-inc.com/antvdemo/assets/city/bj.csv',
);
const pointsData = await response.text();
const scene = new Scene({
id: 'map',
map: new Mapbox({
pitch: 0,
style: 'dark',
center: [116.405289, 39.904987],
zoom: 6,
}),
});
this.scene = scene;
scene.on('loaded', async () => {
const pointLayer = new PointLayer({
blend: 'min',
})
.source(pointsData, {
parser: {
type: 'csv',
x: 'lng',
y: 'lat',
},
})
.size(2)
.color('#FFFECC')
.style({
opacity: 1,
});
scene.addLayer(pointLayer);
this.scene = scene;
});
}
public render() {
return (
<div
id="map"
style={{
position: 'absolute',
top: 0,
left: 0,
right: 0,
bottom: 0,
}}
/>
);
}
}