PROJ.4学习——地图投影

PROJ.4学习——地图投影(坐标系投影)linux

前言git

  PROJ是由大量的基础投影库构成。这里主要讨论学习PROJ库的相关参数。windows

  这里大部分是讲如何将3D坐标系投影到2D平面上。投影时,涉及到基准线,单位,比例英子,偏移量,轴转换等。app

  不少实际操做中却涉及到3D坐标系转换为其余3D坐标系(下一篇更新)。工具

参数列表学习

  下面是能够应用于大多数坐标系定义的PROJ参数列表。此表不尝试描述特定于特定投影类型的参数。spa

 
参数 描述
 +a  椭球体长半轴长度
 +axis  轴防线
 +b  椭球体短半轴长度
 +ellps  椭球体名称,在cmd中输入:proj -le 查看支持哪些椭球体
 +k  比例系数(比例因子),旧版本,不同意使用
 +k_0  比例系数(比例因子)
 +lat_0  维度起点
 +lon_0  中央经线
 +lon_wrap  中央经线的包装参数(详见下面的说明)
 +no_defs

 不要使用proj库中的缺省定义文件。翻译

 在linux中路径为:/usr/share/proj/proj_def.dat3d

 windows中为安装路径下的:E:\SvnWorkspace\LY_WEB_GIS\branches\Documents\ms4w-mapserver-for-wimdows\release-1911-x64-gdal-2-3-3-mapserver-7-2-1\bin\proj\SHARE\proj_def.datcode

标红处是我安装MapServer是自带安装Proj的路径

 +over  容许经度输出在-180到180范围以外,禁用wrapping(详见下面的说明)
 +pm  备用本初子午线(一般是一个城市名称,见下文)
 +proj  投影名称,在cmd中输入:proj -l 查看数据支持
 +units  水平单位,meters(米)、 US survey feet, etc(英尺等 us-ft).
 +vunits  垂直单位
 +x_0  东(伪)偏移量
 +y_0  北(伪)偏移量
 

units

  可使用+units关键字指定水平单位,该关键字具备单位的符号名称(如:+units=us-ft)。另外换算单位米能够用+to_meter关键字(如:美国一英尺为0.304800609601219米)。

  在cmd中输入:  cs2cs -lu 或者 proj -lu 查看PROJ支持的单位。

  

  

  下面来了解一下 +to_meter 关键字的使用

#在cmd中输入:
cs2cs +proj=merc +lat_ts=56.5 +ellps=GRS80 +to +proj=utm +zone=32 +units=km
#再输入参数 1699741.9 376042.8
#获得 2594.43 715.50 0.00

#在cmd中输入:
cs2cs +proj=merc +lat_ts=56.5 +ellps=GRS80 +to_meter=0.5 +to +proj=utm +zone=32 +units=km
#再输入参数
3399483.80      752085.60
#获得
2594.43 715.50 0.00

 

  从两个命令比较,第二个增长了 +to_meter=0.5

  第二个参数范围是第一个的两倍

  可是投影出来的位置倒是同一个

  由于第二个在投影转换是,将1米转换为了0.5倍,即范围缩小了一半

  因此获得的结果是同样的

 

  一样,垂直单位可使用 +vunits 关键字。若是没有指定垂直单位,则垂直单位将默认与水平坐标相同。

  注意:proj根本不处理垂直单元,所以+vto_meter参数将被忽略。

  能够经过应用+k_0参数来缩放输出单元。返回的坐标(经纬度、米、公里等,按照定义的 +units 输出)按使用+k_0参数分配的值进行缩放。

#tmerc 横墨卡托高斯投影
proj +proj=tmerc +lat_0=0 +lon_0=-55.5 +k=0.9999 +x_0=304800 +y_0=0 +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +units=m +no_defs
#输入
12.2 -58.5
#获得
3664306.25      -8536230.41

 东北(伪)偏移量

  几乎全部的坐标系都容许存在一个假的东偏移 (+x_0)和一个假的北偏移 (+y_0)。请注意,这些值老是以米表示,即便坐标系是其余一些单位。有些坐标系(如UTM)具备隐式的假东向和北向值。

 经度覆盖/边界设置(Longitude Wrapping)

  我把Wrap翻译为覆盖或边界,也不知道准确与否。

  默认状况下,PROJ将输出经度覆盖/边界值在-180到180之间。可使用+over开关禁用在pj_inv()中较低级别执行的默认覆盖/边界。这对于等距圆柱投影特别有用,在等距圆柱投影中,X值通过-20000000(大体)后继续通过-180,而不是覆盖/边界到+180。

  可使用+lon_wrap选项在pj_transform()中提供一种进行经度边界设置的替代方法。此选项的参数是一个中心经度。因此+lon_wrap=180表示在0到360范围内的经度。注意+over不会禁用+lon_wrap。

本初子午线Prime Meridian

  本初子午线的定义是基于格林尼治的本初子午线与当前坐标系统本初子午线之间的偏移量定义的(格林尼治的本初子午线是基准,设置 +pm=经度偏移量 表示当前坐标系统的本初子午线;或者是一个符号名称)。

  如:EPSG:27500,它的本初子午线就是基于格林尼治的本初子午线加上西偏2.337208333333333构成

# ATF (Paris) / Nord de Guerre
<27500> +proj=lcc +lat_1=49.50000000000001 +lat_0=49.50000000000001 +lon_0=5.399999999999999 +k_0=0.99950908 +x_0=500000 +y_0=300000 +a=6376523 +b=6355862.933255573 +pm=2.337208333333333 +units=m +no_defs  <>

   再如:EPSG:27395,它的本初子午线就是一个符号定义

# NGO 1948 (Oslo) / NGO zone V
<27395> +proj=tmerc +lat_0=58 +lon_0=6.166666666666667 +k=1 +x_0=0 +y_0=0 +a=6377492.018 +b=6356173.508712696 +towgs84=278.3,93,474.5,7.889,0.05,-6.61,6.21 +pm=oslo +units=m +no_defs  <>

  当前子午线声明只被pj_transform() API利用,而不被pj_inv()和pj_fwd()利用。所以用户工具cs2cs遵照本初子午线参数,可是proj程序忽略它.

  在cmd中输入:cs2cs -lm 查询支持的本初子午线

  

  好比,使用的例子。在格林尼治基于lat/long坐标的位置long=0, lat=0被转换为以马德里为本初子午线的lat/long坐标。

#在cmd中输入:
cs2cs +proj=latlong +datum=WGS84 +to +proj=latlong +datum=WGS84 +pm=madrid
#输入参数
0 0
#获得
3d41'16.58"E    0dN 0.000

轴方向切换

  从PROJ 4.8.0开始,+axis参数可用于控制坐标系的轴向。默认的方向是“向东,向北,向上”,可是方向能够翻转,或者使用+axis开关中的轴的组合来翻转轴。值分别是:

  • "e" - Easting
  • "w" - Westing
  • "n" - Northing
  • "s" - Southing
  • "u" - Up
  • "d" - Down

  其组合格式以下:

  • +axis=enu easting,northing,up - 默认值。
  • +axis=neu northing,easting, up - 适用于“lat/long”地理坐标,或向南横向墨卡托。
  • +axis=wnu westing,northing,up - 有些具备“西正”坐标的行星坐标系。

   注意 +axis不适用与 proj 命令,只适用于 cs2cs 命令(3D投影到2D上面是不行的,只能是3D坐标系转其余3D坐标系)。

相关文章
相关标签/搜索