GPS坐标转换

113 篇文章 179 订阅

前段时间,工作需要学习了一下GPS的坐标转换,发现这个转换过程不算难,但就是概念很容易混淆,结果无论是上网查资料,还是问一些资深人士,都能碰到或多或少的一些概念上的错误。

    经过一段时间的学习,综合了不少资料,我终于搞明白了其中的道理,不敢独享,决定写出来让大家批判一下,希望对大家有所帮助,同时也希望如果各位发现我的错误,也及时通知我。

    说到转换,我不得不先提几个概念:

1.     84坐标系――美国的GPS就用这个坐标系,也就是说我们从GPS接收过来的地心大地坐标就是在这个坐标系下的;

2.     54坐标系――中国常用的坐标系,一般来说,我们就是要得到该坐标系下的平面直角坐标;

3.     地心大地坐标――就是经纬度表示的大地位置数据(B、L、H);

4.     地心直角坐标--是以地心为原点,但表示方式采样直角坐标(X、Y、Z);

5.     平面直角坐标――不用多解释了,就是我们平常用来表示位置的坐标(x、y、z);

6.     椭球参数――地心大地坐标转换到地心直角坐标需要使用的参数;

7.     七参数――不同椭球系下的地心直角坐标互换所使用到的参数;

8.     投影参数――同一椭球系下,地心大地坐标转换为平面直角坐标所使用的参数;

9.     四参数――同一椭球系下,不同平面坐标系之间的转换所使用的参数。

    有了以上概念,只要知道转换过程就OK了。下面我就不罗嗦了,直接用方向线来说明过程,其中我以常用的北京54坐标系作为目标坐标系:

从GPS中接收到84坐标系下的地心大地坐标

使用84坐标系的椭球参数转换为84坐标系下的地心直角坐标

使用七参数转换为54坐标系下的地心直角坐标

使用54坐标系的椭球参数转换为54坐标系下的地心大地坐标

使用投影参数转换为54坐标系下的平面直角坐标

使用四参数转换为其它区域坐标系下的平面直角坐标

上一章已经简单说明了各坐标系的基本概念和相互的转换关系(其实也不叫学习笔记了,所有转换都做完了,只是一直在忙,没有时间一次写完,只能有时间就写一章,一点一点来,实在愧对关注的朋友)。

    这一章就说一下84坐标系下的地心大地坐标如何使用84坐标系的椭球参数转换为84坐标系下的地心直角坐标(好拗口……)。

    先来看看84坐标系的椭球参数:

        椭圆长半径A:6378137.000000

        椭圆短半径B:6356752.314245179497

    根据椭圆长短半径,我们很容易就能算出椭圆第一偏心率e1,计算公式如下:

       e1 = sqrt(A×A-B×B)/ A;

    注意这里sqrt是开方的意思。

    OK,上面我们通过一个简单的公式就计算出了椭圆的第一偏心率e1,下面,我们就利用这个参数把地心大地坐标转换为地心直角坐标。

    已知:B、L、H地心大地坐标

    求:X、Y、Z地心直角坐标

    计算步骤:

1.参数N:N=A/sqrt(1-e1×e1×sin(B)×sin(B));

2.X:X=(N+H)×cos(B)×cos(L);

3.Y:Y=(N+H)×cos(B)×sin(L);

4.Z:Z=(N×(1-e1×e1)+H)×sin(B);

    好了,就是这么简单,BLH方式表示的大地坐标一下就转换为XYZ表示的直角坐标了。不过大家要注意的是,就是BL这两个数值是角度值,在C编程中,cos和sin函数要用弧度值,这个角度转换问题要注意。 

上次说到在84坐标系下如何利用84坐标系的椭球参数把地心大地坐标转换为地心直角坐标。有了84坐标系下的地心直角坐标就可以考虑如何得到54坐标系下的地心直角坐标了(不一定是54坐标系,不过为了描述方便,我选了54坐标系而已)。

    所以这次就讲解一下如何把84坐标系下的地心直角坐标转换成54坐标系下的地心直角坐标。

    转换的方法有很多,但常用的是七参数法,这个方法还有一个外文翻译过来的名称,但我现在忘记了,也懒得追查,反正是一种空间转换方法,顾名思义,需要七个参数才能进行转换,七个参数分别是:

△X △Y △Z——三个坐标方向的平移参数;

αβγ——三个方向的旋转角参数

k——尺度参数

这七个参数不是固定的,而是不同的地区有不同数值,知道的当然可以直接填写,不知道的一般就会找几个已知地方坐标的位置获取GPS采集的坐标再反算这七个参数,如何反算以后我再写。

闲话少说,有了七参数后,把84坐标系下的地心直角坐标转换成54坐标系下的地心直角坐标的计算方式是:

    已知:84坐标系下的地心直角坐标x,y,z

    求:54坐标系下的地心直角坐标X、Y、Z

       X = △X + k*x - β*z + γ*y + x

    Y = △Y + k*y + α*z - γ*x + y

    Z = △Z + k*z - α*y + β*x + z

    公式是推导的,倒没有什么特别,主要是里面的计算单位不要弄错,角度就肯定是弧度的,你别用了角度之类的单位,而那个k的尺度参数单位是ppm,一般坐标都是m为单位,所以k还有除以1000000才能参与计算。

GPSTool4.0(GPS工具箱) 操作说明 一、 总体介绍 本软件为GPS坐标转换工具(并具有线路设计的功能),程序分为标题栏(程序名称及版本号)、状态栏(输入提示及当前时间)、信息栏(提示打开及新建的工程名)、操作面板(转换操作输入),程序总体分为三大功能:单点转换、文件转换、线路设计。 无论做哪种操作,首先要新建项目,保存项目数据,详细的数据格式如下: [Version Information] Version=May 12 2006 [TouYin Par] nsCoord=2        ;源椭球 nCoord=2 ;目标椭球 nTouYin=0 ;投影类型 nDifang=0 ;是否使用四参数 nSevenPar=0 ;是否使用七参数 szdDa=6378137.0000000000 ;目标椭球长半轴 szdDf=298.2572235630   ;目标椭球扁率 szdDa1=6378137.0000000000;源椭求长半轴 szdDf1=298.2572235630 ;源椭球扁率 szdCenter=108.00000000 szlTx=0.000 szlTy=500000.000 szdTk=1.00000000 szdHigh=0.00000000 szdTlon=0.00000000 szdCenter1=114.0 szlTx1=0.000 szlTy1=500000.000 szdTk1=1.00000000 szdHigh1=0.00000000 szdTlon1=0.00000000 [Seven Par] szddx=0.000000000000 szddy=0.000000000000 szddz=0.000000000000 szdWx=0.000000000000 szdWy=0.000000000000 szdWz=0.000000000000 szddK=0.00000000000000000000 [Four Par] szdCx1=0.000000000000 szdCy1=0.000000000000 szdCa1=0.000000000000 szdCk1=0.000000000000 szdCx2=0.000000000000 szdCy2=0.000000000000 szdCa2=0.000000000000 szdCk2=0.000000000000 [Base Coordinate] szdBaseX=2558700.60750000 szdBaseY=435101.83010000 szdBaseH=45.00000000 nBLH=0 nRadioFormat=0 szdBaseAntH=1.20000000 nRadioRate=1 nUseCorr=0 szdCorrX=0.000000000000 szdCorrY=0.000000000000 szdCorrH=0.000000000000 [Nihe Par] nUseNihe=0 szA0=-2.500000000000 szA1=0.000000000000 szA2=0.000000000000 szA3=0.000000000000 szA4=0.000000000000 szA5=0.000000000000 szX0=100.000000000000 szY0=100.000000000000 [Job Par] Ellipsoid=2,2 ;源椭球,目标椭球 AngleType=0 ;角度类型 ConvertType=1 ;转换类型,是否是换带计算 DataType=0,2 ;数据类型 Change=0,114.00000000,114.00000000 ;转换前与转换后的中央子午线 SourcePoint=-1690039.93800000,5555519.86900000,2631658.92700000  ;源数据 TargetPoint=2713845.99600000,390578.41800000,917.25700000 ;目录数据 SourceFilename=6,D:\Documents and Settings\southgps\桌面\22.txt ;源格式,文件名 TargetFilename=1,D:\Documents and Settings\southgps\桌面\888.dat    ;目标,文件名 OutputFormat=0 OutputTitle=GpsTool 工具软件坐标转换成果表 最小化程序时,系统隐藏,双击任务栏图标即可最大化。 二、 单点转换 1、 新建工程中或打开工程 2、 选择源椭球与目标椭球,可以选择相同的椭球。 3、 选择投影方式 4、 选择源数据类型与目标数据类型。 共有三种数据格式:空间格式、大地格式、投影格式 5、 输入起算数据,进行数据格式转换 三、 文件转换      起始设置同单点转换的前四项,除此以外还有: 1、 新建格式 输入数据格式名称,文件扩展名,文件格式描述,数据分隔符等,      可以选择的数据项有:点名、纬度、经度、椭球高、北方向X、东方向Y、水准高、空间X、空间Y、空间Z、其它。       选择添加按钮添加数据项,删除最后数据项,清除所有数据项,添加完毕后完成创建,如果继续新建格式,选择新建格式。 2、 文件选择 从列表框中选择格式,并确认选择,在此框中可以删除格式与编辑格式,编辑格式对话框如下: 文件选择: 选择完数据文件名及数据格式后,开始转换,如果因为数据格式转换不成功,请查看数据格式是否正确,请确认源转换类型与目标转换类型与数据格式中的数据项相匹配。 如果查看数据内容请按 >> 四、 线路设计 1、元素模式 1、 新建或打开线路文件 2、 输入起始桩号。 3、 对线路进行添加元素,起点必须以点元素开始,直线相接,除点和直线外,线路中还可包括圆曲、缓曲。 4、 对线路进行保存并计算,查看线路图形。 5、 根据选择整桩距或整桩号生成中桩坐标文件:线路同名.dat文件,除此以外还可以通过COGO模拟线路的投影桩号及偏线距。 2、交点模式 图形输出如元素模式。 1、 建或打开线路文件 2、 输入起始桩号。 3、 对线路进行添加交点元素,左、右缓曲长可以相同,可以不同,当然也可以为零。  4、 对线路进行保存并计算,查看线路图形。 5、 根据选择整桩距或整桩号生成中桩坐标文件:线路同名.dat文件,除此以外还可以通过COGO模拟线路的投影桩号及偏线距。 五、 其它功能  1、 换带计算  输入换带后的投影参数,主要是换带后的中央子午线经度,此时计算为投影坐标到投影坐标的计算,主要是先由投影坐标到大地坐标,再由新的投影参数投到换带后的投影坐标。 2、参数计算:四参数计算、七参数计算、拟合参数计算 提供简单的参数计算功能。 四参数主要应用于地方坐标转换。 七参数主要应用于椭球之间的变换。本程序为避开投影,与国外软件相同只使用大地坐标进行变换参数。 拟合参数计算主要应用于根据大地高及相关联的水准高计算曲面拟合参数,基中包括两个辅助参数,X中数和Y中数。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值