许可优化
许可优化
产品
产品
解决方案
解决方案
服务支持
服务支持
关于
关于
软件库
当前位置:服务支持 >  软件文章 >  基于esri-leaflet插件和Proj4.js加载ArcGIS独立坐标系服务的方法

基于esri-leaflet插件和Proj4.js加载ArcGIS独立坐标系服务的方法

阅读数 14
点赞 0
article_banner


基于esri-leaflet插件和Proj4.js加载arcgis独立坐标系的服务


需求的产生

目前, 项目  需要基于arcgis服务和leaflet进行开发,由于leaflet官方的网站不能较好的支持独立坐标系(也可以称为地方坐标系或者投影坐标系),所以需要利用proj4.js和proj4leaflet.js进行坐标转换。

资料收集和技术调研

首先,调研了proj4.js的使用方式,主要是弄明白 坐标系  中的各种参数的含义和在proj4中的定义,例如中央子午线,北方向和东方向的偏移值,投影类型等,详细的文档和说明我会放到后面的参考资料中。同时我也参考了三篇博客,吸纳了这三篇博客中的对我有用的内容。

arcgis   service wkt 格式简单介绍

以下是拿我测试的服务的坐标系进行举例,可能与你们实际开发的有出入,但是大部分应该都包括坐标系的基本信息。另外,需要说明的是,由于该参数可能涉密,故本例中的参数均为修改后的参数。具体介绍如下图所示。
arcgis 服务wkt格式参数介绍

代码编写

介绍了这么多,大家可能最关心也就是这里了,毕竟代码作为开发来说是最重要的解决方案。

1.引入leaflet的 地图  框架和esri-leaflet框架,包括相关的css和js等文件,这里不在详述。

<link rel="stylesheet" href="leaflet/leaflet.css" />
<script type="text/javascript" src="leaflet/leaflet.js"></script>
<script type="text/javascript" src="leaflet/esri-leaflet.js"></script> 

2.引入proj4.js和proj4leaflet.js文件

<script type="text/javascript" src="leaflet/proj4.js"></script>
<script type="text/javascript" src="leaflet/proj4leaflet.js"></script>

3.根据wkt格式的服务定义出转换 字符串  

这里是最重要的步骤,我们可以根据上述图片的wkt服务定义出独立坐标系的转换字符串。(另外需要补充的是,我看网上有人介绍了自动转换的,但是我发现那个上传接口会报500的错误,所以没有直接获取到转换字符串,具体网址是:https://epsg.io/,有兴趣的小伙伴可以自己试试。)

var transformStr = "+proj=tmerc +lat_0=0 +lon_0=131.46 +k=1 +x_0=42100 +y_0=5000.0 +ellps=GRS80 +units=m +no_defs"

需要说明的是这些参数均在proj4官网可以找到,还有也可以从这篇博客【ArcGIS的.prj文件生成proj4格式的字符串】上可以找到相对应的参数,由于本人也是短时间看。没能对所有的参数名和参数值有较深的了解,喜欢的研究的小伙伴可以看看官方文档。

4.最后一句就是创建Map并加载地图就可以了

var crs = new L.Proj.CRS("EPSG:test2000",//这里随意定义一个新的坐标系名称,这里是以加载切片服务为例子
	transformStr , {
		origin: [-10000, 9998], // 这里可以从arcgis服务里面拿到
		resolutions: [ // 服务里 复制出所有的层级
			80,
			40,
			20,
			10,
			5,
			2.5,
			1.25,
			0.625,
			0.3125,
		]
	});
	
	//初始化地图
	var initLevel = 0; //初始地图显示等级
	var map = L.map('map', {
		maxZoom: 10,
		minZoom: 0,
		crs: crs,
		// zoomControl: false,
		// bounceAtZoomLimits: false,
		// preferCanvas: true
	}).setView([32, 131.6], initLevel);
	
	//加载切片服务(作为底图)
	L.esri.tiledMapLayer({
		url: mapurl.ele_test,
		continuousWorld: true
	}).addTo(map);
	
	//加载要素服务(作为专题图)
	L.esri.tiledMapLayer({
	  url: mapurl.feature_test_url,
	  continuousWorld: true
    }).addTo(map);

实现的效果

如下图所示,大功告成了!!!
在这里插入图片描述

存在的问题

需要说明的一点,经过我测试的点击识别的效果,属性查询显示的坐标不是独立坐标系的坐标,而是 经纬度  ,我个人理解是,这个proj4.js和proj4leaflet.js是将所有独立坐标系转换到地理坐标系了。但是,坐标值虽然和正常思路不同,但不影响地图正常的功能。以上就是,博客的全部内容,如果有内容上的错误,欢迎各位大佬提出,指正。

参考资料  

1.leafet官网:https://leafletjs.com/

   2.proj4的参考文档:https://proj.org/about.html

   3.参考的另外两篇博客:

   [1] 彻底理解Leaflet之 L.CRS + 搞定Leaflet多坐标系拓展

   [2] leaflet.js/proj4.js自定义坐标系及使用
免责声明:本文系网络转载或改编,未找到原创作者,版权归原作者所有。如涉及版权,请联系删

相关文章
技术文档
QR Code
微信扫一扫,欢迎咨询~
customer

online

联系我们
武汉格发信息技术有限公司
湖北省武汉市经开区科技园西路6号103孵化器
电话:155-2731-8020 座机:027-59821821
邮件:tanzw@gofarlic.com
Copyright © 2023 Gofarsoft Co.,Ltd. 保留所有权利
遇到许可问题?该如何解决!?
评估许可证实际采购量? 
不清楚软件许可证使用数据? 
收到软件厂商律师函!?  
想要少购买点许可证,节省费用? 
收到软件厂商侵权通告!?  
有正版license,但许可证不够用,需要新购? 
联系方式 board-phone 155-2731-8020
close1
预留信息,一起解决您的问题
* 姓名:
* 手机:

* 公司名称:

姓名不为空

姓名不为空

姓名不为空
手机不正确

手机不正确

手机不正确
公司不为空

公司不为空

公司不为空