使用 Leaflet.js 生成北京地铁地图(Trae实现)

引言

我们每天上班要坐地铁,于是我想用Trae帮我快速实现北京地铁地图。实现北京地铁地图我就想到了用 Leaflet.js,Leaflet.js 是一个开源的 JavaScript 库,它轻量级、易用且功能强大,非常适合用于创建交互式地图。本文将详细介绍如何使用 Leaflet.js 生成北京地铁地图,让你可以在网页上展示地铁线路和站点信息。

网站

北京地铁地图:www.metrolinehub.com/zh/china/be...

全球城市地铁地图: www.metrolinehub.com/

准备工作

在开始之前,你需要准备以下内容:

  1. Trae工具:用于快速编写代码。
  2. Leaflet.js 库 :可以从官方网站(leafletjs.com/ ) 下载,也可以使用 CDN 引入。
  3. 北京地铁数据 :可以从公开数据源获取地铁线路和站点的地理坐标信息,通常以 GeoJSON 格式存储,我这边使用的是高德的数据(ditu.amap.com/ )。

操作

步骤一:创建 HTML 结构

首先,创建一个基本的 HTML 文件,引入 Leaflet.js 库和相关的 CSS 文件。

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>北京地铁地图</title>
  <!-- 引入 Leaflet CSS -->
  <link rel="stylesheet" href="https://unpkg.com/leaflet@1.7.1/dist/leaflet.css"
    integrity="sha512-xodZBNTC5n17Xt2atTPuE1HxjVMSvLVW9ocqUKLsCC5CXdbqCmblAshOMAS6/keqq/sMZMZ19scR4PsZChSR7A=="
    crossorigin="" />
  <!-- 引入 Leaflet JavaScript -->
  <script src="https://unpkg.com/leaflet@1.7.1/dist/leaflet.js"
    integrity="sha512-XQoYMqMTK8LvdxXYG3nZ448hOEQiglfqkJs1NOQV44cWnUrBc8PkAOcXy20w0vlaXaVUearIOBhiXZ5V3ynxwA=="
    crossorigin=""></script>
  <style>
    #map {
      height: 600px;
    }
  </style>
</head>

<body>
  <!-- 地图容器 -->
  <div id="map"></div>
  <script>
    // 在这里编写 Leaflet 代码
  </script>
</body>

</html>

步骤二:初始化地图

在 JavaScript 部分,初始化 Leaflet 地图并设置初始视图。

javascript 复制代码
// 创建地图对象
var map = L.map('map').setView([39.9042, 116.4074], 12);

// 添加地图图层
L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
  attribution: 'Map data &copy; <a href="https://www.openstreetmap.org/">OpenStreetMap</a> contributors',
  maxZoom: 18
}).addTo(map);

在上述代码中,L.map('map') 创建了一个地图对象,并将其绑定到 HTML 中 idmap 的元素上。setView([39.9042, 116.4074], 12) 设置了地图的初始中心位置(北京的经纬度)和缩放级别。L.tileLayer 添加了一个基础地图图层,这里使用了 OpenStreetMap 的瓦片地图。

步骤三:加载北京地铁数据

假设你已经获取了北京地铁的 GeoJSON 数据,将其保存为 beijing_subway.geojson 文件。接下来,使用 L.geoJSON 加载并显示地铁线路和站点。

javascript 复制代码
// 加载 GeoJSON 数据
fetch('beijing_subway.geojson')
  .then(response => response.json())
  .then(data => {
    // 创建 GeoJSON 图层
    var subwayLayer = L.geoJSON(data, {
      // 样式设置
      style: function (feature) {
        return {
          color: feature.properties.color, // 根据线路属性设置颜色
          weight: 3
        };
      },
      // 点样式设置
      pointToLayer: function (feature, latlng) {
        return L.circleMarker(latlng, {
          radius: 5,
          fillColor: feature.properties.color,
          color: '#000',
          weight: 1,
          opacity: 1,
          fillOpacity: 0.8
        });
      },
      // 交互事件
      onEachFeature: function (feature, layer) {
        if (feature.properties && feature.properties.name) {
          layer.bindPopup(feature.properties.name);
        }
      }
    }).addTo(map);
  });

在上述代码中,使用 fetch 函数异步加载 GeoJSON 数据。L.geoJSON 创建了一个 GeoJSON 图层,并根据数据的属性设置了线路和站点的样式。pointToLayer 用于自定义点要素(站点)的样式,onEachFeature 为每个要素添加了交互事件,当点击站点时会弹出包含站点名称的弹窗。

步骤四:优化和扩展

为了提升用户体验,你可以进一步优化和扩展地图功能,例如:

  1. 添加图例:显示不同地铁线路的颜色和名称。
  2. 线路筛选:允许用户选择显示特定的地铁线路。
  3. 导航功能:实现站点之间的导航。

以下是一个简单的添加图例的示例代码:

javascript 复制代码
// 创建图例
var legend = L.control({ position: 'bottomright' });

legend.onAdd = function (map) {
  var div = L.DomUtil.create('div', 'info legend');
  var lines = [
    { name: '地铁 1 号线', color: '#FF0000' },
    { name: '地铁 2 号线', color: '#00FF00' },
    // 其他线路...
  ];

  for (var i = 0; i < lines.length; i++) {
    div.innerHTML +=
      '<i style="background:' + lines[i].color + '"></i> ' +
      lines[i].name + '<br>';
  }

  return div;
};

legend.addTo(map);

步骤五:其他功能

根据上面数据我们还能实现北京每条线路的站点情况,如下图:

总结

通过以上步骤,你已经成功使用 Leaflet.js 生成了一个北京地铁地图。Leaflet.js 提供了丰富的 API 和插件,你可以根据自己的需求进一步扩展和定制地图功能,为用户带来更好的地图体验。

希望本文对你有所帮助,祝你在地图开发的道路上取得更多的成果!

相关推荐
Mintopia8 小时前
🌐 动态网络环境中 WebAIGC 的断点续传与容错技术
人工智能·aigc·trae
我有一个object9 小时前
uniapp上传文件报错:targetSdkVersion设置>=29后在Android10+系统设备不支持当前路径。请更改为应用运行路径!
前端·javascript·vue.js·uniapp
北极糊的狐9 小时前
关于jQuery 事件绑定,记录常用事件类型及核心注意事项
前端·javascript·jquery
_Kayo_9 小时前
vue3 computed 练习笔记
前端·vue.js·笔记
CodeSheep9 小时前
VS 2026 正式发布,王炸!
前端·后端·程序员
无奈何杨9 小时前
CoolGuard事件查询增加策略和规则筛选,条件结果展示
前端·后端
梦里不知身是客119 小时前
正则表达式常见的介绍
前端·javascript·正则表达式
初学小白...9 小时前
HTML知识点
前端·javascript·html
鹏多多9 小时前
flutter睡眠与冥想数据可视化神器:sleep_stage_chart插件全解析
android·前端·flutter
艾小码9 小时前
Vue3 脚本革命:<script setup> 让你的代码简洁到飞起!
前端·javascript·vue.js