Mapbox加载浙江省天地图服务和数据处理

1. 加载影像服务

通过浙江省天地图官网申请所需服务,使用token获取服务数据

由于浙江省天地图使用的坐标系是 cgcs2000,需要使用 的框架对应为 @cgcs2000/mapbox-gl,通过cdn引入或npm下载

影像服务地址为:

'https://ditu.zjzwfw.gov.cn:443/services/wmts/imgmap/default/oss?service=WMTS\&request=GetTile\&version=1.0.0\&layer=imgmap\&style=default\&tilematrixSet=esritilematirx\&format=image%2Fjpgpng\&height=256\&width=256\&fullExtent=[object Object]\&tilematrix={z}\&tilerow={y}\&tilecol={x}\&token=申请的token'

影像标注地址为:

'https://ditu.zjzwfw.gov.cn:443/services/wmts/emap_lab/default/oss?service=WMTS\&request=GetTile\&version=1.0.0\&layer=imgmap\&style=default\&tilematrixSet=esritilematirx\&format=image%2Fjpgpng\&height=256\&width=256\&fullExtent=[object Object]\&tilematrix={z}\&tilerow={y}\&tilecol={x}\&token=申请的token'

其他的服务同理

2. 行政边界获取

const getData =async (name) => {

const res = await fetch('https://ditu.zjzwfw.gov.cn/ime-server/rest/xzqh_zj/division/search?withgeometry=true\&token=申请的token\&withparents=false\&fullname=' + name)

.then(resp => resp.json())

return res

}

getData('浙江省杭州市')

3. 行政边界数据处理

获取的数据为wkt 格式,需要使用gis小工具 wicket

wicket 使用cdn或npm 下载

javascript 复制代码
// 使用npm下载
import Wkt from 'wicket'

const wkt = new Wkt.Wkt()

// item.GEOMETRY 为 wkt字符串
const geometry = wkt.read(item.GEOMETRY).toJson()

4. 行政区划查询(正向、逆向)

javascript 复制代码
// 正向
const searchData =async (name) => {
  const res = await fetch('https://ditu.zjzwfw.gov.cn/ime-server/rest/xzqh_zj/division/search?callback=showresult&v=2&token=申请的token&fullname=' + name)
      .then(resp => resp.json())

  return res
}

searchData('浙江省杭州市')


// 逆向
const searchRgeo =async (lnglat:{
  lon: number,
  lat: number
}) => {
  const res = await fetch(`https://ditu.zjzwfw.gov.cn/ime-server/rest/xzqh_zj/division/rgeo?lon=${lnglat.lon}&lat=${lnglat.lat}&token=申请的token`)
      // .then(resp => resp.json())

  return res
}

  searchRgeo({
    lat: 30.25961,
    lon: 120.13026
  })
相关推荐
RadiumAg14 分钟前
记一道有趣的面试题
前端·javascript
yangzhi_emo18 分钟前
ES6笔记2
开发语言·前端·javascript
yanlele34 分钟前
我用爬虫抓取了 25 年 5 月掘金热门面试文章
前端·javascript·面试
烛阴2 小时前
void 0 的奥秘:解锁 JavaScript 中 undefined 的正确打开方式
前端·javascript
初遇你时动了情2 小时前
腾讯地图 vue3 使用 封装 地图组件
javascript·vue.js·腾讯地图
dssxyz2 小时前
uniapp打包微信小程序主包过大问题_uniapp 微信小程序时主包太大和vendor.js过大
javascript·微信小程序·uni-app
ohMyGod_1235 小时前
React16,17,18,19新特性更新对比
前端·javascript·react.js
@大迁世界5 小时前
第1章 React组件开发基础
前端·javascript·react.js·前端框架·ecmascript
一瓣橙子5 小时前
7.7日 实验03-Spark批处理开发(2)
开发语言·javascript·ajax
Hilaku5 小时前
从一个实战项目,看懂 `new DataTransfer()` 的三大妙用
前端·javascript·jquery