// @ts-ignore import { Scene } from '@antv/l7'; import { PolygonLayer, PointLayer } from '@antv/l7-layers'; import { Map } from '@antv/l7-maps'; import * as React from 'react'; export default class ScaleComponent extends React.Component { private scene: Scene; private el: HTMLCanvasElement; public componentWillUnmount() { this.scene.destroy(); } public setCanvas() { this.el.width = 400; this.el.height = 300; this.el.style.width = '300px'; this.el.style.height = '150px'; this.el.style.zIndex = '10'; this.el.style.position = 'absolute'; this.el.style.top = '0'; this.el.style.left = '0'; this.el.style.border = '1px solid'; } public async componentDidMount() { this.setCanvas(); const scene = new Scene({ id: 'map', // canvas: this.el, map: new Map({ hash: true, center: [110.19382669582967, 30.258134], pitch: 0, zoom: 2, }), }); scene.addImage( '00', 'https://gw.alipayobjects.com/zos/basement_prod/604b5e7f-309e-40db-b95b-4fac746c5153.svg', ); let imageLayer = new PointLayer({ blend: 'normal', zIndex: 2, }) .source( [ { id: '5011000000404', name: '铁路新村(华池路)', longitude: 121.4216962, latitude: 31.26082325, unit_price: 71469.4, count: 2, }, ], { parser: { type: 'json', x: 'longitude', y: 'latitude', }, }, ) .shape('name', ['00']) .size(20); fetch( 'https://gw.alipayobjects.com/os/basement_prod/d2e0e930-fd44-4fca-8872-c1037b0fee7b.json', ) .then((res) => res.json()) .then((data) => { const textLayer = new PointLayer({}) .source( [ { lng: 120.5, lat: 31.3, iconType: 'cloud', iconColor: '#F0F8FF', weather: '多云 - 今日适宜出门', textOffset: [-40, 0], }, ], { parser: { type: 'json', x: 'lng', y: 'lat', }, }, ) .shape('weather', 'text') .size(16) .color('#f00') .style({ textAnchor: 'center', // 文本相对锚点的位置 center|left|right|top|bottom|top-left textOffset: [0, 0], // 文本相对锚点的偏移量 [水平, 垂直] spacing: 2, // 字符间距 padding: [1, 1], // 文本包围盒 padding [水平,垂直],影响碰撞检测结果,避免相邻文本靠的太近 fontFamily: 'Times New Roman', textAllowOverlap: true, }); scene.addLayer(textLayer); const layer = new PolygonLayer({ name: '01', }); layer .source(data) .size('name', [0, 10000, 50000, 30000, 100000]) .color('name', [ '#2E8AE6', '#69D1AB', '#DAF291', '#FFD591', '#FF7A45', '#CF1D49', ]) .shape('fill') .select(true) .style({ opacity: 1.0, }); scene.addLayer(layer); }); scene.on('loaded', () => { scene.addLayer(imageLayer); }); } public render() { return (
(this.el = el as HTMLCanvasElement)}>
); } }