AntV L7构建中地大楼

2024-03-17 20:20
文章标签 构建 antv 大楼 l7

本文主要是介绍AntV L7构建中地大楼,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本案例使用L7库和Mapbox GL JS构建中地大楼。

文章目录

  • 1. 引入 CDN 链接
  • 2. 引入组件
  • 3. 创建场景
  • 4. 加载场景
    • 4.1. 获取数据
    • 4.2. 创建多边形图层
    • 4.3. 添加弹窗
  • 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. 引入组件

使用第三方库 L7 来创建一个地图并添加数据到地图上的。L7 库提供了许多组件,如地图、图层、弹窗等,用于创建交互式地图。

  1. Scene:场景,用于绘制地图上的基本元素,如地图底图、事件侦听器等。
  2. Mapbox:Mapbox 地图,一种基于 WebGL 的地图引擎,提供了丰富的地图数据和功能。
  3. PointLayer:点图层,用于绘制地图上的点数据,如标记、circle 等。
  4. GaodeMap:高德地图,一种免费且功能强大的地图服务,提供了丰富的地图数据和功能。
  5. PolygonLayer:多边形图层,用于绘制地图上的多边形数据,如矩形、多边形等。
  6. LineLayer:线图层,用于绘制地图上的线数据,如线条、虚线等。
  7. Popup:弹窗,用于在地图上显示弹窗,展示点的相关信息。
const { Scene, Mapbox, PointLayer, GaodeMap, PolygonLayer, LineLayer, Popup } =L7;

3. 创建场景

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

// 基于高德地图的地图场景
const scene = new Scene({id: "map",map: new GaodeMap({style: "light",center: [114.4, 30.467],zoom: 16,// 俯仰角pitch: 60,}),
});

4. 加载场景

4.1. 获取数据

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

fetch("http://39.103.151.139:8000/gis/zhongdi").then((res) => res.json()).then((data) => {// ...});

4.2. 创建多边形图层

// 4.2 创建一个多边形图层
const zhongdiLayer = new PolygonLayer({}).source(data).color("#21a1f1").size(100).shape("extrude");
// 将图层添加到场景中
scene.addLayer(zhongdiLayer);

4.3. 添加弹窗

当我们点击地图上的某个位置时,会触发这个事件,并显示一个弹出框(Popup)来显示点击位置的属性(名称和工作人员数量)。

// 4.3添加弹窗
// 通过on添加点击事件
zhongdiLayer.on("click", (e) => {// console.log(e);// 从回调中的数据,我们可以获取属性以及坐标const {feature: {properties: { name, people },},lngLat,} = e;// setLnglat需要传入一个经纬度数组const popup = new Popup({offsets: [0, 50],closeButton: false,}).setLnglat([lngLat.lng, lngLat.lat]).setHTML(`<span>名称: ${name}</span><br><span>工作人数: ${people}</span>`);// 将弹出框添加到场景中scene.addPopup(popup);
});

5. 演示效果

image-20240228205019884

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;/* cursor: pointer; */}.l7-popup-content {background-color: skyblue !important;}</style></head><body><div id="map"></div><script>// 2. 引入组件const {Scene,Mapbox,PointLayer,GaodeMap,PolygonLayer,LineLayer,Popup,} = L7;mapboxgl.accessToken ="pk.eyJ1IjoiemhvbmdkaXNodW1hIiwiYSI6ImNsNXJoYXR5eTI2bGgzZW53d2didWF1c3AifQ.6vOplM2NQc_xnJW3aA5ZBA";// 3.创建场景// 基于高德地图的地图场景const scene = new Scene({id: "map",map: new GaodeMap({style: "light",center: [114.4, 30.467],zoom: 16,// 俯仰角pitch: 60,}),});// 4.加载场景scene.on("loaded", () => {// 4.1 从服务器获取中地数据fetch("http://39.103.151.139:8000/gis/zhongdi").then((res) => res.json()).then((data) => {// 4.2 创建一个多边形图层const zhongdiLayer = new PolygonLayer({}).source(data).color("#21a1f1").size(100).shape("extrude");// 将图层添加到场景中scene.addLayer(zhongdiLayer);// 4.3添加点击事件// 通过on添加点击事件zhongdiLayer.on("click", (e) => {// console.log(e);// 从回调中的数据,我们可以获取属性以及坐标const {feature: {properties: { name, people },},lngLat,} = e;// setLnglat需要传入一个经纬度数组const popup = new Popup({offsets: [0, 50],closeButton: false,}).setLnglat([lngLat.lng, lngLat.lat]).setHTML(`<span>名称: ${name}</span><br><span>工作人数: ${people}</span>`);// 将弹出框添加到场景中scene.addPopup(popup);});});});</script></body>
</html>

这篇关于AntV L7构建中地大楼的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/820047

相关文章

基于Python构建一个高效词汇表

《基于Python构建一个高效词汇表》在自然语言处理(NLP)领域,构建高效的词汇表是文本预处理的关键步骤,本文将解析一个使用Python实现的n-gram词频统计工具,感兴趣的可以了解下... 目录一、项目背景与目标1.1 技术需求1.2 核心技术栈二、核心代码解析2.1 数据处理函数2.2 数据处理流程

Python FastMCP构建MCP服务端与客户端的详细步骤

《PythonFastMCP构建MCP服务端与客户端的详细步骤》MCP(Multi-ClientProtocol)是一种用于构建可扩展服务的通信协议框架,本文将使用FastMCP搭建一个支持St... 目录简介环境准备服务端实现(server.py)客户端实现(client.py)运行效果扩展方向常见问题结

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

详解如何使用Python从零开始构建文本统计模型

《详解如何使用Python从零开始构建文本统计模型》在自然语言处理领域,词汇表构建是文本预处理的关键环节,本文通过Python代码实践,演示如何从原始文本中提取多尺度特征,并通过动态调整机制构建更精确... 目录一、项目背景与核心思想二、核心代码解析1. 数据加载与预处理2. 多尺度字符统计3. 统计结果可

一文教你Java如何快速构建项目骨架

《一文教你Java如何快速构建项目骨架》在Java项目开发过程中,构建项目骨架是一项繁琐但又基础重要的工作,Java领域有许多代码生成工具可以帮助我们快速完成这一任务,下面就跟随小编一起来了解下... 目录一、代码生成工具概述常用 Java 代码生成工具简介代码生成工具的优势二、使用 MyBATis Gen

Python使用Reflex构建现代Web应用的完全指南

《Python使用Reflex构建现代Web应用的完全指南》这篇文章为大家深入介绍了Reflex框架的设计理念,技术特性,项目结构,核心API,实际开发流程以及与其他框架的对比和部署建议,感兴趣的小伙... 目录什么是 ReFlex?为什么选择 Reflex?安装与环境配置构建你的第一个应用核心概念解析组件

Python+wxPython构建图像编辑器

《Python+wxPython构建图像编辑器》图像编辑应用是学习GUI编程和图像处理的绝佳项目,本教程中,我们将使用wxPython,一个跨平台的PythonGUI工具包,构建一个简单的... 目录引言环境设置创建主窗口加载和显示图像实现绘制工具矩形绘制箭头绘制文字绘制临时绘制处理缩放和旋转缩放旋转保存编

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

一文详解如何从零构建Spring Boot Starter并实现整合

《一文详解如何从零构建SpringBootStarter并实现整合》SpringBoot是一个开源的Java基础框架,用于创建独立、生产级的基于Spring框架的应用程序,:本文主要介绍如何从... 目录一、Spring Boot Starter的核心价值二、Starter项目创建全流程2.1 项目初始化(