- 1、本文档共7页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
VC++编写GPS的串口通信
作者: ths.?本文可以转载,请以超链接标明原始出处和作者信息及版权声明 网址: /?p=347
::源代码:: GPS通信 真的好多事情,这个代码也是半年前写的了,拿出来贴贴。 阅读此文之前,如果你还不知道如何编写VC++的串口通信,那么你可以先看我的这篇文章:VC++编写串口通信. GPS(Golbal Position System)全球定位系统是一个在做一些项目中很常用到的仪器,它通过卫星的通信可以返回给你你当前所处的时间,时区,经纬度等等。VC++编写GPS通信是属于典型的基本的串口通信例子,而且只用接收信息即可,不用对GPS发送信息。 编写通信的方法的前半部分都跟我上篇文章说的串口通信一样,即注册ActiveX,建立实例及事件的映射等等。完成上面的操作后,你就可以接收的GPS发来的信息了。
CGPSDlg::CGPSDlg(CWnd* pParent /*=NULL*/)?? ?: CDialog(CGPSDlg::IDD, pParent){?? ?m_hIcon = AfxGetApp()-LoadIcon(IDR_MAINFRAME);??? ?m_port = 1; //端口号设置为1?? ?m_strset = _T(38400, n, 8, 1);//串口参数,波特率:38400, 8为数据位,1为停止位?? ?m_inputBuffer = _T();? //清空输入缓冲区??? ?m_str = _T();}?void CGPSDlg::OnBnClickedButton1(){//---------------------------------------------------------------------------?? ?m_str = _T();?? ?//如果端口原来打开,则需要先关闭?? ?if(m_comm.get_PortOpen())?? ? ? ?m_comm.put_PortOpen(FALSE);?? ?//设置连接参数?? ?m_comm.put__CommPort(m_port);? //指定串口号?? ?m_comm.put_Settings(m_strset); //通信参数设置?? ?m_comm.put_InBufferSize(1024); //指定接收缓冲区大小?? ?m_comm.put_InBufferCount(0);? ?//清空输入缓冲区?? ?m_comm.put_InputMode(0);? ? ? ?//文本模式获取数据?? ?m_comm.put_InputLen(0);? ? ? ? //读取缓冲区的全部数据?? ?m_comm.put_RThreshold(1);? ? ? //设置在产生OnComm事件前要接收的字符数阈值??? ?//打开端口连接?? ?if(!m_comm.get_PortOpen())?? ? ? ?m_comm.put_PortOpen(TRUE);//---------------------------------------------------------------------------?}
但因为GPS发送来的信息是源源不断的帧数据,如果你直接阅读这些帧数据,你会发现根本无法阅读。所以接下来的关键一步就是对GPS的帧数据的格式分析,筛选出有用的数据。要筛选数据,首先你必须明白GPS的帧格式,这里我就不说了,你去看我百度 Hi里以前收集的这篇文章《VC++实现GPS全球定位系统定位数据的提取》 其实数据的提取就是对接收过来的字符串进行分析,个人认为比较可简洁高效的方法是正则表达式法。但我当时使用的是最土的逐字分析法,先查找$帧开头,得到一个帧数据后再对这个帧数据分析,反正就是写得很”猥琐”,不过这么写起来也不难就是了。因为方法太土,也就没有什么好讲的了,自己看代码。
void CGPSDlg::OnCommMscomm1(){?? ?CString str = _T();?? ?VARIANT var_in;?? ?CString strtemp;??? ?if(m_comm.get_CommEvent() == 2) {? ?//事件值为2表示接收缓冲区内有字符?? ? ? ?var_in = m_comm.get_Input();? ? //读缓冲区?? ? ? ?m_str += var_in.bstrVal;? ? ? ? ? ? //转换成CString类型??? ? ? ?if(m_str.GetLength() 100) {??
您可能关注的文档
最近下载
- 《英语语言学导论》(第四版)课件 Chapter 9 Language and Society、Chapter 10 Language and Culture.pptx
- 中班语言《谁的尾巴》PPT课件.ppt
- 格拉斯哥昏迷评分新版.pptx
- 大数据探索性分析-吴翌琳-全套课件.pdf
- PMST1-2020设备管理体系 要求.docx
- 正式版挖掘机检验报告.doc
- 语言学概论英文课件:Chapter 8_language in use pragmatics.ppt
- 烟草行业某大型企业数字化转型解决方案(60页 PPT).pptx VIP
- 结核病实验室检查的临床意义PPT通用课件.pptx
- 烟草行业大数据应用规划建设方案.pptx VIP
文档评论(0)