找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 12294|回复: 25
收起左侧

STM32F103C8T6测试MPU6050串口输出 九轴姿态传感器源码

  [复制链接]
ID:302731 发表于 2018-4-6 13:58 | 显示全部楼层 |阅读模式
在网上找了好久,没找到合适的,后来就自己参照资料写了一个,用的最新版的keil5编写,库也是最新的。PB6、PB7为IIC接口读取,PA9、PA10串口输出数据,效果如图,三轴加速已经校准过,数据还算灵敏,eg:98代表加速度为9.8m/s 2 陀螺仪已经能够正常读取,数据还未调校。有中文注释,自行下载研究!!

QQ图片20180406134900.png

单片机源程序如下:
  1. #include "sys.h"
  2. #include "delay.h"
  3. #include "usart.h"
  4. #include "stm32f10x.h"                  // Device header
  5. #include  <math.h>    //Keil library  
  6. GPIO_InitTypeDef GPIO_InitStructure;
  7. ErrorStatus HSEStartUpStatus;
  8. #define   uchar unsigned char
  9. #define   uint unsigned int       
  10. //        加速度,陀螺仪,磁力 Acceleration, gyroscope, magnetic
  11. // 定义MPU6050内部地址
  12. //****************************************
  13. #define        SMPLRT_DIV                0x19        //陀螺仪采样率,典型值:0x07(125Hz)
  14. #define        CONFIG                        0x1A        //低通滤波频率,典型值:0x06(5Hz)
  15. #define        GYRO_CONFIG                0x1B        //陀螺仪自检及测量范围,典型值:0x18(不自检,2000deg/s)
  16. #define        ACCEL_CONFIG        0x1C        //加速计自检、测量范围及高通滤波频率,典型值:0x01(不自检,2G,5Hz)
  17. #define        ACCEL_XOUT_H        0x3B        //加速度地址
  18. #define        ACCEL_XOUT_L        0x3C
  19. #define        ACCEL_YOUT_H        0x3D
  20. #define        ACCEL_YOUT_L        0x3E
  21. #define        ACCEL_ZOUT_H        0x3F
  22. #define        ACCEL_ZOUT_L        0x40
  23. #define        TEMP_OUT_H                0x41        //温度地址
  24. #define        TEMP_OUT_L                0x42

  25. #define        GYRO_XOUT_H                0x43        //陀螺仪地址
  26. #define        GYRO_XOUT_L                0x44       
  27. #define        GYRO_YOUT_H                0x45
  28. #define        GYRO_YOUT_L                0x46
  29. #define        GYRO_ZOUT_H                0x47
  30. #define        GYRO_ZOUT_L                0x48

  31. #define MAG_ADDRESS                0x0c
  32. #define MAG_XOUT_H                0x04                //磁力传感器地址
  33. #define MAG_XOUT_L                0x03
  34. #define MAG_YOUT_H                0x06
  35. #define MAG_YOUT_L                0x05
  36. #define MAG_ZOUT_H                0x08
  37. #define MAG_ZOUT_L                0x07

  38. #define        PWR_MGMT_1                0x6B        //电源管理,典型值:0x00(正常启用)
  39. #define        WHO_AM_I                0x75        //IIC地址寄存器(默认数值0x68,只读)


  40. //****************************

  41. #define        MPU6050_Addr   0xD0          //定义器件在IIC总线中的从地址,根据ALT  ADDRESS地址引脚不同修改

  42. unsigned char TX_DATA[4];           //显示据缓存区

  43. unsigned char BUF0[10];       //接收数据缓存区
  44. unsigned char BUF1[10];       //接收数据缓存区
  45. char  test=0;                                                          //IIC用到
  46. short G_X,G_Y,G_Z,T_T;                         //X,Y,Z轴角度,温度


  47. short A_X,A_Y,A_Z;                                         //X,Y,Z加速度
  48. //short M_X,M_Y,M_Z;                                         //X,Y,Z地磁
  49. //************************************
  50. /*模拟IIC端口输出输入定义*/
  51. #define SCL_H         GPIOB->BSRR = GPIO_Pin_6
  52. #define SCL_L         GPIOB->BRR  = GPIO_Pin_6
  53.    
  54. #define SDA_H         GPIOB->BSRR = GPIO_Pin_7
  55. #define SDA_L         GPIOB->BRR  = GPIO_Pin_7

  56. #define SCL_read      GPIOB->IDR  & GPIO_Pin_6
  57. #define SDA_read      GPIOB->IDR  & GPIO_Pin_7

  58. /* 函数申明 -----------------------------------------------*/
  59. void RCC_Configuration(void);
  60. void GPIO_Configuration(void);                //GPIO初始化
  61. void NVIC_Configuration(void);                //中断初始化
  62. void USART1_Configuration(void);        //串口初始化
  63. void WWDG_Configuration(void);                //看门狗初始化
  64. void Delay(u32 nTime);
  65. void Delayms(vu32 m);  
  66. /* 变量定义 ----------------------------------------------*/

  67.   /*******************************/
  68. void DATA_printf(uchar *s,short temp_data)
  69. {
  70.         if(temp_data<0){
  71.         temp_data=-temp_data;
  72.     *s='-';
  73.         }
  74.         else *s=' ';
  75.     *++s =temp_data/100+0x30;
  76.     temp_data=temp_data%100;     //取余运算
  77.     *++s =temp_data/10+0x30;
  78.     temp_data=temp_data%10;      //取余运算
  79.     *++s =temp_data+0x30;        
  80. }

  81. /*******************************************************************************
  82. * Function Name  : I2C_GPIO_Config
  83. * Description    : Configration Simulation IIC GPIO
  84. * Input          : None
  85. * Output         : None
  86. * Return         : None
  87. ****************************************************************************** */
  88. void I2C_GPIO_Config(void)                                //IIC引脚初始化
  89. {
  90.   GPIO_InitTypeDef  GPIO_InitStructure;

  91.   GPIO_InitStructure.GPIO_Pin =  GPIO_Pin_6;
  92.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  93.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_OD;  
  94.   GPIO_Init(GPIOB, &GPIO_InitStructure);

  95.   GPIO_InitStructure.GPIO_Pin =  GPIO_Pin_7;
  96.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  97.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_OD;
  98.   GPIO_Init(GPIOB, &GPIO_InitStructure);
  99. }

  100. /*******************************************************************************
  101. * Function Name  : I2C_delay
  102. * Description    : Simulation IIC Timing series delay
  103. * Input          : None
  104. * Output         : None
  105. * Return         : None
  106. ****************************************************************************** */
  107. void I2C_delay(void)
  108. {
  109.                
  110.    u8 i=30; //这里可以优化速度        ,经测试最低到5还能写入
  111.    while(i)
  112.    {
  113.      i--;
  114.    }  
  115. }

  116. void delay5ms(void)
  117. {
  118.                
  119.    int i=5000;  
  120.    while(i)
  121.    {
  122.      i--;
  123.    }  
  124. }
  125. /*******************************************************************************
  126. * Function Name  : I2C_Start
  127. * Description    : Master Start Simulation IIC Communication
  128. * Input          : None
  129. * Output         : None
  130. * Return         : Wheather         Start
  131. ****************************************************************************** */
  132. bool I2C_Start(void)                        //IIC开始
  133. {
  134.         SDA_H;
  135.         SCL_H;
  136.         I2C_delay();
  137.         if(!SDA_read)return FALSE;        //SDA线为低电平则总线忙,退出
  138.         SDA_L;
  139.         I2C_delay();
  140.         if(SDA_read) return FALSE;        //SDA线为高电平则总线出错,退出
  141.         SDA_L;
  142.         I2C_delay();
  143.         return TRUE;
  144. }
  145. /*******************************************************************************
  146. * Function Name  : I2C_Stop
  147. * Description    : Master Stop Simulation IIC Communication
  148. * Input          : None
  149. * Output         : None
  150. * Return         : None
  151. ****************************************************************************** */
  152. void I2C_Stop(void)                                //IIC停止
  153. {
  154.         SCL_L;
  155.         I2C_delay();
  156.         SDA_L;
  157.         I2C_delay();
  158.         SCL_H;
  159.         I2C_delay();
  160.         SDA_H;
  161.         I2C_delay();
  162. }
  163. /*******************************************************************************
  164. * Function Name  : I2C_Ack
  165. * Description    : Master Send Acknowledge Single
  166. * Input          : None
  167. * Output         : None
  168. * Return         : None
  169. ****************************************************************************** */
  170. void I2C_Ack(void)                //IIC发送
  171. {       
  172.         SCL_L;
  173.         I2C_delay();
  174.         SDA_L;
  175.         I2C_delay();
  176.         SCL_H;
  177.         I2C_delay();
  178.         SCL_L;
  179.         I2C_delay();
  180. }   
  181. /*******************************************************************************
  182. * Function Name  : I2C_NoAck
  183. * Description    : Master Send No Acknowledge Single
  184. * Input          : None
  185. * Output         : None
  186. * Return         : None
  187. ****************************************************************************** */
  188. void I2C_NoAck(void)       
  189. {       
  190.         SCL_L;
  191.         I2C_delay();
  192.         SDA_H;
  193.         I2C_delay();
  194.         SCL_H;
  195.         I2C_delay();
  196.         SCL_L;
  197.         I2C_delay();
  198. }
  199. /*******************************************************************************
  200. * Function Name  : I2C_WaitAck
  201. * Description    : Master Reserive Slave Acknowledge Single
  202. * Input          : None
  203. * Output         : None
  204. * Return         : Wheather         Reserive Slave Acknowledge Single
  205. ****************************************************************************** */
  206. bool I2C_WaitAck(void)          //返回为:=1有ACK,=0无ACK  等待接收
  207. {
  208.         SCL_L;
  209.         I2C_delay();
  210.         SDA_H;                       
  211.         I2C_delay();
  212.         SCL_H;
  213.         I2C_delay();
  214.         if(SDA_read)
  215.         {
  216.       SCL_L;
  217.           I2C_delay();
  218.       return FALSE;
  219.         }
  220.         SCL_L;
  221.         I2C_delay();
  222.         return TRUE;
  223. }
  224. /*******************************************************************************
  225. * Function Name  : I2C_SendByte
  226. * Description    : Master Send a Byte to Slave
  227. * Input          : Will Send Date
  228. * Output         : None
  229. * Return         : None
  230. ****************************************************************************** */
  231. void I2C_SendByte(u8 SendByte) //数据从高位到低位//发送数据
  232. {
  233.     u8 i=8;
  234.     while(i--)
  235.     {
  236.         SCL_L;
  237.         I2C_delay();
  238.       if(SendByte&0x80)
  239.         SDA_H;  
  240.       else
  241.         SDA_L;
  242.         SendByte<<=1;
  243.         I2C_delay();
  244.                 SCL_H;
  245.         I2C_delay();
  246.     }
  247.     SCL_L;
  248. }  
  249. /*******************************************************************************
  250. * Function Name  : I2C_RadeByte
  251. * Description    : Master Reserive a Byte From Slave
  252. * Input          : None
  253. * Output         : None
  254. * Return         : Date From Slave
  255. ****************************************************************************** */
  256. unsigned char I2C_RadeByte(void)  //数据从高位到低位//读取字节
  257. {
  258.     u8 i=8;
  259.     u8 ReceiveByte=0;

  260.     SDA_H;                               
  261.     while(i--)
  262.     {
  263.       ReceiveByte<<=1;      
  264.       SCL_L;
  265.       I2C_delay();
  266.           SCL_H;
  267.       I2C_delay();       
  268.       if(SDA_read)
  269.       {
  270.         ReceiveByte|=0x01;
  271.       }
  272.     }
  273.     SCL_L;
  274.     return ReceiveByte;
  275. }
  276. //ZRX         
  277. //单字节写入*******************************************

  278. bool Single_Write(unsigned char SlaveAddress,unsigned char REG_Address,unsigned char REG_data)                     //void
  279. {
  280.           if(!I2C_Start())return FALSE;
  281.     I2C_SendByte(SlaveAddress);   //发送设备地址+写信号//I2C_SendByte(((REG_Address & 0x0700) >>7) | SlaveAddress & 0xFFFE);//设置高起始地址+器件地址
  282.     if(!I2C_WaitAck()){I2C_Stop(); return FALSE;}
  283.     I2C_SendByte(REG_Address );   //设置低起始地址      
  284.     I2C_WaitAck();       
  285.     I2C_SendByte(REG_data);
  286.     I2C_WaitAck();   
  287.     I2C_Stop();
  288.     delay5ms();
  289.     return TRUE;
  290. }

  291. //单字节读取*****************************************
  292. unsigned char Single_Read(unsigned char SlaveAddress,unsigned char REG_Address)
  293. {   unsigned char REG_data;            
  294.         if(!I2C_Start())return FALSE;
  295.     I2C_SendByte(SlaveAddress); //I2C_SendByte(((REG_Address & 0x0700) >>7) | REG_Address & 0xFFFE);//设置高起始地址+器件地址
  296.     if(!I2C_WaitAck()){I2C_Stop();test=1; return FALSE;}
  297.     I2C_SendByte((u8) REG_Address);   //设置低起始地址      
  298.     I2C_WaitAck();
  299.     I2C_Start();
  300.     I2C_SendByte(SlaveAddress+1);
  301.     I2C_WaitAck();

  302.         REG_data= I2C_RadeByte();
  303.     I2C_NoAck();
  304.     I2C_Stop();
  305.     //return TRUE;
  306.         return REG_data;

  307. }                                                     

  308. /*
  309. ********************************************************************************
  310. ** 函数名称 : RCC_Configuration(void)
  311. ** 函数功能 : 时钟初始化
  312. ** 输    入        : 无
  313. ** 输    出        : 无
  314. ** 返    回        : 无
  315. ********************************************************************************
  316. */
  317. void RCC_Configuration(void)
  318. {   
  319.   /* RCC system reset(for debug purpose) */
  320.   RCC_DeInit();

  321.   /* Enable HSE */
  322.   RCC_HSEConfig(RCC_HSE_ON);

  323.   /* Wait till HSE is ready */
  324.   HSEStartUpStatus = RCC_WaitForHSEStartUp();

  325.   if(HSEStartUpStatus == SUCCESS)
  326.   {
  327.     /* HCLK = SYSCLK */
  328.     RCC_HCLKConfig(RCC_SYSCLK_Div1);
  329.   
  330.     /* PCLK2 = HCLK */
  331.     RCC_PCLK2Config(RCC_HCLK_Div1);

  332.     /* PCLK1 = HCLK/2 */
  333.     RCC_PCLK1Config(RCC_HCLK_Div2);

  334.     /* Flash 2 wait state */
  335.     FLASH_SetLatency(FLASH_Latency_2);
  336.     /* Enable Prefetch Buffer */
  337.     FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);

  338.     /* PLLCLK = 8MHz * 9 = 72 MHz */
  339.     RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);

  340.     /* Enable PLL */
  341.     RCC_PLLCmd(ENABLE);

  342.     /* Wait till PLL is ready */
  343.     while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)
  344.     {
  345.     }

  346.     /* Select PLL as system clock source */
  347.     RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);

  348.     /* Wait till PLL is used as system clock source */
  349.     while(RCC_GetSYSCLKSource() != 0x08)
  350.     {
  351.     }
  352.   }
  353.    /* Enable GPIOA, GPIOB, GPIOC, GPIOD, GPIOE, GPIOF, GPIOG and AFIO clocks */
  354.     RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOB , ENABLE);
  355.         RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC | RCC_APB2Periph_GPIOD , ENABLE);
  356.         RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOE | RCC_APB2Periph_GPIOF , ENABLE);
  357.         RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOG | RCC_APB2Periph_AFIO  , ENABLE);  
  358. }

  359. /*
  360. ********************************************************************************
  361. ** 函数名称 : GPIO_Configuration(void)
  362. ** 函数功能 : 端口初始化
  363. ** 输    入        : 无
  364. ** 输    出        : 无
  365. ** 返    回        : 无
  366. ********************************************************************************
  367. */
  368. void GPIO_Configuration(void)                                                                        //串口端口初始化
  369. {
  370.   GPIO_InitTypeDef GPIO_InitStructure;
  371.   RCC_APB2PeriphClockCmd( RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOB | RCC_APB2Periph_GPIOC | RCC_APB2Periph_GPIOD, ENABLE  );
  372.    /* Configure USART1 Tx (PA.09) as alternate function push-pull */
  373.   GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;                                 //        选中管脚9
  374.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;                 // 复用推挽输出
  375.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;                 // 最高输出速率50MHz
  376.   GPIO_Init(GPIOA, &GPIO_InitStructure);                                 // 选择A端口
  377.    
  378.   /* Configure USART1 Rx (PA.10) as input floating */
  379.   GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;                          //选中管脚10
  380.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;          //浮空输入
  381.   GPIO_Init(GPIOA, &GPIO_InitStructure);                                  //选择A端口

  382. }

  383. /*
  384. ********************************************************************************
  385. ** 函数名称 : USART1_Configuration(void)
  386. ** 函数功能 : 串口1初始化
  387. ** 输    入        : 无
  388. ** 输    出        : 无
  389. ** 返    回        : 无
  390. ********************************************************************************
  391. */
  392. void USART1_Configuration(void)
  393. {
  394. USART_InitTypeDef USART_InitStructure;
  395. USART_ClockInitTypeDef  USART_ClockInitStructure;

  396. RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM1 |RCC_APB2Periph_USART1, ENABLE  );

  397. USART_ClockInitStructure.USART_Clock = USART_Clock_Disable;                        // 时钟低电平活动
  398. USART_ClockInitStructure.USART_CPOL = USART_CPOL_Low;                                // 时钟低电平
  399. USART_ClockInitStructure.USART_CPHA = USART_CPHA_2Edge;                                // 时钟第二个边沿进行数据捕获
  400. USART_ClockInitStructure.USART_LastBit = USART_LastBit_Disable;                // 最后一位数据的时钟脉冲不从SCLK输出
  401. /* Configure the USART1 synchronous paramters */
  402. USART_ClockInit(USART1, &USART_ClockInitStructure);                                        // 时钟参数初始化设置
  403.                                                                                                                                          
  404. USART_InitStructure.USART_BaudRate = 115200;                                                  // 波特率为:115200
  405. USART_InitStructure.USART_WordLength = USART_WordLength_8b;                          // 8位数据
  406. USART_InitStructure.USART_StopBits = USART_StopBits_1;                                  // 在帧结尾传输1个停止位
  407. USART_InitStructure.USART_Parity = USART_Parity_No ;                                  // 奇偶失能
  408. USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;        // 硬件流控制失能

  409. USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;                  // 发送使能+接收使能
  410. /* Configure USART1 basic and asynchronous paramters */
  411. USART_Init(USART1, &USART_InitStructure);
  412.    
  413.   /* Enable USART1 */
  414. USART_ClearFlag(USART1, USART_IT_RXNE);                         //清中断,以免一启用中断后立即产生中断
  415. USART_ITConfig(USART1,USART_IT_RXNE, ENABLE);                //使能USART1中断源
  416. USART_Cmd(USART1, ENABLE);                                                        //USART1总开关:开启
  417. }

  418. /*
  419. ********************************************************************************
  420. ** 函数名称 : NVIC_Configuration(void)
  421. ** 函数功能 : 中断初始化
  422. ** 输    入        : 无
  423. ** 输    出        : 无
  424. ** 返    回        : 无
  425. ********************************************************************************
  426. */
  427. void NVIC_Configuration(void)
  428. {
  429.   NVIC_InitTypeDef NVIC_InitStructure;  
  430.   NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);

  431.   NVIC_InitStructure.NVIC_IRQChannel = WWDG_IRQn;    //WWDG中断
  432.   NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
  433.   NVIC_Init(&NVIC_InitStructure);
  434. }

  435. /*
  436. ********************************************************************************
  437. ** 函数名称 : WWDG_Configuration(void)
  438. ** 函数功能 : 看门狗初始化
  439. ** 输    入        : 无
  440. ** 输    出        : 无
  441. ** 返    回        : 无
  442. ********************************************************************************
  443. */
  444. void WWDG_Configuration(void)
  445. {
  446.   RCC_APB1PeriphClockCmd(RCC_APB1Periph_WWDG, ENABLE);        //   WWDG时钟使能
  447.   
  448.         WWDG_SetPrescaler(WWDG_Prescaler_8);                      //  WWDG clock counter = (PCLK1/4096)/8 = 244 Hz (~4 ms)  
  449.   
  450.         WWDG_SetWindowValue(0x41);                                 // Set Window value to 0x41
  451.   
  452.         WWDG_Enable(0x50);                       // Enable WWDG and set counter value to 0x7F, WWDG timeout = ~4 ms * 64 = 262 ms
  453.   
  454.         WWDG_ClearFlag();                               // Clear EWI flag
  455.        
  456.   WWDG_EnableIT();                               // Enable EW interrupt
  457. }

  458. /*
  459. ********************************************************************************
  460. ** 函数名称 : Delay(vu32 nCount)
  461. ** 函数功能 : 延时函数
  462. ** 输    入        : 无
  463. ** 输    出        : 无
  464. ** 返    回        : 无
  465. ********************************************************************************
  466. */
  467. void Delay(vu32 nCount)
  468. {
  469.   for(; nCount != 0; nCount--);
  470. }

  471. /*
  472. ********************************************************************************
  473. ** 函数名称 : void Delayms(vu32 m)
  474. ** 函数功能 : 长延时函数         m=1,延时1ms
  475. ** 输    入        : 无
  476. ** 输    出        : 无
  477. ** 返    回        : 无
  478. ********************************************************************************
  479. */
  480. void Delayms(vu32 m)
  481. {
  482.   u32 i;
  483.   
  484.   for(; m != 0; m--)       
  485.        for (i=0; i<50000; i++);
  486. }

  487. /*
  488. ********************************************************************************
  489. ** 函数名称 : WWDG_IRQHandler(void)
  490. ** 函数功能 : 窗口提前唤醒中断
  491. ** 输    入        : 无
  492. ** 输    出        : 无
  493. ** 返    回        : 无
  494. ********************************************************************************
  495. */

  496. void WWDG_IRQHandler(void)
  497. {
  498.   /* Update WWDG counter */
  499.   WWDG_SetCounter(0x50);
  500.        
  501.   /* Clear EWI flag */
  502.   WWDG_ClearFlag();
  503. }
  504. //************************************************
  505. void  USART1_SendData(uchar SendData)
  506. {
  507. USART_SendData(USART1, SendData);
  508. Delayms(1);
  509. }
  510. //初始化MPU6050,根据需要请参考pdf进行修改************************
  511. void Init_MPU6050(void)
  512. {
  513. /*
  514.    Single_Write(MPU6050_Addr,PWR_M, 0x80);   //
  515.    Single_Write(MPU6050_Addr,SMPL, 0x07);    //
  516.    Single_Write(MPU6050_Addr,DLPF, 0x1E);    //±2000°
  517.    Single_Write(MPU6050_Addr,INT_C, 0x00 );  //
  518.    Single_Write(MPU6050_Addr,PWR_M, 0x00);   //
  519. */
  520.   Single_Write(MPU6050_Addr,PWR_MGMT_1, 0x00);        //解除休眠状态
  521.         Single_Write(MPU6050_Addr,SMPLRT_DIV, 0x07);
  522.         Single_Write(MPU6050_Addr,CONFIG, 0x06);
  523.         Single_Write(MPU6050_Addr,GYRO_CONFIG, 0x18);
  524.         Single_Write(MPU6050_Addr,ACCEL_CONFIG, 0x01);
  525. }
  526.        
  527. //******读取MPU6050数据****************************************
  528. void READ_MPU6050(void)
  529. {
  530.         /*        读取陀螺仪数据                */
  531.         //***********************************************************
  532.    BUF0[0]=Single_Read(MPU6050_Addr,GYRO_XOUT_L);
  533.    BUF0[1]=Single_Read(MPU6050_Addr,GYRO_XOUT_H);
  534.    G_X =        (BUF0[1]<<8)|BUF0[0];
  535.    G_X =(double)G_X*250/327.68;                                                    //读取计算X轴数据

  536.    BUF0[2]=Single_Read(MPU6050_Addr,GYRO_YOUT_L);
  537.    BUF0[3]=Single_Read(MPU6050_Addr,GYRO_YOUT_H);
  538.    G_Y =        (BUF0[3]<<8)|BUF0[2];
  539.    G_Y =(double)G_Y*250/327.68;                                                    //读取计算Y轴数据
  540.        
  541.    BUF0[4]=Single_Read(MPU6050_Addr,GYRO_ZOUT_L);
  542.    BUF0[5]=Single_Read(MPU6050_Addr,GYRO_ZOUT_H);
  543.    G_Z =        (BUF0[5]<<8)|BUF0[4];
  544.    G_Z =(double)G_Z*250/327.68;                                                //读取计算Z轴数据

  545.    BUF0[6]=Single_Read(MPU6050_Addr,TEMP_OUT_L);
  546.    BUF0[7]=Single_Read(MPU6050_Addr,TEMP_OUT_H);
  547.    T_T =(BUF0[7]<<8)|BUF0[6];
  548.    T_T =(((double) (T_T + 13200)) / 280)-39;// 读取计算出温度
  549.        
  550.         //ACCEL_ZOUT_L
  551.         //*************************************************************
  552.                 /*        读取加速度数据                */
  553.         //***********************************************************
  554.    BUF1[0]=Single_Read(MPU6050_Addr,ACCEL_XOUT_L);
  555.    BUF1[1]=Single_Read(MPU6050_Addr,ACCEL_XOUT_H);
  556.    A_X =        (BUF1[1]<<8)|BUF1[0];
  557.    A_X = (double)A_X/163.84;                                                    //读取计算X轴数据

  558.    BUF1[2]=Single_Read(MPU6050_Addr,ACCEL_YOUT_L);
  559.    BUF1[3]=Single_Read(MPU6050_Addr,ACCEL_YOUT_H);
  560.    A_Y =        (BUF1[3]<<8)|BUF1[2];
  561.    A_Y = (double)A_Y/163.84;                                                    //读取计算Y轴数据
  562.        
  563.    BUF1[4]=Single_Read(MPU6050_Addr,ACCEL_ZOUT_L);
  564.    BUF1[5]=Single_Read(MPU6050_Addr,ACCEL_ZOUT_H);
  565.    A_Z =        (BUF1[5]<<8)|BUF1[4];
  566.    A_Z = (double)A_Z/163.84;                                                //读取计算Z轴数据
  567.         //*************************************************************
  568. }
  569. //********串口发送数据***************************************
  570. void Send_data(uchar axis)
  571. {uchar i;
  572.   USART1_SendData(axis);
  573.   USART1_SendData(':');
  574.   for(i=0;i<4;i++)USART1_SendData(TX_DATA[i]);
  575.   USART1_SendData(' ');
  576.   USART1_SendData(' ');
  577. }

  578.   /*
  579. ********************************************************************************
  580. ** 函数名称 : main(void)
  581. ** 函数功能 : 主函数
  582. ** 输    入        : 无
  583. ** 输    出        : 无
  584. ** 返    回        : 无
  585. ********************************************************************************
  586. */
  587. int main(void)
  588. {
  589.   RCC_Configuration();                 //配置RCC
  590.   GPIO_Configuration();                 //配置GPIO
  591.   USART1_Configuration();         //配置串口1
  592.   I2C_GPIO_Config();                 //配置IIC使用端口
  593.   Delayms(10);                                 //延时
  594.   Init_MPU6050();                     //初始化MPU6050
  595.   while(1)
  596. {
  597.         READ_MPU6050();                 //读取MPU6050数据
  598. //输出陀螺仪
  599.          printf("Gyroscope: ");
  600.   DATA_printf(TX_DATA,G_X);//转换X轴数据到数组
  601.         Send_data('X');                         //发送X轴数
  602.         DATA_printf(TX_DATA,G_Y);//转换Y轴数据到数组
  603.         Send_data('Y');                         //发送Y轴数
  604.         DATA_printf(TX_DATA,G_Z);//转换Z轴数据到数组
  605.         Send_data('Z');                         //发送Z轴数
  606.         DATA_printf(TX_DATA,T_T);//转换温度数据到数组
  607.         Send_data('T');                         //发送温度数据
  608.         USART1_SendData(0X0D);         //换行
  609.         USART1_SendData(0X0A);         //回车
  610. //输出加速度
  611.          printf("Acceleration: ");
  612.   DATA_printf(TX_DATA,A_X);//转换X轴数据到数组
  613.         Send_data('X');                         //发送X轴数
  614.         DATA_printf(TX_DATA,A_Y);//转换Y轴数据到数组
  615.         Send_data('Y');                         //发送Y轴数
  616.         DATA_printf(TX_DATA,A_Z);//转换Z轴数据到数组
  617.         Send_data('Z');                         //发送Z轴数

  618.         USART1_SendData(0X0D);         //换行
  619.         USART1_SendData(0X0A);         //回车
  620.         USART1_SendData(0X0A);       
  621.         USART1_SendData(0X0A);       
  622.         Delayms(100);
  623.   }
  624. }

  625. /*************结束***************/
复制代码

所有资料51hei提供下载:
九轴姿态传感器STM32F103C8T6串口程序.rar (298.14 KB, 下载次数: 561)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

ID:260931 发表于 2018-5-18 08:47 | 显示全部楼层
我去赚黑币先,等下再下你!
回复

使用道具 举报

ID:336631 发表于 2018-5-23 16:52 | 显示全部楼层
很给力哦
回复

使用道具 举报

ID:400671 发表于 2018-9-20 22:14 | 显示全部楼层
我去赚黑币先,等下再下你!
回复

使用道具 举报

ID:225515 发表于 2018-11-19 22:50 | 显示全部楼层
很不错~~~
回复

使用道具 举报

ID:225515 发表于 2018-11-19 22:50 | 显示全部楼层
很好的资源,刚刚好需要用到,楼主牛逼
回复

使用道具 举报

ID:225515 发表于 2018-11-19 22:50 | 显示全部楼层
刚刚好需要用到,楼主牛逼,找了很久在这里找到;
回复

使用道具 举报

ID:380922 发表于 2019-1-14 13:46 | 显示全部楼层
楼主牛逼!,不过这好像是直接用模拟IIC读MPU的原始数据吧,没经过DMP处理吧,角度那好像不太对
回复

使用道具 举报

ID:378985 发表于 2019-1-23 10:02 | 显示全部楼层
楼主牛逼,完全好用,100分!
回复

使用道具 举报

ID:170847 发表于 2019-4-29 17:27 | 显示全部楼层
为毛我烧进去没反应,接口都是对应的
回复

使用道具 举报

ID:301268 发表于 2019-5-10 18:34 | 显示全部楼层
很有用,感谢楼主
回复

使用道具 举报

ID:301268 发表于 2019-5-10 18:37 | 显示全部楼层
先去赚取黑币,希望楼主给的程序有用
回复

使用道具 举报

ID:301268 发表于 2019-5-15 15:12 | 显示全部楼层
烧录后没有显示啊,不太行啊
回复

使用道具 举报

ID:466188 发表于 2019-5-16 15:46 | 显示全部楼层
为什么传回来的是一些符号呢?
回复

使用道具 举报

ID:397670 发表于 2019-5-22 15:02 | 显示全部楼层
很不错
回复

使用道具 举报

ID:543896 发表于 2019-5-22 22:04 | 显示全部楼层
这个论坛还有基本上一样的,格式都一样,http://www.51hei.com/bbs/dpj-29287-1.html  不知道是谁抄袭谁的,居然只改动了一下标识,抄袭的人可耻呀。
回复

使用道具 举报

ID:490640 发表于 2019-7-19 23:06 | 显示全部楼层
角度怎么计算!!角度怎么计算!!角度怎么计算!!角度怎么计算!!感谢楼主,学习学习!!
回复

使用道具 举报

ID:260931 发表于 2019-9-17 08:10 | 显示全部楼层
谢谢楼主分享
回复

使用道具 举报

ID:457185 发表于 2019-11-12 17:25 | 显示全部楼层
参考一下,现在还在嫌九轴陀螺仪太贵了
回复

使用道具 举报

ID:359272 发表于 2019-11-13 08:01 | 显示全部楼层
多谢分享
回复

使用道具 举报

ID:380802 发表于 2019-12-26 01:48 | 显示全部楼层
很好的资源,感谢楼主
回复

使用道具 举报

ID:660878 发表于 2019-12-27 14:11 | 显示全部楼层
学习了谢谢楼主
回复

使用道具 举报

ID:569027 发表于 2020-1-10 09:34 | 显示全部楼层
我测试过了,非常好用!谢谢你真样的做学问的人
回复

使用道具 举报

ID:407977 发表于 2020-6-7 10:07 | 显示全部楼层
刚刚试了,很好用。
回复

使用道具 举报

ID:881974 发表于 2021-3-31 08:09 | 显示全部楼层
为什么我试就不行
回复

使用道具 举报

ID:90970 发表于 2021-4-8 11:49 | 显示全部楼层
6050是九轴的么?不是吧
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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