当前位置: 首页 > news >正文

MapLibre GL JS第25课:添加栅格瓦片源

📌 学习目标

  • 掌握添加栅格瓦片源的实现方法
  • 理解相关API的使用
  • 能够独立完成类似功能开发

🎯 核心概念

向地图添加栅格瓦片数据源。

💻 完 整 代 码

代码示例

constmap=newmaplibregl.Map({container:'map',// 容器IDstyle:{'version':8,'sources':{'raster-tiles':{'type':'raster','tiles':['https://tile.openstreetmap.org/{z}/{x}/{y}.png'],'tileSize':256,'minzoom':0,'maxzoom':19,'attribution':"© OpenStreetMap contributors",}},'layers':[{'id':'simple-tiles','type':'raster','source':'raster-tiles',}],'id':'blank'},center:[0,0],// 初始位置zoom:0// 初始缩放级别});

代码示例

<!DOCTYPEhtml><htmllang="en"><head><title>Add a raster tile source</title><metaproperty="og:description"content="向地图添加第三方栅格源。"/><metaproperty="og:created"content="2025-06-25"/><metacharset='utf-8'><metaname="viewport"content="width=device-width, initial-scale=1"><linkrel='stylesheet'href='https://unpkg.com/maplibre-gl@5.24.0/dist/maplibre-gl.css'/><scriptsrc='https://unpkg.com/maplibre-gl@5.24.0/dist/maplibre-gl.js'></script><style>body{margin:0;padding:0;}html, body, #map{height:100%;}</style></head><body><divid="map"></div><script>constmap=newmaplibregl.Map({container:'map',// 地图容器idstyle:{'version':8,'sources':{'raster-tiles':{'type':'raster','tiles':['https://tile.openstreetmap.org/{z}/{x}/{y}.png'],'tileSize':256,'minzoom':0,'maxzoom':19,'attribution':"© OpenStreetMap contributors",}},'layers':[{'id':'simple-tiles','type':'raster','source':'raster-tiles',}],'id':'blank'},center:[0,0],// 初始位置zoom:0// 初始缩放级别});</script></body></html>

🔍 代码解析

1. 初始化地图

使用new maplibregl.Map()创建地图实例,配置完整的自定义样式对象。

2. 配置栅格瓦片源

style.sources中定义栅格瓦片源:

  • type: 'raster': 指定为栅格瓦片源
  • tiles: 瓦片URL模板数组,支持{z}/{x}/{y}占位符
  • tileSize: 瓦片大小(通常为256)
  • minzoom/maxzoom: 缩放级别范围
  • attribution: 版权信息

3. 添加栅格图层

style.layers中添加raster类型图层,引用栅格数据源。

⚙️ 参数说明

参数类型必填说明
containerstring地图容器ID
styleobject完整的样式对象
center[number, number]初始中心点,默认[0, 0]
zoomnumber初始缩放级别,默认0

栅格瓦片源配置

属性类型说明
typestring必须为 ‘raster’
tilesarray瓦片URL模板数组
tileSizenumber瓦片像素大小(通常256)
minzoomnumber最小缩放级别
maxzoomnumber最大缩放级别
attributionstring版权归属信息

🎨 效果说明

运行代码后:

  • 地图显示全球视图(中心点 [0, 0],缩放级别0)
  • 使用OpenStreetMap栅格瓦片作为底图
  • 用户可正常交互(拖拽、缩放、旋转)

💡 常 见 问 题

Q1: 矢量瓦片和栅格瓦片有什么区别?
A:矢量瓦片包含矢量数据,可以自定义样式;栅格瓦片是预先渲染的图片,样式固定。

Q2: 如何添加多个栅格图层?
A:定义多个数据源和图层,使用minzoom/maxzoomfilter控制显示。

Q3: 常用的栅格瓦片服务有哪些?
A:OpenStreetMap、MapQuest、Stamen、NASA等提供免费或付费的栅格瓦片服务。

📝 练习任务

  1. 基础练习:更换为其他栅格瓦片服务(如Stamen)
  2. 进阶挑战:添加多个栅格图层,实现图层切换
  3. 拓展思考:如何实现自定义栅格瓦片服务?

🌟 最佳实践

  1. 版权信息: 必须正确设置attribution属性
  2. 缩放级别: 合理设置minzoom/maxzoom,避免加载不必要的瓦片
  3. 瓦片大小: 保持tileSize与服务一致(通常256)
  4. 跨域处理: 确保瓦片服务支持CORS或使用代理

🔗 延伸阅读

  • Map API文档
  • MapLibre GL JS 官方文档
  • [下一课预告]:将继续学习地图图层的基础知识

本文是MapLibre GL JS实践课程系列的一部分,欢迎关注收藏

http://www.jsqmd.com/news/912319/

相关文章:

  • Lindy自动化部署失败率高达67%?揭秘头部企业私藏的7步零故障上线 checklist
  • LLM 推理性能优化:从 vLLM 到投机解码的工程实践
  • 2026北京海淀区公司注册哪家好?3家靠谱机构TOP排名 - 小柏云
  • lat.md:将任意项目代码转换为可查询的知识图谱
  • PVE Tools:如何在30分钟内为虚拟化架构师实现运维效率提升300%的技术杠杆
  • 经营分析怎么做?打通经营分析的4个环节:收入、成本、利润、业财
  • Kali365 钓鱼工具包绕过 MFA 窃取 Microsoft 365 账号的机理与防御研究
  • Java还有前景吗?2026年还能学吗?过来人谈谈见解
  • AgentScope:一个多Agent框架
  • AI健康助手如何重塑医疗:从症状分诊到慢性病管理的实践
  • 题解:洛谷 P13019 [GESP202506 八级] 树上旅行
  • 四川盛世钢联|成都钢材销售厂家|本地现货供货商|代理商批量拿货价优 - 四川盛世钢联营销中心
  • 文旅 GEO×AIAGC:OPD 一人部门如何引爆文旅内容与获客效率革命
  • 全网音乐免费下Go Music 音乐工具,听歌下载全搞
  • 魔兽争霸3终极优化指南:5分钟让经典游戏在现代电脑完美运行
  • 【AI面试临阵磨枪-088】Skill 如何做参数校验、依赖注入、权限控制、超时、重试、幂等?
  • 别再纠结QCustomPlot、QtChart和QWT了!手把手教你用PyQt5为Arduino/STM32数据选对绘图库
  • 炒股要有激情,就不聊股票的 怎么可能赚钱 股灾空仓最好,平时也要复盘的,有没有职业炒股的,要怎么做?
  • 设计师的“数字武器库”:CAD库分类解析与选型指南
  • 小红书怎么无水印保存视频到相册?2026详细操作攻略 - 科技大爆炸
  • 基于云端OpenClaw的情绪互动机器人系统-Milk-V Duo S + 机器人 端开发(7)
  • 2026最新台州玉环黄金回收+白银回收+铂金回收店铺门店权威榜单TOP1~5家推荐地址电话 - 诚信金利回收
  • 中文语境钓鱼即服务(PhaaS)产业链演化与闭环防御研究
  • 测试开发干货:用 Python 玩转数据库,告别 pymysql 的繁琐操作!
  • 华硕笔记本终极控制指南:用G-Helper替代Armoury Crate的完整教程
  • 淘宝淘金币自动化脚本终极指南:快速解决8大常见问题
  • 工装集成墙板十大品牌推荐
  • 如何轻松管理游戏DLSS版本:DLSS Swapper使用指南
  • JavaScript 垃圾回收机制详解
  • 【字节跳动】江苏苏州江南水乡临水低碳液冷算力集群