AntV L7地图可视化入坑笔记

先用 HTML CDN的方式跑起来一个地图案例:
官方案例地址:https://codesandbox.io/s/laughing-fermat-fjy5y?file=/index.html:491-499

我的案例代码:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>L7</title>
    <link href='https://api.tiles.mapbox.com/mapbox-gl-js/v1.5.0/mapbox-gl.css' rel='stylesheet' />
    <script src='https://api.tiles.mapbox.com/mapbox-gl-js/v1.5.0/mapbox-gl.js'></script>
    <script src='https://unpkg.com/@antv/l7'></script>
</head>

<body>
    <div style="width: 800px;height: 600px; position: absolute;" id="map"></div>
    <script>       
        const scene = new L7.Scene({
            id: 'map',
            //GaodeMap   Mapbox 需要上面的mapbox-gl.js
            map: new L7.Mapbox({
                style: 'dark', // 样式URL dark blank light
                center: [110.19382669582967, 30.258134],
                pitch: 40,
                zoom: 3,
                // token: 'mapbox token',
            }),
        });

        fetch('https://gw.alipayobjects.com/os/rmsportal/oVTMqfzuuRFKiDwhPSFL.json')
            .then(res => res.json())
            .then(data => {
                const pointLayer = new L7.PointLayer({})
                    .source(data.list, {
                        parser: {
                            type: 'json',
                            x: 'j',
                            y: 'w'
                        }
                    })
                    .shape('cylinder')
                    .size('t', function (level) {
                        return [1, 2, level * 2 + 20];
                    })
                    .color('t', [
                        '#094D4A',
                        '#146968',
                        '#1D7F7E',
                        '#289899',
                        '#34B6B7',
                        '#4AC5AF',
                        '#5FD3A6',
                        '#7BE39E',
                        '#A1EDB8',
                        '#CEF8D6'
                    ])
                    .style({
                        opacity: 1.0
                    });
                scene.addLayer(pointLayer);
            });
    </script>
</body>
</html>

运行结果:

在这里插入图片描述
我的案例使用的是Mapbox。如果不引用mapbox-gl.js会出现下面的错误。

在这里插入图片描述
注意事项:

  1. div设置宽高之后必须指定position,否则宽高无效。吐槽一下scene居然没有设置宽高的方法,只有一个getSize()。

折腾了好久才折腾出这样的一个模样出来。

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

X01动力装甲

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值