找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3111|回复: 1
打印 上一主题 下一主题
收起左侧

STM32f4的GPS定位源码程序(模块型号:UBLOX-6M)

[复制链接]
跳转到指定楼层
楼主
ID:342700 发表于 2019-8-8 14:29 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
最近自己调试了以下GPS模块,代码实现经纬度显示、UTC日期及时间、高度、速度、卫星数,这些数据均由串口打印出来。下面是部分参考代码:
  1. #include "sys.h"
  2. #include "delay.h"  
  3. #include "usart.h"  
  4. #include "led.h"
  5. #include "lcd.h"
  6. #include "usmart.h"        
  7. #include "usart2.h"                  
  8. #include "string.h"                  
  9. #include "gps.h"         

  10.                                           
  11. u8 USART5_TX_BUF[USART2_MAX_RECV_LEN];                                         //串口1,发送缓存区
  12. nmea_msg gpsx;                                                                                         //GPS信息
  13. __align(4) u8 dtbuf[50];                                                                   //打印缓存器
  14. const u8*fixmode_tbl[4]={"Fail","Fail"," 2D "," 3D "};        //fix mode字符串
  15.          
  16. //显示GPS定位信息
  17. void Gps_Msg_Show(void)
  18. {
  19.          float tp;                           
  20.         tp=gpsx.longitude;           
  21.         printf("Longitude:%.5f %1c  \r\n ",tp/=100000,gpsx.ewhemi);        //得到经度字符串
  22.             
  23.         tp=gpsx.latitude;           
  24.         printf("Latitude:%.5f %1c   \r\n ",tp/=100000,gpsx.nshemi);        //得到纬度字符串
  25.          
  26.         tp=gpsx.altitude;           
  27.          printf("Altitude:%.1fm    \r\n  ",tp/=10);                                    //得到高度字符串
  28.                            
  29.         tp=gpsx.speed;           
  30.          printf("Speed:%.3fkm/h   \r\n   ",tp/=1000);                                    //得到速度字符串         
  31.                                     
  32.         if(gpsx.fixmode<=3)                                                                                                                //定位状态
  33.         {  
  34.                 printf("Fix Mode:%s  \r\n",fixmode_tbl[gpsx.fixmode]);        
  35.                            
  36.         }                    
  37.         printf("Valid satellite:%02d  \r\n",gpsx.posslnum);                         //用于定位的卫星数
  38.    
  39.         printf("Visible satellite:%02d \r\n",gpsx.svnum%100);                         //可见卫星数
  40.          
  41.         printf("UTC Date:%04d/%02d/%02d \r\n   ",gpsx.utc.year,gpsx.utc.month,gpsx.utc.date);        //显示UTC日期
  42.         //printf("year2:%d\r\n",gpsx.utc.year);
  43.                     
  44.         printf("UTC Time:%02d:%02d:%02d   \r\n ",gpsx.utc.hour,gpsx.utc.min,gpsx.utc.sec);        //显示UTC时间
  45.                     
  46. }         


  47. int main(void)
  48. {
  49.         u16 i,rxlen;
  50.         u16 lenx;
  51.         u8 upload=0;
  52.         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//设置系统中断优先级分组2
  53.         delay_init(168);      //初始化延时函数
  54.         uart5_init(115200);                //初始化串口波特率为115200
  55.         
  56.         usart2_init(9600);                //初始化串口3波特率为9600
  57.         usmart_dev.init(84);                 //初始化USMART                        
  58.         usmart_dev.init(72);                 //初始化USMART         
  59.    

  60.         if(Ublox_Cfg_Rate(1000,1)!=0)        //设置定位信息更新速度为1000ms,顺便判断GPS模块是否在位.
  61.         {
  62.         printf("NEO-6M Setting...\r\n");
  63.                 while((Ublox_Cfg_Rate(1000,1)!=0))        //持续判断,直到可以检查到NEO-6M,且数据保存成功
  64.                 {
  65.                         usart2_init(9600);                        //初始化串口3波特率为9600(EEPROM没有保存数据的时候,波特率为9600.)
  66.                           Ublox_Cfg_Prt(38400);                        //重新设置模块的波特率为38400
  67.                         Ublox_Cfg_Tp(1000000,100000,1);        //设置PPS为1秒钟输出1次,脉冲宽度为100ms            
  68.                         Ublox_Cfg_Cfg_Save();                //保存配置  
  69.             printf("检测设备\r\n");
  70.                 }
  71.       
  72.         }
  73.         while(1)
  74.         {        
  75.                 delay_ms(1);
  76.                 if(USART2_RX_STA&0X8000)                //接收到一次数据了
  77.                 {
  78.             printf("GPS_Res_sucess...\r\n");
  79.                         rxlen=USART2_RX_STA&0X7FFF;        //得到数据长度
  80.                         for(i=0;i<rxlen;i++)USART5_TX_BUF[i]=USART2_RX_BUF[i];           
  81.                          USART2_RX_STA=0;                           //启动下一次接收
  82.                         USART5_TX_BUF[i]=0;                        //自动添加结束符
  83.                         GPS_Analysis(&gpsx,(u8*)USART5_TX_BUF);//分析字符串
  84.                         Gps_Msg_Show();                                //显示信息        
  85.                         if(upload)printf("\r\n%s\r\n",USART5_TX_BUF);//发送接收到的数据到串口1
  86.                  }

  87.                         upload=!upload;
  88.                         if(upload)printf("NMEA Data Upload:ON ");
  89.                         else printf("NMEA Data Upload:OFF");
  90.          delay_ms(1000);
  91.                 if((lenx%500)==0)
  92.                 lenx++;        
  93.         }                                                                           
  94. }
复制代码

GPS.7z (343.7 KB, 下载次数: 81)
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏2 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:658914 发表于 2023-4-21 10:44 来自手机 | 只看该作者
好复杂啊
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表