找回密码
 立即注册

QQ登录

只需一步,快速开始

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

MPU9250资料与源码-九轴9轴姿态 加速度 陀螺仪 指南针

  [复制链接]
跳转到指定楼层
楼主
MPU9250资料-九轴9轴姿态 加速度 陀螺仪 指南针


所有资料51hei提供下载:
MPU9250 9DOF 九轴9轴姿态 加速度 陀螺仪 指南针 磁场传感器.rar (5.59 MB, 下载次数: 320)



单片机源程序如下:

  1. /*******************************************************************************
  2. // GY-9250 GY-9150  IIC测试程序
  3. // 使用单片机STM32F103C8T6
  4. // 晶振:8.00M
  5. // 编译环境 Keil uVision4
  6. // 时间:2012年5月1日
  7. // 与模块连接 GPIOB6->SCL GPIOB7->SDA      
  8. // 使用:STM32F103C8T6串口1连接电脑
  9. // 电脑串口助手显示,波特率:115200

  10. *******************************************************************************/

  11. #include "stm32f10x_lib.h"
  12. #include  <math.h>    //Keil library  

  13. GPIO_InitTypeDef GPIO_InitStructure;
  14. ErrorStatus HSEStartUpStatus;

  15. #define   uchar unsigned char
  16. #define   uint unsigned int       

  17. // 定义MPU9250内部地址
  18. //****************************************
  19. #define        SMPLRT_DIV                0x19        //陀螺仪采样率,典型值:0x07(125Hz)
  20. #define        CONFIG                        0x1A        //低通滤波频率,典型值:0x06(5Hz)
  21. #define        GYRO_CONFIG                0x1B        //陀螺仪自检及测量范围,典型值:0x18(不自检,2000deg/s)
  22. #define        ACCEL_CONFIG        0x1C        //加速计自检、测量范围及高通滤波频率,典型值:0x01(不自检,2G,5Hz)

  23. #define        ACCEL_XOUT_H        0x3B
  24. #define        ACCEL_XOUT_L        0x3C
  25. #define        ACCEL_YOUT_H        0x3D
  26. #define        ACCEL_YOUT_L        0x3E
  27. #define        ACCEL_ZOUT_H        0x3F
  28. #define        ACCEL_ZOUT_L        0x40

  29. #define        TEMP_OUT_H                0x41
  30. #define        TEMP_OUT_L                0x42

  31. #define        GYRO_XOUT_H                0x43
  32. #define        GYRO_XOUT_L                0x44       
  33. #define        GYRO_YOUT_H                0x45
  34. #define        GYRO_YOUT_L                0x46
  35. #define        GYRO_ZOUT_H                0x47
  36. #define        GYRO_ZOUT_L                0x48

  37.                
  38. #define MAG_XOUT_L                0x03
  39. #define MAG_XOUT_H                0x04
  40. #define MAG_YOUT_L                0x05
  41. #define MAG_YOUT_H                0x06
  42. #define MAG_ZOUT_L                0x07
  43. #define MAG_ZOUT_H                0x08


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


  46. //****************************

  47. #define        GYRO_ADDRESS   0xD0          //陀螺地址
  48. #define MAG_ADDRESS    0x18   //磁场地址
  49. #define ACCEL_ADDRESS  0xD0

  50. unsigned char TX_DATA[4];           //显示据缓存区
  51. unsigned char BUF[10];       //接收数据缓存区
  52. char  test=0;                                  //IIC用到
  53. short T_X,T_Y,T_Z,T_T;                 //X,Y,Z轴,温度

  54. //************************************
  55. /*模拟IIC端口输出输入定义*/
  56. #define SCL_H         GPIOB->BSRR = GPIO_Pin_6
  57. #define SCL_L         GPIOB->BRR  = GPIO_Pin_6
  58.    
  59. #define SDA_H         GPIOB->BSRR = GPIO_Pin_7
  60. #define SDA_L         GPIOB->BRR  = GPIO_Pin_7

  61. #define SCL_read      GPIOB->IDR  & GPIO_Pin_6
  62. #define SDA_read      GPIOB->IDR  & GPIO_Pin_7

  63. /* 函数申明 -----------------------------------------------*/
  64. void RCC_Configuration(void);
  65. void GPIO_Configuration(void);
  66. void NVIC_Configuration(void);
  67. void USART1_Configuration(void);
  68. void WWDG_Configuration(void);
  69. void Delay(u32 nTime);
  70. void Delayms(vu32 m);  
  71. /* 变量定义 ----------------------------------------------*/

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

  86. /*******************************************************************************
  87. * Function Name  : I2C_GPIO_Config
  88. * Description    : Configration Simulation IIC GPIO
  89. * Input          : None
  90. * Output         : None
  91. * Return         : None
  92. ****************************************************************************** */
  93. void I2C_GPIO_Config(void)
  94. {
  95.   GPIO_InitTypeDef  GPIO_InitStructure;

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

  100.   GPIO_InitStructure.GPIO_Pin =  GPIO_Pin_7;
  101.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  102.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_OD;
  103.   GPIO_Init(GPIOB, &GPIO_InitStructure);
  104. }

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

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

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

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

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

  307.         REG_data= I2C_RadeByte();
  308.     I2C_NoAck();
  309.     I2C_Stop();
  310.     //return TRUE;
  311.         return REG_data;

  312. }                                                     

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

  326.   /* Enable HSE */
  327.   RCC_HSEConfig(RCC_HSE_ON);

  328.   /* Wait till HSE is ready */
  329.   HSEStartUpStatus = RCC_WaitForHSEStartUp();

  330.   if(HSEStartUpStatus == SUCCESS)
  331.   {
  332.     /* HCLK = SYSCLK */
  333.     RCC_HCLKConfig(RCC_SYSCLK_Div1);
  334.   
  335.     /* PCLK2 = HCLK */
  336.     RCC_PCLK2Config(RCC_HCLK_Div1);

  337.     /* PCLK1 = HCLK/2 */
  338.     RCC_PCLK1Config(RCC_HCLK_Div2);

  339.     /* Flash 2 wait state */
  340.     FLASH_SetLatency(FLASH_Latency_2);
  341.     /* Enable Prefetch Buffer */
  342.     FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);

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

  345.     /* Enable PLL */
  346.     RCC_PLLCmd(ENABLE);

  347.     /* Wait till PLL is ready */
  348.     while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)
  349.     {
  350.     }

  351.     /* Select PLL as system clock source */
  352.     RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);

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

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

  387. }

  388. /*
  389. ********************************************************************************
  390. ** 函数名称 : USART1_Configuration(void)
  391. ** 函数功能 : 串口1初始化
  392. ** 输    入        : 无
  393. ** 输    出        : 无
  394. ** 返    回        : 无
  395. ********************************************************************************
  396. */
  397. void USART1_Configuration(void)
  398. {

  399. USART_InitTypeDef USART_InitStructure;
  400. USART_ClockInitTypeDef  USART_ClockInitStructure;

  401. RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM1 |RCC_APB2Periph_USART1, ENABLE  );

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

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


  423. /*
  424. ********************************************************************************
  425. ** 函数名称 : NVIC_Configuration(void)
  426. ** 函数功能 : 中断初始化
  427. ** 输    入        : 无
  428. ** 输    出        : 无
  429. ** 返    回        : 无
  430. ********************************************************************************
  431. */
  432. void NVIC_Configuration(void)
  433. {
  434.   NVIC_InitTypeDef NVIC_InitStructure;  
  435.   NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);

  436.   NVIC_InitStructure.NVIC_IRQChannel = WWDG_IRQChannel;
  437.   NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
  438.   NVIC_Init(&NVIC_InitStructure);

  439. }

  440. /*
  441. ********************************************************************************
  442. ** 函数名称 : WWDG_Configuration(void)
  443. ** 函数功能 : 看门狗初始化
  444. ** 输    入        : 无
  445. ** 输    出        : 无
  446. ** 返    回        : 无
  447. ********************************************************************************
  448. */
  449. void WWDG_Configuration(void)
  450. {
  451.   RCC_APB1PeriphClockCmd(RCC_APB1Periph_WWDG, ENABLE);       
  452.   WWDG_SetPrescaler(WWDG_Prescaler_8);                      //  WWDG clock counter = (PCLK1/4096)/8 = 244 Hz (~4 ms)  
  453.   WWDG_SetWindowValue(0x41);                                 // Set Window value to 0x41
  454.   WWDG_Enable(0x50);                       // Enable WWDG and set counter value to 0x7F, WWDG timeout = ~4 ms * 64 = 262 ms
  455.   WWDG_ClearFlag();                               // Clear EWI flag
  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. //初始化MPU9250,根据需要请参考pdf进行修改************************
  511. void Init_MPU9250(void)
  512. {
  513. /*
  514.    Single_Write(GYRO_ADDRESS,PWR_M, 0x80);   //
  515.    Single_Write(GYRO_ADDRESS,SMPL, 0x07);    //
  516.    Single_Write(GYRO_ADDRESS,DLPF, 0x1E);    //±2000°
  517.    Single_Write(GYRO_ADDRESS,INT_C, 0x00 );  //
  518.    Single_Write(GYRO_ADDRESS,PWR_M, 0x00);   //
  519. */
  520.   Single_Write(GYRO_ADDRESS,PWR_MGMT_1, 0x00);        //解除休眠状态
  521.         Single_Write(GYRO_ADDRESS,SMPLRT_DIV, 0x07);
  522.         Single_Write(GYRO_ADDRESS,CONFIG, 0x06);
  523.         Single_Write(GYRO_ADDRESS,GYRO_CONFIG, 0x18);
  524.         Single_Write(GYRO_ADDRESS,ACCEL_CONFIG, 0x01);
  525.   //----------------
  526. //        Single_Write(GYRO_ADDRESS,0x6A,0x00);//close Master Mode       

  527. }
  528.        
  529. //******读取MPU9250数据****************************************
  530. void READ_MPU9250_ACCEL(void)
  531. {

  532.    BUF[0]=Single_Read(ACCEL_ADDRESS,ACCEL_XOUT_L);
  533.    BUF[1]=Single_Read(ACCEL_ADDRESS,ACCEL_XOUT_H);
  534.    T_X=        (BUF[1]<<8)|BUF[0];
  535.    T_X/=164;                                                    //读取计算X轴数据

  536.    BUF[2]=Single_Read(ACCEL_ADDRESS,ACCEL_YOUT_L);
  537.    BUF[3]=Single_Read(ACCEL_ADDRESS,ACCEL_YOUT_H);
  538.    T_Y=        (BUF[3]<<8)|BUF[2];
  539.    T_Y/=164;                                                    //读取计算Y轴数据
  540.    BUF[4]=Single_Read(ACCEL_ADDRESS,ACCEL_ZOUT_L);
  541.    BUF[5]=Single_Read(ACCEL_ADDRESS,ACCEL_ZOUT_H);
  542.    T_Z=        (BUF[5]<<8)|BUF[4];
  543.    T_Z/=164;                                                //读取计算Z轴数据

  544. }

  545. void READ_MPU9250_GYRO(void)
  546. {

  547.    BUF[0]=Single_Read(GYRO_ADDRESS,GYRO_XOUT_L);
  548.    BUF[1]=Single_Read(GYRO_ADDRESS,GYRO_XOUT_H);
  549.    T_X=        (BUF[1]<<8)|BUF[0];
  550.    T_X/=16.4;                                                    //读取计算X轴数据

  551.    BUF[2]=Single_Read(GYRO_ADDRESS,GYRO_YOUT_L);
  552.    BUF[3]=Single_Read(GYRO_ADDRESS,GYRO_YOUT_H);
  553.    T_Y=        (BUF[3]<<8)|BUF[2];
  554.    T_Y/=16.4;                                                    //读取计算Y轴数据
  555.    BUF[4]=Single_Read(GYRO_ADDRESS,GYRO_ZOUT_L);
  556.    BUF[5]=Single_Read(GYRO_ADDRESS,GYRO_ZOUT_H);
  557.    T_Z=        (BUF[5]<<8)|BUF[4];
  558.    T_Z/=16.4;                                                //读取计算Z轴数据


  559.   // BUF[6]=Single_Read(GYRO_ADDRESS,TEMP_OUT_L);
  560.   // BUF[7]=Single_Read(GYRO_ADDRESS,TEMP_OUT_H);
  561.   // T_T=(BUF[7]<<8)|BUF[6];
  562.   // T_T = 35+ ((double) (T_T + 13200)) / 280;// 读取计算出温度
  563. }


  564. void READ_MPU9250_MAG(void)
  565. {
  566.    Single_Write(GYRO_ADDRESS,0x37,0x02);//turn on Bypass Mode
  567.    Delayms(10);       
  568.    Single_Write(MAG_ADDRESS,0x0A,0x01);
  569.    Delayms(10);       
  570.    BUF[0]=Single_Read (MAG_ADDRESS,MAG_XOUT_L);
  571.    BUF[1]=Single_Read (MAG_ADDRESS,MAG_XOUT_H);
  572.    T_X=(BUF[1]<<8)|BUF[0];

  573.    BUF[2]=Single_Read(MAG_ADDRESS,MAG_YOUT_L);
  574. ……………………

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


评分

参与人数 2黑币 +53 收起 理由
凭栏尽处 + 3 赞一个!
admin + 50 共享资料的黑币奖励!

查看全部评分

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

使用道具 举报

沙发
ID:284472 发表于 2018-3-9 15:18 | 只看该作者
很有用
回复

使用道具 举报

板凳
ID:303403 发表于 2018-4-8 18:40 | 只看该作者

为什么我编译都通不过
回复

使用道具 举报

地板
ID:303403 发表于 2018-4-8 18:41 | 只看该作者
为什么我编译都通不过
回复

使用道具 举报

5#
ID:349774 发表于 2018-6-13 10:49 | 只看该作者
学习了,先下载下来。
回复

使用道具 举报

6#
ID:90169 发表于 2018-7-25 19:17 来自手机 | 只看该作者
不错,学习了
回复

使用道具 举报

7#
ID:331281 发表于 2019-1-14 10:03 | 只看该作者
51能不能用呢,感觉运算量太大了,考虑成本想着用51来写
回复

使用道具 举报

8#
ID:475043 发表于 2019-5-12 11:26 | 只看该作者
感谢楼主的分享!!试试看!
回复

使用道具 举报

9#
ID:583711 发表于 2019-7-13 22:55 | 只看该作者
很经典的代码
回复

使用道具 举报

10#
ID:712537 发表于 2020-4-7 14:38 | 只看该作者
代码能正常出结果吗?我运行了好像不行。
回复

使用道具 举报

11#
ID:102688 发表于 2020-4-9 20:45 | 只看该作者
参考好资料,感谢分享,
回复

使用道具 举报

12#
ID:801466 发表于 2021-6-20 16:08 | 只看该作者
有 姿态 计算吗
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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