GNGGA 解析北斗数据获得经纬度 以及数据NMEA数据转换

char  GPS1[] = "$GNGGA,121252.000,3937.3032,N,11611.6046,E,1,05,2.0,45.9,M,-5.7,M,,0000*77";

int Parse_GPS(char *data,char * longtitude,char * latitude)
{
    int ret,temp;
    char* start, *tempStr;
    char *field;
   int index = 0;
    start = strstr(data,"GNGGA");

    if (start)
    {
        tempStr = strstr(start,"E");
        if (tempStr == NULL)
        {
            //return -1;
        }

        //*(tempStr - 1) = 0;

        field = strtok(start,",");

        while (field)
        {
            index++;
            printf("%s\n", field);
            field = strtok(NULL,",");
            if (index == 2)
            {
                strcpy(longtitude,field);
            }
            if (index == 4)
            {
                strcpy(latitude, field);
            }
        }
    }

    return 0;
}

int main(int argc, char *argv[])
{
	int ret;
	int port = -1;
    CHAR * server = (CHAR*)"N/A";
	if(argc == 2)
	{
		port = atoi(argv[1]);
		if(port >65535 || port <1)
		{
			printf("Port should between 1-65535!\n");
			return 0;
		}
	}


    char longtitude[100] = { 0 };
    char latitude[100] = { 0 };

    ret = Parse_GPS(GPS1, longtitude, latitude);

    printf("[%s----%s]\n", longtitude, latitude);
    char* temp = strstr(longtitude,".");
    char dummy1,dummy2;
    if (temp)
    {
        dummy1 = *(temp - 1);
        dummy2 = *(temp - 2);

        *temp = dummy1;
        *(temp - 1) = dummy2;
        *(temp - 2) = '.';
    }


    temp = strstr(latitude, ".");
    
    if (temp)
    {
        dummy1 = *(temp - 1);
        dummy2 = *(temp - 2);

        *temp = dummy1;
        *(temp - 1) = dummy2;
        *(temp - 2) = '.';
    }



	
    printf("[%s----%s]\n",longtitude, latitude);


    double f_long = atof(longtitude);
    double f_lati = atof(latitude);

    printf("[%f----%f]\n", f_long, f_lati);

    return 0;

}

刚开始不知道 后来经过实测发现  gps模块直接读出来的数据 是需要转换的 

转换公式可以去看下gps的手册上一般会提供的

代码很简单 如下:

double longtitude = atof("11403.2467");
    double latitude = atof("2236.9142");


    double long1 = (int)(longtitude / 100) + fmod(longtitude, 100) / 60.0;

    double lati = (int)(latitude / 100) + fmod(latitude, 100) / 60.0;

不了解业务的前提下 写代码 就是 聪明反被聪明误!!!!!

  • 8
    点赞
  • 52
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

QMCY_jason

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值