AntV L7的填充图

本案例使用L7库和Mapbox GL JS绘制填充图。

文章目录

  • 1. 引入 CDN 链接
  • 2. 引入组件
  • 3. 创建场景
  • 4. 绘制填充图
    • 4.1. 获取数据
    • 4.2. 定义颜色数组
    • 4.3. 创建多边形图层
    • 4.4. 创建线图层
    • 4.5. 添加图层
    • 4.6. 绘制填充图代码
  • 5. 演示效果
  • 6. 代码实现

1. 引入 CDN 链接

<script src="https://unpkg.com/@antv/l7"></script>
<script src="https://api.mapbox.com/mapbox-gl-js/v2.12.0/mapbox-gl.js"></script>
<linkhref="https://api.mapbox.com/mapbox-gl-js/v2.12.0/mapbox-gl.css"rel="stylesheet"
/>

2. 引入组件

我们导入的库和组件有:

  • Scene:谷歌地球模式。
  • Mapbox:Mapbox 地图服务。
  • PointLayer:点图层。
  • GaodeMap:高德地图服务。
  • PolygonLayer:多边形图层。
  • LineLayer:线图层。
const { Scene, Mapbox, PointLayer, GaodeMap, PolygonLayer, LineLayer } = L7;

3. 创建场景

在这里,我们创建基于高德地图的地图场景。

// 基于高德地图的地图场景
const scene = new Scene({id: "map",map: new GaodeMap({style: "light",center: [108.280717, 23.157163],zoom: 7,}),
});

4. 绘制填充图

4.1. 获取数据

使用 fetch 函数从服务器获取数据:

fetch("https://geo.datav.aliyun.com/areas_v3/bound/450100_full.json").then((res) => res.json()).then((data) => {// ...});

4.2. 定义颜色数组

const color = ["rgb(255,255,217)","rgb(237,248,177)","rgb(199,233,180)","rgb(127,205,187)","rgb(65,182,196)","rgb(29,145,192)","rgb(34,94,168)","rgb(12,44,132)",
];

4.3. 创建多边形图层

const layer1 = new PolygonLayer({}).source(data)// 根据adcode字段进行分段.scale("adcode", {type: "quantile",})// 根据adcode字段设置颜色.color("adcode", color)// 设置填充形状.shape("fill")// 设置透明度.style({opacity: 0.7,})// 设置激活状态.active(true);

4.4. 创建线图层

const layer2 = new LineLayer({zIndex: 2,
}).source(data)// 设置颜色.color("#fff")// 设置激活状态.active(true)// 设置线宽.size(1)// 设置透明度.style({opacity: 0.6,})// 设置线型.style({lineType: "dash",dashArray: [2, 2],});

4.5. 添加图层

将图层添加到场景中:

scene.addLayer(layer1);
scene.addLayer(layer2);

4.6. 绘制填充图代码

scene.on("loaded", () => {// 从服务器获取数据fetch("https://geo.datav.aliyun.com/areas_v3/bound/450100_full.json").then((res) => res.json()).then((data) => {// 打印获取到的数据// console.log(data);// 定义颜色数组const color = ["rgb(255,255,217)","rgb(237,248,177)","rgb(199,233,180)","rgb(127,205,187)","rgb(65,182,196)","rgb(29,145,192)","rgb(34,94,168)","rgb(12,44,132)",];// 创建一个多边形图层const layer1 = new PolygonLayer({}).source(data)// 根据adcode字段进行分段.scale("adcode", {type: "quantile",})// 根据adcode字段设置颜色.color("adcode", color)// 设置填充形状.shape("fill")// 设置透明度.style({opacity: 0.7,})// 设置激活状态.active(true);// 创建一个线图层const layer2 = new LineLayer({zIndex: 2,}).source(data)// 设置颜色.color("#fff")// 设置激活状态.active(true)// 设置线宽.size(1)// 设置透明度.style({opacity: 0.6,})// 设置线型.style({lineType: "dash",dashArray: [2, 2],});// 将图层添加到场景中scene.addLayer(layer1);scene.addLayer(layer2);});
});

5. 演示效果

image-20240228202433906

6. 代码实现

<!DOCTYPE html>
<html lang="zh-CN"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>填充图</title><!-- 1.引入CDN链接 --><script src="https://unpkg.com/@antv/l7"></script><script src="https://api.mapbox.com/mapbox-gl-js/v2.12.0/mapbox-gl.js"></script><linkhref="https://api.mapbox.com/mapbox-gl-js/v2.12.0/mapbox-gl.css"rel="stylesheet"/><style>* {padding: 0;margin: 0;}body {overflow: hidden;}#map {width: 100vw;height: 100vh;}</style></head><body><div id="map"></div><script>// 2. 引入组件const { Scene, Mapbox, PointLayer, GaodeMap, PolygonLayer, LineLayer } =L7;mapboxgl.accessToken ="pk.eyJ1IjoiemhvbmdkaXNodW1hIiwiYSI6ImNsNXJoYXR5eTI2bGgzZW53d2didWF1c3AifQ.6vOplM2NQc_xnJW3aA5ZBA";// 3.创建场景// 基于高德地图的地图场景const scene = new Scene({id: "map",map: new GaodeMap({style: "light",center: [108.280717, 23.157163],zoom: 7,}),});// 4.绘制填充图scene.on("loaded", () => {// 从服务器获取数据fetch("https://geo.datav.aliyun.com/areas_v3/bound/450100_full.json").then((res) => res.json()).then((data) => {// 打印获取到的数据// console.log(data);// 定义颜色数组const color = ["rgb(255,255,217)","rgb(237,248,177)","rgb(199,233,180)","rgb(127,205,187)","rgb(65,182,196)","rgb(29,145,192)","rgb(34,94,168)","rgb(12,44,132)",];// 创建一个多边形图层const layer1 = new PolygonLayer({}).source(data)// 根据adcode字段进行分段.scale("adcode", {type: "quantile",})// 根据adcode字段设置颜色.color("adcode", color)// 设置填充形状.shape("fill")// 设置透明度.style({opacity: 0.7,})// 设置激活状态.active(true);// 创建一个线图层const layer2 = new LineLayer({zIndex: 2,}).source(data)// 设置颜色.color("#fff")// 设置激活状态.active(true)// 设置线宽.size(1)// 设置透明度.style({opacity: 0.6,})// 设置线型.style({lineType: "dash",dashArray: [2, 2],});// 将图层添加到场景中scene.addLayer(layer1);scene.addLayer(layer2);});});</script></body>
</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/540053.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

什么牌子的台灯好用不伤眼?明基、柏曼、书客护眼台灯深度测评对比

近年来&#xff0c;青少年儿童近视问题越来越严重了&#xff0c;而且近视也在持续升高&#xff0c;不少年纪很小的孩子已经戴上了厚厚的近视眼镜。很多家长会选择给孩子备上一台光源舒适的台灯&#xff0c;不过在这也要提醒大家&#xff0c;在挑选过程中一定要多加留意&#xf…

为什么手机和电视ip地址不一样

在数字化时代&#xff0c;我们每天都会与各种电子设备打交道&#xff0c;其中最常见的就是手机和电视。当我们连接到互联网时&#xff0c;这些设备都会被分配一个独特的IP地址&#xff0c;用于在网络上进行标识和通信。然而&#xff0c;您可能已经注意到&#xff0c;即使手机和…

MQTT.fx实现(MQTT Client)连接物联网平台(ThingsCloud )

目录 概述 1 ThingsCloud平台介绍 2 ThingsCloud创建项目 2.1 创建项目 2.2 创建数据类型 2.3 创建设备类型 3 发布和订阅主题 3.1 发布Topic 3.2 订阅主题Topic 4 使用MQTT.fx 测试ThingsClond 4.1 使用MQTT.fx连接ThingsClond 4.2 MQTT.fx 订阅ThingsCloud Messag…

深度学习_GoogLeNet_4

目标 知道GoogLeNet网络结构的特点能够利用GoogLeNet完成图像分类 一、开发背景 GoogLeNet在2014年由Google团队提出&#xff0c; 斩获当年ImageNet(ILSVRC14)竞赛中Classification Task (分类任务) 第一名&#xff0c;VGG获得了第二名&#xff0c;为了向“LeNet”致敬&#x…

linux中netstat命令详解及常见用法

在Linux使用过程中&#xff0c;需要了解当前系统开放了哪些端口&#xff0c;并且要查看开放这些端口的具体进程和用户&#xff0c;可以通过netstat命令进行简单查询 1.netstat命令各个参数说明 -a 或–all 显示所有连线中的Socket。 -A …

2024-3-13高位分歧

今天的盘面早盘低位的AIGC和信创一致转分歧&#xff0c;低空经济和算力分歧加剧&#xff0c;老周期的每个小龙头资金开始撤离&#xff0c;立航科技 早上还在表演给了昨天接力的老师大肉机会&#xff0c;今天被骗上车的人属于傻白甜了&#xff1b;中电兴发 早上分歧挡刀功臣&…

【AI+CAD】(二)LLM和VLM生成结构化数据结构(PPT/CAD/DXF)

当前LLM和VLM在PPT生成任务上已经小有成效,如ChatPPT。 @TOC 1. PPT-LLM LLM根据用户的instruction生成规范的绘制ppt的API语句:即使是最强的GPT-4 + CoT也只能达到20-30%的内容准确度。 LLM输入:User_instruction(当前+过去)、PPT_content、PPT_reader_API。其中 PPT_rea…

【UE5】持枪状态站立移动的动画混合空间

项目资源文末百度网盘自取 创建角色在持枪状态站立移动的动画混合空间 在BlendSpace文件夹中单击右键选择动画(Animation)中的混合空间(Blend Space) 选择SK_Female_Skeleton 命名为BS_RifleStand 打开 水平轴表示角色的方向&#xff0c;命名为Direction&#xff0c;方…

漏洞复现-金蝶系列

漏洞复现-金蝶系列 金蝶云-星空 ServiceGateway.GetServiceUri.common 反序列化Apusic 金蝶天燕Apusic 应⽤中间件代码命令执⾏金蝶云星空RCE金蝶云OA星空 CommonFileserver 任意文件读取金蝶云星空 管理中心介绍⾦蝶 EAS 系统存在⽬录遍历金蝶EAS myUploadFile任意文件上传实战…

Docker笔记-进入运行中的镜像,查看日志等操作

docker搭建好后&#xff0c;查看运行的docker镜像&#xff1a; docker ps -a 进入运行的容器&#xff0c;命令如下&#xff1a; docker exec -it <容器ID> /bin/bash # 或者&#xff0c;直接用容器里面的命令&#xff0c;比如mysql镜像 docker exec -it <容器ID>…

java数据结构与算法刷题-----LeetCode47. 全排列 II

java数据结构与算法刷题目录&#xff08;剑指Offer、LeetCode、ACM&#xff09;-----主目录-----持续更新(进不去说明我没写完)&#xff1a;https://blog.csdn.net/grd_java/article/details/123063846 文章目录 1. 暴力回溯2. 分区法回溯 此题为46题的衍生题&#xff0c;在46题…

C语言之指针(四)

一、前言 哈喽大家好&#xff0c;经过前三次的学习&#xff0c;我们已经了解到了指针的诸多概念&#xff0c;同时也分别从计算机内存、&符号、机器位数和野指针等多方面去研究指针&#xff0c;那么接下来&#xff0c;我们要研究的是关于指针在数组中的应用&#xff0c;在此…