找回密码
 立即注册

QQ登录

只需一步,快速开始

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

stm32库函数版本GPS源码

[复制链接]
跳转到指定楼层
楼主
ID:284564 发表于 2018-2-21 10:02 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
stm32GPS源码,可以在上位机上显示

单片机源程序如下:
  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 "gps.h"       
  8. #include "usart3.h"        
  9. #include "key.h"          
  10. #include "string.h"       
  11. //ALIENTEK 战舰V3/精英开发板扩展实验16
  12. //ATK-S1216F8 GPS模块测试实验  

  13. u8 USART1_TX_BUF[USART3_MAX_RECV_LEN];                                         //串口1,发送缓存区
  14. nmea_msg gpsx;                                                                                         //GPS信息
  15. __align(4) u8 dtbuf[50];                                                                   //打印缓存器
  16. const u8*fixmode_tbl[4]={"Fail","Fail"," 2D "," 3D "};        //fix mode字符串
  17.           
  18. //显示GPS定位信息
  19. void Gps_Msg_Show(void)
  20. {
  21.         float tp;                  
  22.         POINT_COLOR=BLUE;           
  23.         tp=gpsx.longitude;          
  24.         sprintf((char *)dtbuf,"Longitude:%.5f %1c   ",tp/=100000,gpsx.ewhemi);        //得到经度字符串
  25.         LCD_ShowString(30,120,200,16,16,dtbuf);                   
  26.         tp=gpsx.latitude;          
  27.         sprintf((char *)dtbuf,"Latitude:%.5f %1c   ",tp/=100000,gpsx.nshemi);        //得到纬度字符串
  28.         LCD_ShowString(30,140,200,16,16,dtbuf);                  
  29.         tp=gpsx.altitude;          
  30.         sprintf((char *)dtbuf,"Altitude:%.1fm     ",tp/=10);                                    //得到高度字符串
  31.         LCD_ShowString(30,160,200,16,16,dtbuf);                                   
  32.         tp=gpsx.speed;          
  33.         sprintf((char *)dtbuf,"Speed:%.3fkm/h     ",tp/=1000);                                    //得到速度字符串         
  34.         LCD_ShowString(30,180,200,16,16,dtbuf);                                             
  35.         if(gpsx.fixmode<=3)                                                                                                                //定位状态
  36.         {  
  37.                 sprintf((char *)dtbuf,"Fix Mode:%s",fixmode_tbl[gpsx.fixmode]);       
  38.           LCD_ShowString(30,200,200,16,16,dtbuf);                          
  39.         }                   
  40.         sprintf((char *)dtbuf,"GPS+BD Valid satellite:%02d",gpsx.posslnum);                         //用于定位的GPS卫星数
  41.         LCD_ShowString(30,220,200,16,16,dtbuf);            
  42.         sprintf((char *)dtbuf,"GPS Visible satellite:%02d",gpsx.svnum%100);                         //可见GPS卫星数
  43.         LCD_ShowString(30,240,200,16,16,dtbuf);
  44.        
  45.         sprintf((char *)dtbuf,"BD Visible satellite:%02d",gpsx.beidou_svnum%100);                         //可见北斗卫星数
  46.         LCD_ShowString(30,260,200,16,16,dtbuf);
  47.        
  48.         sprintf((char *)dtbuf,"UTC Date:%04d/%02d/%02d   ",gpsx.utc.year,gpsx.utc.month,gpsx.utc.date);        //显示UTC日期
  49.         LCD_ShowString(30,280,200,16,16,dtbuf);                    
  50.         sprintf((char *)dtbuf,"UTC Time:%02d:%02d:%02d   ",gpsx.utc.hour,gpsx.utc.min,gpsx.utc.sec);        //显示UTC时间
  51.   LCD_ShowString(30,300,200,16,16,dtbuf);                            
  52. }
  53. int main(void)
  54. {         
  55.         u16 i,rxlen;
  56.         u16 lenx;
  57.         u8 key=0XFF;
  58.         u8 upload=0;            
  59.         delay_init();                     //延时函数初始化          
  60.   NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//设置中断优先级分组为组2:2位抢占优先级,2位响应优先级
  61.         uart_init(115200);                 //串口初始化为115200
  62.         usmart_dev.init(72);                //初始化USMART               
  63.         LED_Init();                                          //初始化与LED连接的硬件接口
  64.         KEY_Init();                                        //初始化按键
  65.         LCD_Init();                                           //初始化LCD   
  66.         usart3_init(38400);                //初始化串口3
  67.         POINT_COLOR=RED;
  68.         LCD_ShowString(30,20,200,16,16,"ALIENTEK STM32F1 ^_^");          
  69.         LCD_ShowString(30,40,200,16,16,"S1216F8 GPS TEST");       
  70.         LCD_ShowString(30,60,200,16,16,"ATOM@ALIENTEK");
  71.         LCD_ShowString(30,80,200,16,16,"KEY0:Upload NMEA Data SW");                                                                                                         
  72.   LCD_ShowString(30,100,200,16,16,"NMEA Data Upload:OFF");
  73.         if(SkyTra_Cfg_Rate(5)!=0)        //设置定位信息更新速度为5Hz,顺便判断GPS模块是否在位.
  74.         {
  75.            LCD_ShowString(30,120,200,16,16,"SkyTraF8-BD Setting...");
  76.                 do
  77.                 {
  78.                         usart3_init(9600);                        //初始化串口3波特率为9600
  79.                   SkyTra_Cfg_Prt(3);                        //重新设置模块的波特率为38400
  80.                         usart3_init(38400);                        //初始化串口3波特率为38400
  81.       key=SkyTra_Cfg_Tp(100000);        //脉冲宽度为100ms
  82.                 }while(SkyTra_Cfg_Rate(5)!=0&&key!=0);//配置SkyTraF8-BD的更新速率为5Hz
  83.           LCD_ShowString(30,120,200,16,16,"SkyTraF8-BD Set Done!!");
  84.                 delay_ms(500);
  85.                 LCD_Fill(30,120,30+200,120+16,WHITE);//清除显示
  86.         }
  87.         while(1)
  88.         {               
  89.                 delay_ms(1);
  90.                 if(USART3_RX_STA&0X8000)                //接收到一次数据了
  91.                 {
  92.                         rxlen=USART3_RX_STA&0X7FFF;        //得到数据长度
  93.                         for(i=0;i<rxlen;i++)USART1_TX_BUF[i]=USART3_RX_BUF[i];          
  94.                         USART3_RX_STA=0;                           //启动下一次接收
  95.                         USART1_TX_BUF[i]=0;                        //自动添加结束符
  96.                         GPS_Analysis(&gpsx,(u8*)USART1_TX_BUF);//分析字符串
  97.                         Gps_Msg_Show();                                //显示信息       
  98.                         if(upload)printf("\r\n%s\r\n",USART1_TX_BUF);//发送接收到的数据到串口1
  99.                 }
  100.                 key=KEY_Scan(0);
  101.                 if(key==KEY0_PRES)
  102.                 {
  103.                         upload=!upload;
  104.                         POINT_COLOR=RED;
  105.                         if(upload)LCD_ShowString(30,100,200,16,16,"NMEA Data Upload:ON ");
  106.                         else LCD_ShowString(30,100,200,16,16,"NMEA Data Upload:OFF");
  107.                 }
  108.                 if((lenx%500)==0)
  109.                         LED0=!LED0;
  110.                 lenx++;       
  111.         }
  112. }
复制代码

所有资料51hei提供下载:
(库函数版本,适合战舰V3和精英STM32开发板)扩展实验16 ATK-S1216F8 GPS模块实验.rar (398.26 KB, 下载次数: 31)


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享淘帖 顶 踩
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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