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
  })
相关推荐
郭优秀的笔记6 分钟前
html鼠标悬浮提示功能
android·javascript·html
冰暮流星14 分钟前
if与switch的区分
javascript
2501_9447114327 分钟前
React性能优化相关hook记录:React.memo、useCallback、useMemo
javascript·react.js·性能优化
梦65038 分钟前
Vue 中 v-for 与 v-if 优先级
前端·javascript·vue.js
摘星编程1 小时前
在OpenHarmony上用React Native:MapView路线规划
javascript·react native·react.js
木易 士心1 小时前
Vue 响应式数据失效全解析:从原理机制到工程实践
前端·javascript·vue.js
AC赳赳老秦1 小时前
ELK栈联动:DeepSeek编写Logstash过滤规则与ES日志分析逻辑
运维·前端·javascript·低代码·jenkins·数据库架构·deepseek
忠实米线1 小时前
使用lottie.js播放json动画文件
开发语言·javascript·json
Marshmallowc1 小时前
React页面刷新数据丢失怎么办?彻底掌握LocalStorage持久化与状态回填的最佳实践
前端·javascript·react.js
郝学胜-神的一滴1 小时前
Vue国际化(i18n)完全指南:原理、实践与最佳方案
前端·javascript·vue.js·程序人生·前端框架