import { PointLayer, Scene, PolygonLayer, LineLayer } from '@antv/l7'; import { GaodeMap } from '@antv/l7-maps'; import * as React from 'react'; export default class Amap2demo_mesh2 extends React.Component { // @ts-ignore private scene: Scene; public componentWillUnmount() { this.scene.destroy(); } public async componentDidMount() { const scene = new Scene({ id: 'map', map: new GaodeMap({ style: 'dark', pitch: 40, center: [118.8, 32.056], zoom: 12.5, }), }); this.scene = scene; let fontFamily = 'iconfont'; let fontPath = '//at.alicdn.com/t/font_2534097_bl34aphh10n.woff2?t=1622180820063'; scene.addIconFont('up', ''); scene.addIconFont('down', ''); scene.addFontFace(fontFamily, fontPath); scene.on('loaded', () => { fetch( 'https://gw.alipayobjects.com/os/bmw-prod/41802695-0f7e-4a81-ab16-539c4e39df0d.json', ) .then((res) => res.json()) .then((data) => { const filllayer = new PolygonLayer({ name: 'fill', zIndex: 3, }) .source(data) .shape('fill') .color('count', ['rgb(194, 143, 133)', 'rgb(148, 167, 192)']) .style({ opacity: 0.5, }); scene.addLayer(filllayer); const linelayer = new LineLayer({ zIndex: 5, name: 'line2', }) .source(data) .shape('line') .size(1) .color('#fff') .style({ opacity: 0.3, }); scene.addLayer(linelayer); const pointLayer = new PointLayer({ zIndex: 10, }) .source(data) .shape('icon', 'text') .size(15) .color('count', (n) => (n > 0 ? '#0f0' : '#f00')) .style({ textAnchor: 'center', // 文本相对锚点的位置 center|left|right|top|bottom|top-left textOffset: [30, 5], padding: [2, 2], fontFamily, iconfont: true, // textAllowOverlap: true }); scene.addLayer(pointLayer); const textLayer = new PointLayer({ zIndex: 10, }) .source(data) .shape('count', 'text') .size(12) .color('count', (n) => (n > 0 ? '#0f0' : '#f00')) .style({ textAnchor: 'center', // 文本相对锚点的位置 center|left|right|top|bottom|top-left textOffset: [40, 10], padding: [1, 1], }); scene.addLayer(textLayer); }); }); } public render() { return ( <> <div id="map" style={{ position: 'absolute', top: 0, left: 0, right: 0, bottom: 0, }} /> </> ); } }