Skip to content

这是一个通用的地理坐标系转换工具,基于七参数转换原理,实现了毫米级别的转换。如实现了WGS-84和XIAN80坐标系统之间的相互转化,经度的转换精度为小数点后7位,纬度的转换精度为小数点后6位,平面坐标的转换精度为毫米级别。

Notifications You must be signed in to change notification settings

zy693415/CoordSystemTransform--SevenParameterConversion

 
 

Repository files navigation

CoordSystemTransform使用说明

阿拉灯Aladeng

CoordSystemTransform

CoordSystemTransform这款工具由"阿拉灯Aladeng"编写,项目上传至Github分享,所有源码都可以下载和修改。CoordSystemTransform采用了七参数转换原理,对GIS中不同坐标系统中的坐标数据进行毫米级转换,转换精度相当高。当然,由于保密原因,七参数需要用户自己提供,七参数具体计算方法参照5分钟快速计算七参数。本项目中使用的七参数为测试数据,不是实际七参数。CoordSystemTransform将各个转换过程进行了分割,并将使用接口暴露出来,用户可根据需要自由组合转换过程,每个接口及参数在代码中都有详细注释。

效果截图

CoordSystemTransform效果截图

使用说明

  1. 引入库文件

    CoordSystemTransform工具由C++语言编写,只有两个文件,Trans.hTrans.cpp文件,只需将这两个文件引入项目中便可直接调用函数接口。

  2. 接口调用

    (1) 建立Trans对象

    Trans trans2(8.5, -28, -14.8888, -0.888, 1.9999, -3.1111, 4.22222, coord::XIAN80, coord::WGS84);

    (2) 坐标系转换

    //方法1
    Point result1 = trans2.plane2geodetic(Point(19348965.21, 2894958.496, 0), 6378140, 6356755.2882, 1 / 298.257, 6378137, 1 / 298.2572236, 6);
    //方法2
    Point result1_copy = trans2.plane2geodetic(Point(19348965.21, 2894958.496, 0), 6);
    //plane2geodetic重载了两种不同方法,具体说明请下载源码见注释
    //result1和result1_copy结果相同,都是最终的转换结果,任选其一即可

wgs84坐标系与西安80互相转换

  1. wgs84转西安80

    Trans trans(-8.5, 28, 14.8888, 0.888, -1.9999, 3.1111, -4.22222,coord::WGS84,coord::XIAN80);
    Point result_copy = trans.geodetic2plane(Point(108.635229183, 26.111425709, 0), 6);
  2. 西安80转wgs84

    Trans trans2(8.5, -28, -14.8888, -0.888, 1.9999, -3.1111, 4.22222, coord::XIAN80, coord::WGS84);
    Point result1_copy = trans2.plane2geodetic(Point(19348965.21, 2894958.496, 0), 6);

GIS坐标系扩展方法

目前,CoordSystemTransform只引入了XIAN80和WGS84两种类型的大地坐标系,如果你的坐标是其他坐标系的,可以通过扩展坐标系的方法扩展本项目。如果你有意愿对本项目进行扩展,请在github中Fork代码,并将修改发至本项目

  1. Trans.h的枚举类GEODETIC_COORD_SYSTEM中添加新的大地坐标系变量

    /**
     * 大地坐标系枚举类
    */
    enum GEODETIC_COORD_SYSTEM
    {
        XIAN80,
        WGS84
    };
  2. Trans.hEllipsoidParamArray数组中添加新大地坐标系对应椭球体的名称和参数(a,b,f)

    /**
    * 各个椭球体参数的数组 (大地坐标系名称,a,b,f)
    */
    static EllipsoidParam EllipsoidParamArray[] =
    {
    	{ "XIAN80", 6378140, 6356755.2882, 1 / 298.257 },//名称、长半轴、短半轴、扁率
    	{ "WGS84", 6378137, 6356752.314, 1 / 298.2572236 }
    };

    注意:步骤1和2添加的变量顺序要对应

PS

更多内容敬请关注 阿拉灯Aladeng

About

这是一个通用的地理坐标系转换工具,基于七参数转换原理,实现了毫米级别的转换。如实现了WGS-84和XIAN80坐标系统之间的相互转化,经度的转换精度为小数点后7位,纬度的转换精度为小数点后6位,平面坐标的转换精度为毫米级别。

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 100.0%