gps模块.doc_第1页
gps模块.doc_第2页
gps模块.doc_第3页
gps模块.doc_第4页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

#include / 引用标准库的头文件#include #include #define uchar unsigned char #define uint unsigned int uchar StrGpsLgd8; / 存放经度数据uint i;uint RecFlag; / 记录标志 uint IGpsLgd; / 经度数据计数变量uint NumComa; / 逗号计数变量void DisableAllOut(); / 配置GPS模块禁用所有输出语句子函数void EnableGPRMC(); / 配置GPS模块使能$GPRMC输出语句子函数/* 延时t毫秒 */void delay(uint t)uint i;while(t-)/* 对于12MHz时钟,约延时1ms */for (i=0;i125;i+) /* 串口接收中断 */serial() interrupt 4 using 1RI = 0; / 清除中断标志位/* 判断是否收到GPRMC格式语句的第一个字符$,其数值为0x24,收到后开始记录数据,并设置记录标志RecFlag。 */if (SBUF = 0x24)RecFlag = 1;i = 0;IGpsLgd = 0; / 经度数据计数变量置0NumComa = 0; / 逗号计数变量置0/* 开始处理GPRMC中的数据信息 */if (RecFlag = 1)if(SBUF = 0x2c) NumComa+;/* 第5个逗号之后的字符属于经度数据 */if (NumComa = 3) StrGpsLgdIGpsLgd = SBUF; / 存入字符串StrGps IGpsLgd+;/* 判断是否收到GPRMC格式语句的字符*,其数值为0x2a,收到则结束记录 */ if (SBUF = 0x2a) StrGpsLgdIGpsLgd = 0; / 字符串的结束符 RecFlag = 0; IGpsLgd = 0; / 经度数据计数变量置0 NumComa = 0; / 逗号计数变量置0 /* 延时半秒钟后重新接收新的GPS定位信息中的经度信息 */ REN = 0; delay(500); / 延时500ms REN = 1; void main()/* 初始化串口 */TMOD = 0x20; TL1= 0xfd;TH1 = 0xfd;SCON = 0x40;/ 方式1:10位异步收发,波特率由定时器控制。REN=0。PCON = 0x00;/ SMOD = 0IE = 0x90; / EA = 1,ES = 1TR1 = 1; / 定时器1启动DisableAllOut();EnableGPRMC();delay(1000);/ 延时1sREN = 1; / REN = 1,开始接收数据while(1); /* 配置GPS模块禁用所有输出语句 */void DisableAllOut()/* 发送语句:$PGRMO,2 */TI = 0;SBUF = 0x24; / 发送$while(!TI);TI = 0;SBUF = P; / 发送Pwhile(!TI);TI = 0;SBUF = G; / 发送Gwhile(!TI);TI = 0;SBUF = R; / 发送Rwhile(!TI);TI = 0;SBUF = M; / 发送Mwhile(!TI);TI = 0;SBUF = O; / 发送Owhile(!TI);TI = 0;SBUF = ,; / 发送,while(!TI);TI = 0;SBUF = ,; / 发送,while(!TI);TI = 0;SBUF = 2; / 发送2while(!TI);TI = 0;SBUF = 0x2a; / 发送*while(!TI);TI = 0;/* 配置GPS模块使能$GPRMC输出语句 */void EnableGPRMC()/* 发送语句:$PGRMO,GPRMC,1 */TI = 0;SBUF = 0x24; / 发送$while(!TI);TI = 0;SBUF = P; / 发送Pwhile(!TI);TI = 0;SBUF = G; / 发送Gwhile(!TI);TI = 0;SBUF = R; / 发送Rwhile(!TI);TI = 0;SBUF = M; / 发送Mwhile(!TI);TI = 0;SBUF = O; / 发送Owhile(!TI);TI = 0;SBUF = ,; / 发送,while(!TI);TI = 0;SBUF = G; / 发送Gwhile(!TI);TI = 0;SBUF = P; / 发送Pwhile(!TI);TI = 0;SBUF = R; / 发送Rwhile(!TI);TI = 0;SBUF = M; / 发送Mwhile(!TI);TI = 0;SBUF = C; / 发送Cwhile(!TI);T

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论