news 2026/4/16 12:34:20

MapBox从入门到精通

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MapBox从入门到精通

Mapbox GL JS 是 Mapbox 核心的前端地图开发库,支持添加点、线、面、圆、符号、文本等各类矢量图形,主要通过数据源(Source) + 图层(Layer) 的模式实现。以下是详细的添加方法和示例,涵盖常用图形类型:

一、基础准备:初始化地图

首先确保引入 Mapbox GL JS 并初始化地图(需提前申请 Mapbox Access Token):

<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Mapbox 添加各类图形</title> <!-- 引入 Mapbox GL JS 核心库和样式 --> <link href="https://api.mapbox.com/mapbox-gl-js/v3.4.0/mapbox-gl.css" rel="stylesheet"> <script src="https://api.mapbox.com/mapbox-gl-js/v3.4.0/mapbox-gl.js"></script> <style> body { margin: 0; padding: 0; } #map { width: 100vw; height: 100vh; } </style> </head> <body> <div id="map"></div> <script> // 初始化地图 mapboxgl.accessToken = '你的Mapbox Access Token'; // 替换为自己的Token const map = new mapboxgl.Map({ container: 'map', // 容器ID style: 'mapbox://styles/mapbox/streets-v12', // 基础地图样式 center: [116.4074, 39.9042], // 初始中心点(北京) zoom: 12 // 初始缩放级别 }); // 地图加载完成后执行添加图形的逻辑 map.on('load', () => { // 所有图形添加逻辑写在这里 }); </script> </body> </html>

二、核心概念:Source + Layer

Mapbox 中所有图形都需要先定义数据源(Source)(存储地理数据),再通过图层(Layer)(定义渲染样式)展示。

Source 类型:常用 geojson(兼容 GeoJSON 格式,支持点、线、面)、image(图片)、video(视频)等;

Layer 类型:根据图形类型选择,如 circle(圆)、line(线)、fill(面)、symbol(符号 / 文本)等。

三、各类图形添加示例

以下示例均写在 map.on('load', () => { ... }) 内部。

1. 点图形(Circle 图层:圆形点)

适合展示坐标点(如 POI、传感器位置),可自定义半径、颜色、透明度:

// 1. 添加 GeoJSON 数据源(单个点) map.addSource('point-source', { type: 'geojson', data: { type: 'Feature', geometry: { type: 'Point', coordinates: [116.4074, 39.9042] // [经度, 纬度] }, properties: { name: '天安门' } // 自定义属性(可选) } }); // 2. 添加 Circle 图层渲染点 map.addLayer({ id: 'point-layer', // 图层唯一ID type: 'circle', // 图层类型:圆形 source: 'point-source', // 关联数据源 paint: { 'circle-radius': 10, // 圆半径(像素) 'circle-color': '#FF5733', // 填充色 'circle-opacity': 0.8, // 透明度 'circle-stroke-width': 2, // 描边宽度 'circle-stroke-color': '#FFFFFF' // 描边色 } });

2. 线图形(Line 图层:折线 / 曲线)

适合展示道路、轨迹、边界线等:

// 1. 添加线数据源 map.addSource('line-source', { type: 'geojson', data: { type: 'Feature', geometry: { type: 'LineString', coordinates: [ [116.35, 39.9], // 起点 [116.4, 39.92], // 中点 [116.45, 39.9] // 终点 ] } } }); // 2. 添加 Line 图层渲染线 map.addLayer({ id: 'line-layer', type: 'line', source: 'line-source', paint: { 'line-width': 4, // 线宽度 'line-color': '#3498DB', // 线颜色 'line-dasharray': [2, 2], // 虚线(可选,[实线长度, 空白长度]) 'line-opacity': 0.9 // 透明度 } });

3. 面图形(Fill 图层:多边形 / 区域)

适合展示行政区、湖泊、建筑区域等:

// 1. 添加面数据源(多边形,闭合坐标) map.addSource('fill-source', { type: 'geojson', data: { type: 'Feature', geometry: { type: 'Polygon', coordinates: [ [ [116.38, 39.89], // 顶点1 [116.42, 39.89], // 顶点2 [116.42, 39.92], // 顶点3 [116.38, 39.92], // 顶点4 [116.38, 39.89] // 闭合点(与顶点1一致) ] ] } } }); // 2. 添加 Fill 图层渲染面 map.addLayer({ id: 'fill-layer', type: 'fill', source: 'fill-source', paint: { 'fill-color': '#2ECC71', // 填充色 'fill-opacity': 0.5, // 填充透明度 'fill-outline-color': '#27AE60' // 面轮廓线颜色 } });
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 12:33:40

Wan2.2-T2V-5B + HuggingFace镜像网站:快速部署你的AI视频引擎

Wan2.2-T2V-5B HuggingFace镜像网站&#xff1a;快速部署你的AI视频引擎 在短视频内容爆炸式增长的今天&#xff0c;一个创意从灵感到上线的时间窗口正在急剧缩短。广告团队需要为多个平台生成数十个版本的动效素材&#xff0c;教育产品希望根据用户输入实时生成教学动画&…

作者头像 李华
网站建设 2026/4/12 16:08:24

音频下载终极指南:三步搞定喜马拉雅VIP与付费内容

音频下载终极指南&#xff1a;三步搞定喜马拉雅VIP与付费内容 【免费下载链接】xmly-downloader-qt5 喜马拉雅FM专辑下载器. 支持VIP与付费专辑. 使用GoQt5编写(Not Qt Binding). 项目地址: https://gitcode.com/gh_mirrors/xm/xmly-downloader-qt5 还在为无法离线收听喜…

作者头像 李华
网站建设 2026/4/16 12:21:52

C++基础语法篇八 ——【类型转换、再探构造、友元】

不出意外&#xff0c;本篇博客是对类和对象的结尾&#xff0c;最后一些相关知识点在本篇博客将会细细讲解。下课来看深入探究构造函数 再探构造函数&#xff08;深入探究构造函数&#xff09; • 之前我们实现构造函数时&#xff0c;初始化成员变量主要使用函数体内赋值&#x…

作者头像 李华
网站建设 2026/4/16 12:20:34

Codex的效率命令真的更快吗?对比Seed-Coder-8B-Base实测结果

Codex的效率命令真的更快吗&#xff1f;对比Seed-Coder-8B-Base实测结果 在AI编程助手逐渐成为开发者“标配”的今天&#xff0c;一个看似简单却直击本质的问题浮出水面&#xff1a;所谓的“高效”代码生成&#xff0c;到底快在哪里&#xff1f;是响应速度更快&#xff0c;还是…

作者头像 李华
网站建设 2026/4/16 10:45:33

AVL树的学习

平衡因子(左子树高度 - 右子树高度)的绝对值 < 1旋转操作左旋&#xff1a;向左旋转&#xff0c;冲突的左孩变右孩冲突的左孩变成了右孩&#xff0c;两个中序遍历是一致的&#xff0c;说明它俩是等价的。右旋&#xff1a;向右旋转&#xff0c;重推的右孩变左孩冲突的右孩变左…

作者头像 李华
网站建设 2026/4/15 21:59:48

50亿参数轻量化T2V模型Wan2.2-T2V-5B性能实测与优化建议

50亿参数轻量化T2V模型Wan2.2-T2V-5B性能实测与优化建议 在短视频内容爆炸式增长的今天&#xff0c;创作者和企业正面临一个共同挑战&#xff1a;如何以更低的成本、更快的速度生产出足够多的动态视觉内容&#xff1f;传统视频制作流程耗时耗力&#xff0c;而动辄上百亿参数的文…

作者头像 李华