UTM坐标与wgs84坐标转换关系

类定义 需要安装Proj

#ifndef PROJECTION_H
#define PROJECTION_H

// #include <projects.h>
#define ACCEPT_USE_OF_DEPRECATED_PROJ_API_H
#include <proj_api.h>

class Projection
{
private:
    projPJ m_pj_wgs84;  //球体:wgs84、投影:经纬度投影
    projPJ m_pj_utm;    //球体:wgs84、投影UTM
    int m_nUTMZone;     //utm带号
    bool m_bNorth;      //是否为北半球

public:
    Projection();
    ~Projection();
    bool wgs84ToUTM(const double dLongi, const double dLati, double &dX, double &dY);
    bool utmToWgs84(const double dX, const double dY, double &dLongi, double &dLati);

};

#endif // PROJECTION_H
#include <iostream>
#include <string>
using namespace std;

Projection::Projection():
    m_nUTMZone(-10000), m_bNorth(false), m_pj_utm(NULL)
{
    const char *wgs84 = "+proj=longlat +datum=WGS84 +no_defs ";//GPS所用坐标系,EPSG:4326
    m_pj_wgs84 = pj_init_plus(wgs84);
}
Projection::~Projection()
{
    if(m_pj_utm != NULL)
    {
        pj_free(m_pj_utm);
        m_pj_utm = NULL;
    }
    if(m_pj_wgs84 != NULL)
    {
        pj_free(m_pj_wgs84);
        m_pj_wgs84 = NULL;
    }
}
/**
* function:经纬度转为UTM坐标
* input:经度,维度,x轴,y轴
*/
bool Projection::wgs84ToUTM(const double dLongi, const double dLati, double &dX, double &dY)
{
  
    int nUTMZone = (int)((dLongi+186.0)/6.0);
    bool bNorth = dLati > 0 ? true : false;    
    if(m_nUTMZone != nUTMZone || m_bNorth != bNorth)
    {
        //"+proj=utm +zone=50 +datum=WGS84 +units=m +no_defs";
        // "+proj=utm +zone=48 +south +datum=WGS84 +units=m +no_defs"
        std::string qstrUTM = "+proj=utm +zone=" + std::to_string(nUTMZone);
        if(!bNorth)
        {
            qstrUTM += " +south ";
        }
        qstrUTM += " +datum=WGS84 +units=m +no_defs";
        if(m_pj_utm != NULL)
        {
            pj_free(m_pj_utm);
            m_pj_utm = NULL;
        }
        string strUTM = qstrUTM;
        const char *pUTM = strUTM.c_str();

        m_pj_utm = pj_init_plus(pUTM);
        

        m_nUTMZone = nUTMZone;
        m_bNorth = bNorth;
    }
    dX = dLongi * DEG_TO_RAD;
    dY = dLati * DEG_TO_RAD;
    pj_transform(m_pj_wgs84, m_pj_utm, 1, 1, &dX, &dY, NULL);

    return true;
}
/**
* function:UTM坐标转为经纬度
* input:x轴,y轴,经度,维度
*/
bool Projection::utmToWgs84(const double dX, const double dY, double &dLongi, double &dLati)
{
    if(m_pj_utm == NULL)
    {
        return false;
    }
    dLongi = dX;
    dLati = dY;
    pj_transform(m_pj_utm, m_pj_wgs84, 1, 1, &dLongi, &dLati, NULL);
    dLongi = dLongi * RAD_TO_DEG;
    dLati = dLati * RAD_TO_DEG;

    return  true;
}
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: WGS84坐标系UTM坐标系是两种常用的地理坐标系WGS84坐标系是一种大地坐标系,它使用地心坐标系(ECEF)表示地球表面上的点,通常使用经纬度和海报高度来描述这些点。UTM坐标系是一种地方坐标系,它使用平面直角坐标系来描述地球表面上的点,通常使用横坐标和纵坐标来描述这些点。 在C语言中,可以使用空间参考系转换库(如 PROJ.4)来实现WGS84坐标系UTM坐标系之间的转换。 PROJ.4是一个开源库,可以用于地理信息系统(GIS)和其他应用程序中的空间参考系转换。使用 PROJ.4 库时,需要先安装 PROJ.4 库并包含 proj_api.h 头文件。 下面是使用 PROJ.4 库将WGS84坐标转换UTM坐标的示例代码: ``` #include <stdio.h> #include <proj_api.h> int main() { // 定义 WGS84 坐标系UTM 坐标系的投影参数 projPJ wgs84, utm; // 初始化 WGS84 坐标系的投影参数 wgs84 = pj_init_plus("+proj=longlat +ellps=WGS84 +datum=WGS84 +no_defs"); // 初始化 UTM 坐标系的投影参数 utm = pj_init ### 回答2: WGS84坐标UTM坐标是两种常用的地理坐标系统,用于描述地球上不同位置的点。由于其使用范围广泛,相互之间的转换在地理信息系统和空间数据处理中非常重要。下面将用C语言实现WGS84坐标UTM坐标的相互转换。 首先,我们需要定义一些公式和常数来处理坐标转换。这些公式和常数可以在WGS84UTM坐标系统的文档中找到。 对于从WGS84坐标转换UTM坐标,我们可以使用以下步骤: 1. 根据经度计算所属的UTM带号,可根据给定的经度范围进行判断。 2. 根据WGS84坐标的纬度计算相应的UTM纬度带,例如北半球为奇数带号,南半球为偶数带号。 3. 计算在该UTM带下的中央经度,即该带号的中心经线。 4. 计算WGS84坐标的纬度与中央经线之间的差异,称为Δλ。 5. 使用公式计算UTM坐标的东北位移。 对于从UTM坐标转换WGS84坐标,我们可以使用以下步骤: 1. 根据UTM带号计算中央经度。 2. 根据UTM纬度带和给定的UTM带号范围,判断坐标位于北半球还是南半球。 3. 根据UTM坐标的纬度与中央经线之间的差值,得到纬度。 4. 根据公式计算经度。 以上是WGS84坐标UTM坐标相互转换的一般步骤,具体的C语言代码实现需要参考相关的数学公式和算法。可以通过搜索相关的代码库或开源项目,找到已经实现了这些功能的代码,并根据自己的需求进行调整和使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值