使用 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/[email protected]/dist/leaflet.css"
    integrity="sha512-xodZBNTC5n17Xt2atTPuE1HxjVMSvLVW9ocqUKLsCC5CXdbqCmblAshOMAS6/keqq/sMZMZ19scR4PsZChSR7A=="
    crossorigin="" />
  <!-- 引入 Leaflet JavaScript -->
  <script src="https://unpkg.com/[email protected]/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 和插件,你可以根据自己的需求进一步扩展和定制地图功能,为用户带来更好的地图体验。

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

相关推荐
布列瑟农的星空12 分钟前
从RequireJS到Webpack——前端跨越式发展的里程碑
前端
明教卢师傅44 分钟前
JS实现文件点击或者拖拽上传
前端·javascript
布列瑟农的星空1 小时前
WeakMap+AbortController——优雅地取消请求
前端
二川bro1 小时前
Vuex Actions 多参数传递的解决方案及介绍
开发语言·前端·javascript
dmy1 小时前
后端1小时上手vue开发到上线
前端·vue.js·vite
codingandsleeping2 小时前
OSI 七层网络模型
前端·网络协议·http
codingandsleeping2 小时前
TCP 三次握手与四次挥手
前端·网络协议
GUIQU.2 小时前
【JavaScript】ES6+ 新特性
前端·javascript·es6
小白_ysf2 小时前
《前端面试题之 CSS篇(第一集)》
前端·css·面试题
患得患失9492 小时前
【前端】【css】flex布局详解
前端·css