vue3+leaflet+天地图

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


一、准备工作

需要先安装leaflet插件 并且申请一个天地图秘钥

1.安装插件

npm install leaflet -D

2.天地图秘钥

https://www.tianditu.gov.cn/在天地图官网注册并登陆一个账号,进入控制台 。

在这里插入图片描述创建新应用。
在这里插入图片描述
类型选择浏览器端

创建成功后,我们可以获得秘钥key
在这里插入图片描述

二、使用步骤

1.引入库

代码如下(示例):

	import L from 'leaflet';
	import 'leaflet/dist/leaflet.css'

2.创建地图容器

代码如下(示例):

<template>
    <!-- leaflet 地图容器 -->
    <div id="myMap"></div> 
</template>

3.初始化地图

代码如下(示例):

<script setup>
  import L from 'leaflet';
  import 'leaflet/dist/leaflet.css'
  import {onMounted} from 'vue'
  let tdtKey = '刚刚上一步申请的天地图秘钥key'
  const initMap = () => {
    //影像地图
    const tiandituMap =  L.tileLayer(`http://t0.tianditu.gov.cn/img_w/wmts?SERVICE=WMTS&REQUEST=GetTile&VERSION=1.0.0&LAYER=img&STYLE=default&TILEMATRIXSET=w&FORMAT=tiles&TILEMATRIX={z}&TILEROW={y}&TILECOL={x}&tk=${tdtKey}`)
    //注记
    const tiandituText =  L.tileLayer(`http://t0.tianditu.gov.cn/cia_w/wmts?SERVICE=WMTS&REQUEST=GetTile&VERSION=1.0.0&LAYER=cia&STYLE=default&TILEMATRIXSET=w&FORMAT=tiles&TILEMATRIX={z}&TILEROW={y}&TILECOL={x}&tk=${tdtKey}`)
    const layers = L.layerGroup([tiandituMap,tiandituText])
    let map = L.map('myMap',{  //需绑定地图容器div的id
      center:[39.56,116.20], //初始地图中心
      zoom:10, //初始缩放等级
      maxZoom:18, //最大缩放等级
      minZoom:0, //最小缩放等级
      zoomControl:false,//不显示缩放小控件
      layers:[layers]
    })
  }
  onMounted(()=>{
    initMap()
  })
</script>

4.界面效果

在这里插入图片描述


天地图地图服务API相关

http://lbs.tianditu.gov.cn/server/MapService.html
在这里插入图片描述

//想要切换不同的地图服务 只需要将下图中红色标记的部分替换为上图中红色标记的部分即可。 "LAYER=“后只需要替换”_"之前的部分。

在这里插入图片描述
如想要将影像地图替换为矢量地图
http://t0.tianditu.gov.cn/img_w /wmts?SERVICE=WMTS&REQUEST=GetTile&VERSION=1.0.0&LAYER=img &STYLE=default&TILEMATRIXSET=w&FORMAT=tiles&TILEMATRIX={z}&TILEROW={y}&TILECOL={x}&tk=${tdtKey}

http://t0.tianditu.gov.cn/vec_w/wmts?SERVICE=WMTS&REQUEST=GetTile&VERSION=1.0.0&LAYER=vec &STYLE=default&TILEMATRIXSET=w&FORMAT=tiles&TILEMATRIX={z}&TILEROW={y}&TILECOL={x}&tk=${tdtKey}

菜鸟一枚,如有问题欢迎大家指正哈~

  • 7
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值