找回密码
 立即注册

QQ登录

只需一步,快速开始

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

STM32解析MPU6050源程序

[复制链接]
跳转到指定楼层
楼主
ID:222817 发表于 2017-7-27 17:10 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
使用STM32 MPU6050编写的程序

单片机源程序如下:
  1. #include "stm32f10x.h"
  2. #include "delay.h"
  3. #include "sys.h"
  4. #include "usart.h"
  5. #include "MY_time_Conf.h"
  6. //#include "uart_1.h"
  7. //#include "dma.h"
  8. //#include "RS485.h"
  9. //#include "74hc595.h"
  10. #include "string.h"

  11. /**************************
  12. 模板配置信息:
  13. 选用芯片是 stm32f103vc
  14. 启动信息:stm32f10x_hd.s
  15. 固件库:stm32固件库v3.5
  16. ***************************/

  17. #define led_PB12   PBout(12)           //位绑定,位定义PB12口作为LED输出。这样速度最快
  18. //#define led_PB1   PBout(1)           //位绑定,位定义PB1口作为LED输出。这样速度最快
  19. //#define PA9   PAout(10)
  20. //#define CLK1   PDout(0)
  21. //#define CWW1   PDout(1)
  22. //#define CLK2   PDout(2)
  23. //#define CWW2   PDout(3)


  24. //uint8_t i = 0;    //测试用

  25. float a[3],w[3],angle[3],T;
  26. extern unsigned char Re_buf[11],temp_buf[11],counter;
  27. extern unsigned char sign;

  28. /*************************************************
  29. 函数: int main(void)
  30. 功能: main主函数
  31. 参数: 无
  32. 返回: 无
  33. **************************************************/

  34. int main(void)
  35. {
  36.    unsigned char Temp[11];
  37.    //u8 i;

  38.    RCC_Configuration();      //初始化时钟
  39.    GPIO_Configuration();      //初始化IO端口
  40.    delay_init(72);            //初始化延时函数
  41.    NVIC_Configuration();      //中断优先级初始化

  42.    USART1_Config();   //初始化 配置USART1
  43.    USART2_Config();   //初始化 配置USART2 (用于接收MPU6050数据)
  44.    
  45.    delay_ms(200);
  46.       
  47.    while (1)
  48.    {
  49.       if(sign)
  50.       {  
  51.          memcpy(Temp,Re_buf,11);
  52.          sign=0;
  53.          if(Re_buf[0]==0x55)       //检查帧头
  54.          {  
  55.             switch(Re_buf[1])
  56.             {
  57.                case 0x51: //标识这个包是加速度包
  58.                   a[0] = ((short)(Temp[3]<<8 | Temp[2]))/32768.0*16;      //X轴加速度
  59.                   a[1] = ((short)(Temp[5]<<8 | Temp[4]))/32768.0*16;      //Y轴加速度
  60.                   a[2] = ((short)(Temp[7]<<8 | Temp[6]))/32768.0*16;      //Z轴加速度
  61.                   T    = ((short)(Temp[9]<<8 | Temp[8]))/340.0+36.25;      //温度
  62.                   break;
  63.                case 0x52: //标识这个包是角速度包
  64.                   w[0] = ((short)(Temp[3]<<8| Temp[2]))/32768.0*2000;      //X轴角速度
  65.                   w[1] = ((short)(Temp[5]<<8| Temp[4]))/32768.0*2000;      //Y轴角速度
  66.                   w[2] = ((short)(Temp[7]<<8| Temp[6]))/32768.0*2000;      //Z轴角速度
  67.                   T    = ((short)(Temp[9]<<8| Temp[8]))/340.0+36.25;      //温度
  68.                   break;
  69.                case 0x53: //标识这个包是角度包
  70.                   angle[0] = ((short)(Temp[3]<<8| Temp[2]))/32768.0*180;   //X轴滚转角(x 轴)
  71.                   angle[1] = ((short)(Temp[5]<<8| Temp[4]))/32768.0*180;   //Y轴俯仰角(y 轴)
  72.                   angle[2] = ((short)(Temp[7]<<8| Temp[6]))/32768.0*180;   //Z轴偏航角(z 轴)
  73.                   T        = ((short)(Temp[9]<<8| Temp[8]))/340.0+36.25;   //温度

  74.                   //printf("X轴角度:%.2f   Y轴角度:%.2f   Z轴角度:%.2f\r\n",angle[0],angle[1],angle[2]);
  75.                   break;
  76.                default:  break;
  77.             }
  78.                         printf("X角度:%.2f  Y角度:%.2f  Z角度:%.2f  X速度:%.2f  Y速度:%.2f  Z速度:%.2f\r\n",angle[0],angle[1],angle[2],w[0],w[1],w[2]);
  79.          }
  80.          
  81.       }
  82.       delay_ms(50);
  83.    }
  84. }


  85. /*
  86. int main(void)
  87. {
  88.        
  89.         //u8 i;

  90.         RCC_Configuration();           //初始化时钟
  91.         GPIO_Configuration();           //初始化IO端口
  92.         delay_init(72);                           //初始化延时函数
  93.         NVIC_Configuration();           //中断优先级初始化

  94.         USART1_Config();   //初始化 配置USART1
  95.         USART2_Config();   //初始化 配置USART2 (用于接收MPU6050数据)
  96.        
  97.         delay_ms(200);

  98.                
  99.         while (1)
  100.         {
  101.                 if(sign)
  102.                 {  
  103.                         sign=0;
  104. //                        if(Re_buf[0]==0x55)       //检查帧头
  105. //                        {  
  106. //                                switch(Re_buf[1])
  107. //                                {
  108. //                                        case 0x51: //标识这个包是加速度包
  109. //                                                a[0] = ((short)(Re_buf[3]<<8 | Re_buf[2]))/32768.0*16;                //X轴加速度
  110. //                                                a[1] = ((short)(Re_buf[5]<<8 | Re_buf[4]))/32768.0*16;                //Y轴加速度
  111. //                                                a[2] = ((short)(Re_buf[7]<<8 | Re_buf[6]))/32768.0*16;                //Z轴加速度
  112. //                                                T    = ((short)(Re_buf[9]<<8 | Re_buf[8]))/340.0+36.25;                //温度
  113. //                                                break;
  114. //                                        case 0x52: //标识这个包是角速度包
  115. //                                                w[0] = ((short)(Re_buf[3]<<8| Re_buf[2]))/32768.0*2000;                //X轴角速度
  116. //                                                w[1] = ((short)(Re_buf[5]<<8| Re_buf[4]))/32768.0*2000;                //Y轴角速度
  117. //                                                w[2] = ((short)(Re_buf[7]<<8| Re_buf[6]))/32768.0*2000;                //Z轴角速度
  118. //                                                T    = ((short)(Re_buf[9]<<8| Re_buf[8]))/340.0+36.25;                //温度
  119. //                                                break;
  120. //                                        case 0x53: //标识这个包是角度包
  121. //                                                angle[0] = ((short)(Re_buf[3]<<8| Re_buf[2]))/32768.0*180;        //X轴滚转角(x 轴)
  122. //                                                angle[1] = ((short)(Re_buf[5]<<8| Re_buf[4]))/32768.0*180;        //Y轴俯仰角(y 轴)
  123. //                                                angle[2] = ((short)(Re_buf[7]<<8| Re_buf[6]))/32768.0*180;        //Z轴偏航角(z 轴)
  124. //                                                T        = ((short)(Re_buf[9]<<8| Re_buf[8]))/340.0+36.25;        //温度
  125. //
  126. //                                                //printf("X轴角度:%.2f   Y轴角度:%.2f   Z轴角度:%.2f\r\n",angle[0],angle[1],angle[2]);
  127. //                                                printf("%.2f   %.2f   %.2f\r\n",angle[0],angle[1],angle[2]);
  128. //                                                break;
  129. //                                        default:  break;
  130. //                                }
  131. //                        }
  132.                         //printf("X角度:%.2f  Y角度:%.2f  Z角度:%.2f  X速度:%.2f  Y速度:%.2f  Z速度:%.2f\r\n",angle[0],angle[1],angle[2],w[0],w[1],w[2]);

  133. //                        if(temp_buf[0]==0x55)       //检查帧头
  134. //                        {  
  135. //                                temp_buf[0] = 0;
  136. //                                switch(temp_buf[1])
  137. //                                {
  138. //                                        case 0x51: //标识这个包是加速度包
  139. //                                                a[0] = ((short)(temp_buf[3]<<8 | temp_buf[2]))/32768.0*16;                //X轴加速度
  140. //                                                a[1] = ((short)(temp_buf[5]<<8 | temp_buf[4]))/32768.0*16;                //Y轴加速度
  141. //                                                a[2] = ((short)(temp_buf[7]<<8 | temp_buf[6]))/32768.0*16;                //Z轴加速度
  142. //                                                T    = ((short)(temp_buf[9]<<8 | temp_buf[8]))/340.0+36.25;                //温度
  143. //                                                break;
  144. //                                        case 0x52: //标识这个包是角速度包
  145. //                                                w[0] = ((short)(temp_buf[3]<<8| temp_buf[2]))/32768.0*2000;                //X轴角速度
  146. //                                                w[1] = ((short)(temp_buf[5]<<8| temp_buf[4]))/32768.0*2000;                //Y轴角速度
  147. ……………………

  148. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
STM32解析MPU6050.zip (386.78 KB, 下载次数: 19)



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

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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