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

解决基于VectorGrid的矢量瓦片Y轴偏移的问题

目录

前言

 一、GeoServer的瓦片

1、GeoWebcache缓存配置

 2、矢量瓦片本地缓存

3、瓦片访问

二、VectorGrid加载本地瓦片

1、加载关键代码

2、默认模式的问题

 3、问题分析

4、tms参数修改

 总结


前言

        在前面的博文介绍中,在线连接如下:浅谈前端自定义VectorGrid矢量瓦片样式,基于VectorGrid加载GeoServer发布的矢量瓦片实例,这里介绍了在Leaflet中加载矢量瓦片,也支持样式的定制。这里采用的矢量瓦片是使用GeoServer发布出来的,而且在GeoServer中是用的900913的gridset。使用GeoServer是一种不错的解决方案,但是无疑要引入一个新的组件,如果容易存在访问瓶颈。因此,跟栅格瓦片的原理一样,我们是否可以类似于栅格瓦片的原理,直接访问已经生成好的矢量瓦片,来进行访问加速。

        使用GeoServer瓦片存在几个问题,一个是瓦片访问性能依赖于GeoServer。在进行架构扩展时不太方便。在GeoServer发布的矢量瓦片请求格式跟Google的xyz瓦片访问不太一致,有一点点儿小复杂。在此背景下,我们尝试使用将矢量瓦片直接瓦片化,然后再使用VectorGrid进行展示,但是发现,使用自己切好的矢量瓦片的加载方式跟GeoServer发布的矢量瓦片,加载出来的效果不一致,Y轴出现了偏移。

        本文将重点讲解,如何使用VectorGrid加载自己切好的矢量瓦片,同时解决其出现的Y轴偏转的问题,如果您在项目开发过程中也出现这个问题,可以从这篇博客中找到解决办法。

 一、GeoServer的瓦片

1、GeoWebcache缓存配置

        众所周知,在GeoServer甚至很多的应用系统当中,使用缓存来进行应用访问加速是常规的做法,也是很有效的方式。在gis中,缓存的使用就更频繁了。通过空间换时间,效率得到了很大的提升。首先在GeoServer中打开配置页面,查看GeoWebcache的详细位置,在地址栏中输入:

http://localhost:8083/geoserver/gwc/

        然后可以看到以下的配置页面:

 大家可以把页面拉倒最下面,有cache的配置说明:

 2、矢量瓦片本地缓存

        在上面看到的访问地址中,将地址复制下来,然后在windows的资源管理器中打开,如下:

C:\Users\Administrator\AppData\Local\Temp\geowebcache

        这里可以看到经过页面发布后的900913的矢量瓦片。注意,Geoserver的缓存生成规则是必须由前台发起访问,后台才会进行缓存。因此,如果第一次没有看到缓存,请先打开页面进行访问,访问方法可以参考之前的博客。 

3、瓦片访问

        通过查看上面的瓦片发布地址可以看到,其瓦片的pbf访问路径与常见的xyz瓦片不一致。我们来看一下xyz矢量瓦片路径规则,示意参考如下:

         这种路径跟常见的栅格瓦片就是一样的了,可以采用同样的加载规则进行初始化。

二、VectorGrid加载本地瓦片

1、加载关键代码

        关于如何在VectorGrid中加载本地矢量瓦片,在之前的博文中有一定叙述,这里将关键代码贴一下:

var vectorTileOptions = {layerURL: pbfUrl,rendererFactory: L.canvas.tile,           tms: true, interactive: true,	//开启VectorGrid触发mouse/pointer事件vectorTileLayerStyles: vectorTileStyling};      var vectorTile = new L.vectorGrid.protobuf(pbfUrl, vectorTileOptions).addTo(map)vectorTile.on('mouseover', function (e) {    var properties = e.layer.properties;    L.popup().setContent(properties.province_c+";" + properties.province_n ).setLatLng(e.latlng).openOn(map);  });

2、默认模式的问题

        经过上述配置后,在浏览器中查看运行的效果,我们发现实际的效果跟我们的期望还是有一定差异的,准确来说。是矢量瓦片叠加后,整个Y轴反转了,如下图:

 3、问题分析

        在gis中,通过观察地图的偏移位置,大致可以猜测出来问题的所在,在这里可以看到。X轴(经度)几乎是一致的,没有偏移。偏移的Y轴(纬度),由此很容易联想到Y轴的为止变换。

这里我们先来看一下VectorGrid中,对于y轴参数控制的说明,源文件:

Leaflet.VectorGrid.Protobuf.js

打开之后,我们找到Y轴控制的方法:_getVectorTilePromise

_getVectorTilePromise: function(coords, tileBounds) {var data = {s: this._getSubdomain(coords),x: coords.x,y: coords.y,z: coords.z
// 			z: this._getZoomForUrl()	/// TODO: Maybe replicate TileLayer's maxNativeZoom};if (this._map && !this._map.options.crs.infinite) {var invertedY = this._globalTileRange.max.y - coords.y;if (this.options.tms) { // Should this option be available in Leaflet.VectorGrid?data['y'] = invertedY;}data['-y'] = invertedY;}if (!this._isCurrentTile(coords, tileBounds)) {return Promise.resolve({layers:[]});}xxx
}

这里有一句话很重要:

if (this.options.tms) { // Should this option be available in Leaflet.VectorGrid?

就是这个配置引起的,默认情况下tms为true,所以y轴进行了处理。而默认情况是通过tms加载的,本地直接加载的方式并不是,因此我们要将tms标志设置为false。

4、tms参数修改

        在知道了问题所在之后,我们再来修改初始参数配置:

var vectorTileOptions = {layerURL: pbfUrl,rendererFactory: L.canvas.tile,           tms: false, //本地加载设为falseinteractive: true,	//开启VectorGrid触发mouse/pointer事件vectorTileLayerStyles: vectorTileStyling};

然后再刷新来看一下实际的效果:

 可以看到,矢量瓦片和底图就完美的贴合了,没有任何偏移。至此,Y轴偏移的问题解决。

 总结

        以上就是本文的主要内容,本文将重点讲解,如何使用VectorGrid加载自己切好的矢量瓦片,同时解决其出现的Y轴偏转的问题,如果您在项目开发过程中也出现这个问题,可以从这篇博客中找到解决办法。

相关文章:

  • 软件有效找不到dll文件,五种可靠的解决dll方法分享
  • Zookeeprt实战(待完善)
  • java虚拟机内存管理
  • 最新版本Vue3的学习笔记-第五章
  • java 内部错误2753_内部错误 2753.regutils.dll
  • LLM之RAG实战(九)| 高级RAG 03:多文档RAG体系结构
  • webrtc turn服务器搭建
  • leetcode 75. 颜色分类(medium)(优质解法)
  • 每日一练:LeeCode-347. 前 K 个高频元素(中) - 【优先级队列】
  • docker-compose Install TeamCity
  • git教程——日常工作git使用流程
  • Android Matrix画布Canvas旋转Rotate,Kotlin
  • Xcode 编译速度慢是什么原因?如何提高编译速度?
  • 太阳系三体模拟器
  • PHP序列化总结1--序列化和反序列化的基础知识
  • -------------------- 第二讲-------- 第一节------在此给出链表的基本操作
  • 〔开发系列〕一次关于小程序开发的深度总结
  • 4月23日世界读书日 网络营销论坛推荐《正在爆发的营销革命》
  • Android框架之Volley
  • Javascript 原型链
  • Java新版本的开发已正式进入轨道,版本号18.3
  • MYSQL如何对数据进行自动化升级--以如果某数据表存在并且某字段不存在时则执行更新操作为例...
  • React Transition Group -- Transition 组件
  • React16时代,该用什么姿势写 React ?
  • redis学习笔记(三):列表、集合、有序集合
  • vue-cli在webpack的配置文件探究
  • 从零搭建Koa2 Server
  • 第2章 网络文档
  • 缓存与缓冲
  • 推荐一款sublime text 3 支持JSX和es201x 代码格式化的插件
  • ​马来语翻译中文去哪比较好?
  • # 数仓建模:如何构建主题宽表模型?
  • (12)目标检测_SSD基于pytorch搭建代码
  • (C#)Windows Shell 外壳编程系列9 - QueryInfo 扩展提示
  • (C语言)fread与fwrite详解
  • (Matlab)遗传算法优化的BP神经网络实现回归预测
  • (Python) SOAP Web Service (HTTP POST)
  • (二)hibernate配置管理
  • (附源码)spring boot网络空间安全实验教学示范中心网站 毕业设计 111454
  • (免费领源码)python+django+mysql线上兼职平台系统83320-计算机毕业设计项目选题推荐
  • (牛客腾讯思维编程题)编码编码分组打印下标(java 版本+ C版本)
  • (算法)大数的进制转换
  • (已更新)关于Visual Studio 2019安装时VS installer无法下载文件,进度条为0,显示网络有问题的解决办法
  • (原創) X61用戶,小心你的上蓋!! (NB) (ThinkPad) (X61)
  • (转)Java socket中关闭IO流后,发生什么事?(以关闭输出流为例) .
  • (自用)gtest单元测试
  • **PHP分步表单提交思路(分页表单提交)
  • .NET CORE 2.0发布后没有 VIEWS视图页面文件
  • .net core MVC 通过 Filters 过滤器拦截请求及响应内容
  • .NET 发展历程
  • .NET 服务 ServiceController
  • .NET 事件模型教程(二)
  • .Net(C#)自定义WinForm控件之小结篇
  • .NET下的多线程编程—1-线程机制概述
  • .考试倒计时43天!来提分啦!