VC++实现GPS全球定位系统定位数据的提取
来源:MCUBLOG   作者:未知
字体大小:[大][中][小]

  引言

  卫星导航技术的飞速发展已逐渐取代了无线电导航、天文导航等传统导航技术,而成为一种普遍采用的导航定位技术,并在精度、实时性、全天候等方面取得了长足进步。现不仅应用于物理勘探、电离层测量和航天器导航等诸多民用领域,在军事领域更是取得了广泛的应用--在弹道导弹、野战指挥系统、精确弹道测量以及军用地图快速测绘等领域均大量采用了卫星导航定位技术。有鉴于卫星导航技术在民用和军事领域的重要意义,使其得到了许多国家的关注。我国也于2000年10月31日和12月21日成功发射了第一颗和第二颗导航定位试验卫星并建立了我国第一代卫星导航定位系统--"北斗导航系统",但由于起步晚也没有得到广泛应用。目前在我国应用最多的还是美国的GPS系统。本文就针对当前比较普及的GPS系统,对其卫星定位信息的接收及其定位参数提取的实现方法予以介绍。

  定位信息的接收

  通常GPS定位信息接收系统主要由GPS接收天线、变频器、信号通道、微处理器、存储器以及电源等部分组成。由于GPS定位信息内容较少,因此多用RS-232串口将定位信息(NEMA0183语句)从GPS接收机传送到计算机中进行信息提取处理。从串口读取数据有多种方法,在此直接使用 Win32 API函数对其进行编程处理。在Windows下不允许直接对硬件端口进行控制操作,所有的端口均被视为"文件",因此在对串口进行侦听之前需要通过打开文件来打开串口,并对其进行相关参数配置:

m_hCom=CreateFile("COM1",GENERIC_READ|GENERIC_WRITE,0,NULL,OPEN_EXISTING, FILE_FLAG_OVERLAPPED,NULL); file://以异步方式打开COM1口
SetCommMask (m_hCom, EV_RXCHAR ) ; file://添加或修改Windows所报告的事件列表
SetupComm (m_hCom,READBUFLEN/*读缓冲*/,WRITEBUFLEN/*写缓冲*/); // 初始化通讯设备参数
// 清除缓冲信息
PurgeComm (m_hCom, PURGE_TXABORT | PURGE_RXABORT | PURGE_TXCLEAR | PURGE_RXCLEAR) ;
// 对异步I/O进行设置
CommTimeOuts.ReadIntervalTimeout = MAXDWORD ; file://接收两连续字节的最大时间间隔
CommTimeOuts.ReadTotalTimeoutMultiplier =0; file://接收每字节的平均允许时间
CommTimeOuts.ReadTotalTimeoutConstant = 0 ; file://接收时间常数
SetCommTimeouts (m_hCom , &CommTimeOuts) ;
file://获取并设置串口
GetCommState ( m_hCom, &dcb) ;
dcb.BaudRate = CBR_4800;
dcb.ByteSize = 8;
dcb.Parity = ODDPARITY;
dcb.StopBits = ONESTOPBIT ;
SetCommState( m_hCom, &dcb);

  在成功打开并设置通讯口后,可采取轮询串口和事件触发两种方式对数据进行接收处理,本文在此采取效率比较高的事件触发方式进行接收处理,通过等待EV_RXCHAR事件的发生来启动ReadFile函数完成对GPS定位信息的接收:

while(true){
 WaitCommEvent (m_hCom,&dwEvtMask,NULL);
 if (dwEvtMask&EV_RXCHAR == EV_RXCHAR)
  if(ComStat.cbInQue>0)
   ReadFile(m_hCom,m_readbuf,ComStat.cbInQue,&nLength,&olRead);
}

  提取定位数据

  GPS接收机只要处于工作状态就会源源不断地把接收并计算出的GPS导航定位信息通过串口传送到计算机中。前面的代码只负责从串口接收数据并将其放置于缓存,在没有进一步处理之前缓存中是一长串字节流,这些信息在没有经过分类提取之前是无法加以利用的。因此,必须通过程序将各个字段的信息从缓存字节流中提取出来,将其转化成有实际意义的,可供高层决策使用的定位信息数据。同其他通讯协议类似,对GPS进行信息提取必须首先明确其帧结构,然后才能根据其结构完成对各定位信息的提取。对于本文所使用的GARMIN GPS天线板,其发送到计算机的数据主要由帧头、帧尾和帧内数据组成,根据数据帧的不同,帧头也不相同,主要有"$GPGGA"、"$GPGSA"、"$GPGSV"以及"$GPRMC"等。这些帧头标识了后续帧内数据的组成结构,各帧均以回车符和换行符作为帧尾标识一帧的结束。对于通常的情况,我们所关心的定位数据如经纬度、速度、时间等均可以从"$GPRMC"帧中获取得到,该帧的结构及各字段释义如下:

  $GPRMC,<1>,<2>,<3>,<4>,<5>,<6>,<7>,<8>,<9>,<10>,<11>*hh

  <1> 当前位置的格林尼治时间,格式为hhmmss

  <2> 状态, A 为有效位置, V为非有效接收警告,即当前天线视野上方的卫星个数少于3颗。

  <3> 纬度, 格式为ddmm.mmmm

  <4> 标明南北半球, N 为北半球、S为南半球

  <5> 径度,格式为dddmm.mmmm

  <6> 标明东西半球,E为东半球、W为西半球

  <7> 地面上的速度,范围为0.0到999.9

  <8> 方位角,范围为000.0到 359.9 度

  <9> 日期, 格式为ddmmyy

  <10> 地磁变化,从000.0到 180.0 度

  <11> 地磁变化方向,为E 或 W

  至于其他几种帧格式,除了特殊用途外,平时并不常用,虽然接收机也在源源不断地向主机发送各种数据帧,但在处理时一般先通过对帧头的判断而只对"$GPRMC"帧进行数据的提取处理。如果情况特殊,需要从其他帧获取数据,处理方法与之也是完全类似的。由于帧内各数据段由逗号分割,因此在处理缓存数据时一般是通过搜寻ASCII码"$"来判断是否是帧头,在对帧头的类别进行识别后再通过对所经历逗号个数的计数来判断出当前正在处理的是哪一种定位导航参数,并作出相应的处理。下面就是对缓存Data中的数据进行解帧处理的主要代码,本文在此只关心时间(日期和时间)和地理坐标(经、纬度):

for(int i=0;i  if(Data[i]==$) file://帧头,SectionID为逗号计数器
  SectionID=0;
  if(Data[i]==10){ file://帧尾
}
 if(Data[i]==,) file://逗号计数
  SectionID++;
 else {
  switch(SectionID){
   case 1: file://提取出时间
    m_sTime+=Data[i];
    break;
   case 2: file://判断数据是否可信(当GPS天线能接收到有3颗GPS卫星时为A,可信)
    if(Data[i]==A)
     GPSParam[m_nNumber].m_bValid=true;
     break;
   case 3: file://提取出纬度
     m_sPositionY+=Data[i];
     break;
   case 5: file://提取出经度
     m_sPositionX+=Data[i];
     break;
   case 9: file://提取出日期
     m_sDate+=Data[i];
     break;
     default:
     break;
  }
 }
}

  现在已将所需信息提取到内存,即时间、日期以及经纬度分别保存在CString型变量 m_sTime、m_Data、m_sPositionY和m_sPositionX中。在实际应用中往往要根据需要对其做进一步的运算处理,比如从GPS接收机中获得的时间信息为格林尼治时间,因此需要在获取时间上加8小时才为我国标准时间。而且GPS使用的WGS-84坐标系也与我国采用的坐标系不同,有时也要对此加以变换。而这些变换运算必须通过数值运算完成,因此需要将前面获取的字符型变量转化为数值型变量,这部分工作可放在检测到帧尾完成:

::strcpy(buf,m_sTime);
str.Format("%c%c",buf[0],buf[1]);
GPSParam[m_nNumber].m_nHour=(atoi(str)+8)%24; file://提取出小时并转化为24小时制北京时间
file://buf第2、3字节为分钟,4、5字节为秒,提取方法同上
……
::strcpy(buf,m_sDate);
str.Format("%c%c",buf[0],buf[1]); file://提取出月份
file://buf第2、3字节为天,4、5字节为年,提取方法同上
……
::strcpy(buf,m_sPositionY);
str.Format("%c%c",buf[0],buf[1]);
PositionValue=atoi(str);
str.Format("%c%c%c%c%c%c%c",buf[2],buf[3],buf[4],buf[5],buf[6],buf[7],buf[8]);
GPSParam[m_nNumber].m_dPositionY=PositionValue*60+atof(str); file://提取出纬度
……
::strcpy(buf,m_sPositionX);
if(m_sPositionX.GetLength()==10) file://经度超过90度(如东经125度)
{
 str.Format("%c%c%c",buf[0],buf[1],buf[2]);
 PositionValue=atoi(str);
 str.Format("%c%c%c%c%c%c%c",buf[3],buf[4],buf[5],buf[6],buf[7],buf[8],buf[9]);
 GPSParam[m_nNumber].m_dPositionX=PositionValue*60+atof(str); file://提取出经度(单位为分)
}
if(m_sPositionX.GetLength()==9) file://经度未超过90度(如东经89度)
{
 file://处理方法同上,只是buf的第0、1字节为度数,2~9为分数。
}

  到此为止,已将时间和经纬度信息提取到GPS结构数组GPSParam中的各个变量中去,后续的处理和高层决策可根据该结构中存储的数据作出相应的处理。

  小结

  本文结合主要的相关程序代码对GPS全球定位系统的定位导航信息的接收和参数数据的提取进行了讨论,同时也对串口的程序设计作了简要的讲述。通过本文的设计方法可以将GPS定位导航信息从GPS接收机完整接收,通过对定位参数的提取可将其应用于其他高层应用决策如各种GIS、RS系统等。本文程序在Windows 98下,由Microsoft Visual C++ 6.0编译通过。

VC++实现GPS全球定位系统定位数据的提取相关推荐

  1. php gps数据处理,使用c++提取GPS全球定位系统定位数据

    摘 要:本文主要针对GPS导航定位系统,对其卫星定位信息的接收及其定位参数提取的实现方法予以介绍,并使用C++可视化编程技术得以实现. 关键字:c++;GPS全球定位系统定位;GPS数据提取 Abst ...

  2. VC++提取GPS全球定位系统定位数据

    引言 卫星导航技术的飞速发展已逐渐取代了无线电导航.天文导航等传统导航技术,而成为一种普遍采用的导航定位技术,并在精度.实时性.全天候等方面取得了长足进步.现不仅应用于物理勘探.电离层测量和航天器导航 ...

  3. nema gps数据转换 matlab,GPS通信的NEMA协议与定位数据的提取.pdf

    第 2 1 卷第 12 期 计算机应用与软件 Vol 2 1 ,No12 2004 年 12 月 Computer Applications and Software Dec2004 GPS 通信的 ...

  4. GPS全球定位系统构成及原理

    GPS全球定位系统构成及原理 全球定位系统(GPS)是本世纪70年代由美国陆海空三军联合研制的新一代空间卫星导航定位系统 .其主要目的是为陆.海.空三大领域提供实时. 全天候和全球性的导航服务,并用于 ...

  5. 组合导航(三):GPS全球定位系统

    组合导航(三):GPS全球定位系统 1. GPS 观测 1.1伪距测量 1.2 载波相位测量 1.3 多普勒测量 2. GPS信号 3. GPS误差源 3.1 卫星时钟误差 3.2 接收机时钟误差 3 ...

  6. 手机卫星定位与GPS全球定位系统的区别

    手机定位系统的作用主要用在寻人找人的技术上,GPS全球定位系统可以在找人找车中起到一定的辅助作用,最早发明GPS定位系统的是美国,在民间调查行业使用的是在2005年上半年,GPS定位系统的实现原理详细 ...

  7. GNSS/INS组合导航(三):GPS全球定位系统

    全球定位系统(GPS)由美国国防部在20世纪70年代开发.GPS的定位基础是24颗卫星组成的网络.每颗卫星发送一个包含伪随机噪声(PRN)码与导航信息的无线电信号.接收机通过PRN码获得无线电信号的传 ...

  8. python大数据平台_基于腾讯位置大数据平台的全球移动定位数据Python爬取与清洗...

    前不久投稿了一篇论文是以腾讯位置大数据为基础进行人口空间化研究的,但是还未见刊,见刊后会给大家分享下具体的研究方法. 首先打开腾讯位置大数据星云图链接:https://xingyun.map.qq.c ...

  9. GPS(Global Position System)全球定位系统原理

    1. GPS是怎么定位的 GPS的定位是靠GPS接收芯片来定位的,这个芯片可以接收.处理GPS信号,并且输出坐标值,而各个应用就是用这个坐标值在地图上标志你的位置的.GPS芯片可以内置在各种设备中,包 ...

最新文章

  1. 颠覆arXiv等传统论文平台?谷歌大牛强推的Distill进展如何?
  2. args, sys.argv的区别
  3. ASP.NET 例程完全代码版(3)——随意创建图形信息
  4. visual studio intergration
  5. 20189208 2018-2019-2 《移动平台开发实践》分析小组项目代码
  6. python与excel结合-Python与Excel之间的交互
  7. MYSQL中的主表和父表_主表,从表,关联表,父表,子表
  8. JZOJ 5444. 【NOIP2017提高A组冲刺11.2】救赎
  9. Sqlserver内存管理:限制最大占用内存(转载)
  10. ue4玻璃材质_UE4-材质
  11. 容器编排技术 -- Kubernetes kubectl rollout undo 命令详解
  12. 作为移动开发程序员,腾讯3轮面试都问了Android事件分发,分享PDF高清版
  13. 电池SOH仿真系列-基于LSTM神经网络的电池SOH估算方法
  14. 小米智能音箱使用体验:大树底下好乘凉
  15. java 其他文件转pdf_java 其他文件转成pdf java生成pdf
  16. linux网卡加vlan标签,如何在 CentOS/RHEL 系统中使用带 VLAN 标记的以太网卡
  17. fastqc检验时不能执行java_fastqc对原始测序reads质控
  18. 炒短线的好方法.以及如何买入涨停股票
  19. 微信小程序中的正则验证、手机号验证随笔
  20. 痞子衡嵌入式:PCM编码与Waveform音频文件(.wav)格式详解

热门文章

  1. php 音频顺序播放,html5 Audio多个mp3音频顺序播放
  2. 探究动态库函数的地址是在何时确定的
  3. keil5 每次重启或者编译显示save changes to xxx.c
  4. 基于PHP的汉服交流网站的设计与实现
  5. 6款办公软件,让你10分钟搞定3小时的工作!
  6. AlarmManager研究
  7. 每日记录,2022年1月7日
  8. java线程基础知识整理
  9. 初三物理光学知识点总结_初中物理光学知识点归纳
  10. 仪表盘布局的5个技巧,都帮你总结好了