AntV L7深圳智慧城市

本案例使用L7 库和Mapbox GL JS构建深圳智慧城市。

文章目录

  • [1. 引入 CDN 链接](#1. 引入 CDN 链接)
  • [2. 引入组件](#2. 引入组件)
  • [3. 创建地图](#3. 创建地图)
  • [4. 创建场景](#4. 创建场景)
  • [5. 获取数据](#5. 获取数据)
  • [6. 创建面图层](#6. 创建面图层)
  • [7. 演示效果](#7. 演示效果)
  • [8. 代码实现](#8. 代码实现)

1. 引入 CDN 链接

html 复制代码
<!-- 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>
<link
  href="https://api.mapbox.com/mapbox-gl-js/v2.12.0/mapbox-gl.css"
  rel="stylesheet"
/>

2. 引入组件

我们使用开源库 L7 来引入和初始化三个类:Scene、Mapbox 和 PolygonLayer。L7 库是一个用于创建地图的可控组件的库,它基于 Vue.js 和 Tuandoushi(天斗星)框架。

  1. Scene 类:这是一个用于创建地图场景的类。它提供了地图的基本设置,如视图、地图图层和样式。

  2. Mapbox 类:这是一个用于创建 Mapbox 地图的类。它提供了基于 Mapbox 的地图服务器的设置。

  3. PolygonLayer 类:这是一个用于创建多边形图层的类。它提供了绘制多边形图层的方法。

js 复制代码
const { Scene, Mapbox, PolygonLayer } = L7;

3. 创建地图

我们创建了一个Mapbox GL JS地图实例,设置了地图的容器、默认的地图风格、中心点坐标、地图级别、默认的地图投影模式以及俯仰角。

js 复制代码
// 3.创建地图
const map = new mapboxgl.Map({
  container: "map",
  style: "mapbox://styles/mapbox/streets-v12",
  center: [114.050008, 22.529272],
  zoom: 13,
  projection: "globe",
  pitch: 70,
});

4. 创建场景

Scene组件负责显示地图和其他图层。

js 复制代码
const scene = new L7.Scene({
  id: "map",
  map: new Mapbox({
    mapInstance: map,
  }),
});

5. 获取数据

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

javascript 复制代码
        fetch(
          "https://gw.alipayobjects.com/os/basement_prod/972566c5-a2b9-4a7e-8da1-bae9d0eb0117.json"
        )
          .then((res) => res.json())
          .then((data) => {
            const colors = [
              "#816CAD",
              "#A67FB5",
              "#C997C7",
              "#DEB8D4",
              "#F5D4E6",
              "#FAE4F1",
              "#FFF3FC",
            ];

6. 创建面图层

我们需要创建一个新的PolygonLayer对象,然后添加数据源,接着设置形状、激活状态和颜色等属性,最后将层添加到场景中。

js 复制代码
// 6.创建面图层
const layer = new PolygonLayer({})
  // source添加数据源
  .source(data)
  .shape("extrude")
  .active(true)
  .color("h20", colors)
  .size("h20", [100, 120, 160, 200, 260, 300]);

scene.addLayer(layer);

7. 演示效果

8. 代码实现

html 复制代码
<!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>
    <link
      href="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, PolygonLayer } = L7;
      mapboxgl.accessToken =
        "pk.eyJ1IjoiemhvbmdkaXNodW1hIiwiYSI6ImNsNXJoYXR5eTI2bGgzZW53d2didWF1c3AifQ.6vOplM2NQc_xnJW3aA5ZBA";

      // 3.创建地图
      const map = new mapboxgl.Map({
        container: "map",
        style: "mapbox://styles/mapbox/streets-v12",
        center: [114.050008, 22.529272],
        zoom: 13,
        projection: "globe",
        pitch: 70,
      });

      // 4.创建场景
      const scene = new L7.Scene({
        id: "map",
        map: new Mapbox({
          mapInstance: map,
        }),
      });

      scene.on("loaded", () => {
        // 5.获取数据
        fetch(
          "https://gw.alipayobjects.com/os/basement_prod/972566c5-a2b9-4a7e-8da1-bae9d0eb0117.json"
        )
          .then((res) => res.json())
          .then((data) => {
            const colors = [
              "#816CAD",
              "#A67FB5",
              "#C997C7",
              "#DEB8D4",
              "#F5D4E6",
              "#FAE4F1",
              "#FFF3FC",
            ];
            // 6.创建面图层
            const layer = new PolygonLayer({})
              // source添加数据源
              .source(data)
              .shape("extrude")
              .active(true)
              .color("h20", colors)
              .size("h20", [100, 120, 160, 200, 260, 300]);

            scene.addLayer(layer);
          });
      });
    </script>
  </body>
</html>
相关推荐
Robot2515 分钟前
浅谈,华为切入具身智能赛道
人工智能
只怕自己不够好10 分钟前
OpenCV 图像运算全解析:加法、位运算(与、异或)在图像处理中的奇妙应用
图像处理·人工智能·opencv
追梦的小猴子1 小时前
智慧监测数据集成平台:破孤岛,促互联,提数据价值强化履约,保质量,降成本为水务、城市、能源等领域发展添动力
智慧城市·能源
果冻人工智能1 小时前
2025 年将颠覆商业的 8 大 AI 应用场景
人工智能·ai员工
代码不行的搬运工1 小时前
神经网络12-Time-Series Transformer (TST)模型
人工智能·神经网络·transformer
石小石Orz1 小时前
Three.js + AI:AI 算法生成 3D 萤火虫飞舞效果~
javascript·人工智能·算法
孤独且没人爱的纸鹤1 小时前
【深度学习】:从人工神经网络的基础原理到循环神经网络的先进技术,跨越智能算法的关键发展阶段及其未来趋势,探索技术进步与应用挑战
人工智能·python·深度学习·机器学习·ai
阿_旭2 小时前
TensorFlow构建CNN卷积神经网络模型的基本步骤:数据处理、模型构建、模型训练
人工智能·深度学习·cnn·tensorflow
羊小猪~~2 小时前
tensorflow案例7--数据增强与测试集, 训练集, 验证集的构建
人工智能·python·深度学习·机器学习·cnn·tensorflow·neo4j
极客代码2 小时前
【Python TensorFlow】进阶指南(续篇三)
开发语言·人工智能·python·深度学习·tensorflow