久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 13122|回復(fù): 25
打印 上一主題 下一主題
收起左側(cè)

STM32F103C8T6測試MPU6050串口輸出 九軸姿態(tài)傳感器源碼

  [復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
在網(wǎng)上找了好久,沒找到合適的,后來就自己參照資料寫了一個(gè),用的最新版的keil5編寫,庫也是最新的。PB6、PB7為IIC接口讀取,PA9、PA10串口輸出數(shù)據(jù),效果如圖,三軸加速已經(jīng)校準(zhǔn)過,數(shù)據(jù)還算靈敏,eg:98代表加速度為9.8m/s 2 陀螺儀已經(jīng)能夠正常讀取,數(shù)據(jù)還未調(diào)校。有中文注釋,自行下載研究!



單片機(jī)源程序如下:
  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內(nèi)部地址
  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        //加速計(jì)自檢、測量范圍及高通濾波頻率,典型值: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地址寄存器(默認(rèn)數(shù)值0x68,只讀)


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

  41. #define        MPU6050_Addr   0xD0          //定義器件在IIC總線中的從地址,根據(jù)ALT  ADDRESS地址引腳不同修改

  42. unsigned char TX_DATA[4];           //顯示據(jù)緩存區(qū)

  43. unsigned char BUF0[10];       //接收數(shù)據(jù)緩存區(qū)
  44. unsigned char BUF1[10];       //接收數(shù)據(jù)緩存區(qū)
  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. /* 函數(shù)申明 -----------------------------------------------*/
  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;     //取余運(yùn)算
  77.     *++s =temp_data/10+0x30;
  78.     temp_data=temp_data%10;      //取余運(yùn)算
  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; //這里可以優(yōu)化速度        ,經(jīng)測試最低到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線為高電平則總線出錯(cuò),退出
  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發(fā)送
  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) //數(shù)據(jù)從高位到低位//發(fā)送數(shù)據(jù)
  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)  //數(shù)據(jù)從高位到低位//讀取字節(jié)
  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. //單字節(jié)寫入*******************************************

  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);   //發(fā)送設(shè)備地址+寫信號//I2C_SendByte(((REG_Address & 0x0700) >>7) | SlaveAddress & 0xFFFE);//設(shè)置高起始地址+器件地址
  282.     if(!I2C_WaitAck()){I2C_Stop(); return FALSE;}
  283.     I2C_SendByte(REG_Address );   //設(shè)置低起始地址      
  284.     I2C_WaitAck();       
  285.     I2C_SendByte(REG_data);
  286.     I2C_WaitAck();   
  287.     I2C_Stop();
  288.     delay5ms();
  289.     return TRUE;
  290. }

  291. //單字節(jié)讀取*****************************************
  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);//設(shè)置高起始地址+器件地址
  296.     if(!I2C_WaitAck()){I2C_Stop();test=1; return FALSE;}
  297.     I2C_SendByte((u8) REG_Address);   //設(shè)置低起始地址      
  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. ** 函數(shù)名稱 : RCC_Configuration(void)
  311. ** 函數(shù)功能 : 時(shí)鐘初始化
  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. ** 函數(shù)名稱 : GPIO_Configuration(void)
  362. ** 函數(shù)功能 : 端口初始化
  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;                 // 復(fù)用推挽輸出
  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. ** 函數(shù)名稱 : USART1_Configuration(void)
  386. ** 函數(shù)功能 : 串口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;                        // 時(shí)鐘低電平活動
  398. USART_ClockInitStructure.USART_CPOL = USART_CPOL_Low;                                // 時(shí)鐘低電平
  399. USART_ClockInitStructure.USART_CPHA = USART_CPHA_2Edge;                                // 時(shí)鐘第二個(gè)邊沿進(jìn)行數(shù)據(jù)捕獲
  400. USART_ClockInitStructure.USART_LastBit = USART_LastBit_Disable;                // 最后一位數(shù)據(jù)的時(shí)鐘脈沖不從SCLK輸出
  401. /* Configure the USART1 synchronous paramters */
  402. USART_ClockInit(USART1, &USART_ClockInitStructure);                                        // 時(shí)鐘參數(shù)初始化設(shè)置
  403.                                                                                                                                          
  404. USART_InitStructure.USART_BaudRate = 115200;                                                  // 波特率為:115200
  405. USART_InitStructure.USART_WordLength = USART_WordLength_8b;                          // 8位數(shù)據(jù)
  406. USART_InitStructure.USART_StopBits = USART_StopBits_1;                                  // 在幀結(jié)尾傳輸1個(gè)停止位
  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;                  // 發(fā)送使能+接收使能
  410. /* Configure USART1 basic and asynchronous paramters */
  411. USART_Init(USART1, &USART_InitStructure);
  412.    
  413.   /* Enable USART1 */
  414. USART_ClearFlag(USART1, USART_IT_RXNE);                         //清中斷,以免一啟用中斷后立即產(chǎn)生中斷
  415. USART_ITConfig(USART1,USART_IT_RXNE, ENABLE);                //使能USART1中斷源
  416. USART_Cmd(USART1, ENABLE);                                                        //USART1總開關(guān):開啟
  417. }

  418. /*
  419. ********************************************************************************
  420. ** 函數(shù)名稱 : NVIC_Configuration(void)
  421. ** 函數(shù)功能 : 中斷初始化
  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. ** 函數(shù)名稱 : WWDG_Configuration(void)
  438. ** 函數(shù)功能 : 看門狗初始化
  439. ** 輸    入        : 無
  440. ** 輸    出        : 無
  441. ** 返    回        : 無
  442. ********************************************************************************
  443. */
  444. void WWDG_Configuration(void)
  445. {
  446.   RCC_APB1PeriphClockCmd(RCC_APB1Periph_WWDG, ENABLE);        //   WWDG時(shí)鐘使能
  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. ** 函數(shù)名稱 : Delay(vu32 nCount)
  461. ** 函數(shù)功能 : 延時(shí)函數(shù)
  462. ** 輸    入        : 無
  463. ** 輸    出        : 無
  464. ** 返    回        : 無
  465. ********************************************************************************
  466. */
  467. void Delay(vu32 nCount)
  468. {
  469.   for(; nCount != 0; nCount--);
  470. }

  471. /*
  472. ********************************************************************************
  473. ** 函數(shù)名稱 : void Delayms(vu32 m)
  474. ** 函數(shù)功能 : 長延時(shí)函數(shù)         m=1,延時(shí)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. ** 函數(shù)名稱 : WWDG_IRQHandler(void)
  490. ** 函數(shù)功能 : 窗口提前喚醒中斷
  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,根據(jù)需要請參考pdf進(jìn)行修改************************
  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);        //解除休眠狀態(tài)
  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數(shù)據(jù)****************************************
  528. void READ_MPU6050(void)
  529. {
  530.         /*        讀取陀螺儀數(shù)據(jù)                */
  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;                                                    //讀取計(jì)算X軸數(shù)據(jù)

  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;                                                    //讀取計(jì)算Y軸數(shù)據(jù)
  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;                                                //讀取計(jì)算Z軸數(shù)據(jù)

  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;// 讀取計(jì)算出溫度
  549.        
  550.         //ACCEL_ZOUT_L
  551.         //*************************************************************
  552.                 /*        讀取加速度數(shù)據(jù)                */
  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;                                                    //讀取計(jì)算X軸數(shù)據(jù)

  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;                                                    //讀取計(jì)算Y軸數(shù)據(jù)
  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;                                                //讀取計(jì)算Z軸數(shù)據(jù)
  567.         //*************************************************************
  568. }
  569. //********串口發(fā)送數(shù)據(jù)***************************************
  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. ** 函數(shù)名稱 : main(void)
  581. ** 函數(shù)功能 : 主函數(shù)
  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);                                 //延時(shí)
  594.   Init_MPU6050();                     //初始化MPU6050
  595.   while(1)
  596. {
  597.         READ_MPU6050();                 //讀取MPU6050數(shù)據(jù)
  598. //輸出陀螺儀
  599.          printf("Gyroscope: ");
  600.   DATA_printf(TX_DATA,G_X);//轉(zhuǎn)換X軸數(shù)據(jù)到數(shù)組
  601.         Send_data('X');                         //發(fā)送X軸數(shù)
  602.         DATA_printf(TX_DATA,G_Y);//轉(zhuǎn)換Y軸數(shù)據(jù)到數(shù)組
  603.         Send_data('Y');                         //發(fā)送Y軸數(shù)
  604.         DATA_printf(TX_DATA,G_Z);//轉(zhuǎn)換Z軸數(shù)據(jù)到數(shù)組
  605.         Send_data('Z');                         //發(fā)送Z軸數(shù)
  606.         DATA_printf(TX_DATA,T_T);//轉(zhuǎn)換溫度數(shù)據(jù)到數(shù)組
  607.         Send_data('T');                         //發(fā)送溫度數(shù)據(jù)
  608.         USART1_SendData(0X0D);         //換行
  609.         USART1_SendData(0X0A);         //回車
  610. //輸出加速度
  611.          printf("Acceleration: ");
  612.   DATA_printf(TX_DATA,A_X);//轉(zhuǎn)換X軸數(shù)據(jù)到數(shù)組
  613.         Send_data('X');                         //發(fā)送X軸數(shù)
  614.         DATA_printf(TX_DATA,A_Y);//轉(zhuǎn)換Y軸數(shù)據(jù)到數(shù)組
  615.         Send_data('Y');                         //發(fā)送Y軸數(shù)
  616.         DATA_printf(TX_DATA,A_Z);//轉(zhuǎn)換Z軸數(shù)據(jù)到數(shù)組
  617.         Send_data('Z');                         //發(fā)送Z軸數(shù)

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

  625. /*************結(jié)束***************/
復(fù)制代碼

所有資料51hei提供下載:
九軸姿態(tài)傳感器STM32F103C8T6串口程序.rar (298.14 KB, 下載次數(shù): 561)


評分

參與人數(shù) 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎(jiǎng)勵(lì)!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏12 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

沙發(fā)
ID:260931 發(fā)表于 2018-5-18 08:47 | 只看該作者
我去賺黑幣先,等下再下你!
回復(fù)

使用道具 舉報(bào)

板凳
ID:336631 發(fā)表于 2018-5-23 16:52 | 只看該作者
很給力哦
回復(fù)

使用道具 舉報(bào)

地板
ID:400671 發(fā)表于 2018-9-20 22:14 | 只看該作者
我去賺黑幣先,等下再下你!
回復(fù)

使用道具 舉報(bào)

5#
ID:225515 發(fā)表于 2018-11-19 22:50 | 只看該作者
很不錯(cuò)~~~
回復(fù)

使用道具 舉報(bào)

6#
ID:225515 發(fā)表于 2018-11-19 22:50 | 只看該作者
很好的資源,剛剛好需要用到,樓主牛逼
回復(fù)

使用道具 舉報(bào)

7#
ID:225515 發(fā)表于 2018-11-19 22:50 | 只看該作者
剛剛好需要用到,樓主牛逼,找了很久在這里找到;
回復(fù)

使用道具 舉報(bào)

8#
ID:380922 發(fā)表于 2019-1-14 13:46 | 只看該作者
樓主牛逼!,不過這好像是直接用模擬IIC讀MPU的原始數(shù)據(jù)吧,沒經(jīng)過DMP處理吧,角度那好像不太對
回復(fù)

使用道具 舉報(bào)

9#
ID:378985 發(fā)表于 2019-1-23 10:02 | 只看該作者
樓主牛逼,完全好用,100分!
回復(fù)

使用道具 舉報(bào)

10#
ID:170847 發(fā)表于 2019-4-29 17:27 | 只看該作者
為毛我燒進(jìn)去沒反應(yīng),接口都是對應(yīng)的
回復(fù)

使用道具 舉報(bào)

11#
ID:301268 發(fā)表于 2019-5-10 18:34 | 只看該作者
很有用,感謝樓主
回復(fù)

使用道具 舉報(bào)

12#
ID:301268 發(fā)表于 2019-5-10 18:37 | 只看該作者
先去賺取黑幣,希望樓主給的程序有用
回復(fù)

使用道具 舉報(bào)

13#
ID:301268 發(fā)表于 2019-5-15 15:12 | 只看該作者
燒錄后沒有顯示啊,不太行啊
回復(fù)

使用道具 舉報(bào)

14#
ID:466188 發(fā)表于 2019-5-16 15:46 | 只看該作者
為什么傳回來的是一些符號呢?
回復(fù)

使用道具 舉報(bào)

15#
ID:397670 發(fā)表于 2019-5-22 15:02 | 只看該作者
很不錯(cuò)
回復(fù)

使用道具 舉報(bào)

16#
ID:543896 發(fā)表于 2019-5-22 22:04 | 只看該作者
這個(gè)論壇還有基本上一樣的,格式都一樣,http://www.zg4o1577.cn/bbs/dpj-29287-1.html  不知道是誰抄襲誰的,居然只改動了一下標(biāo)識,抄襲的人可恥呀。
回復(fù)

使用道具 舉報(bào)

17#
ID:490640 發(fā)表于 2019-7-19 23:06 | 只看該作者
角度怎么計(jì)算。〗嵌仍趺从(jì)算!角度怎么計(jì)算。〗嵌仍趺从(jì)算!感謝樓主,學(xué)習(xí)學(xué)習(xí)!!
回復(fù)

使用道具 舉報(bào)

18#
ID:260931 發(fā)表于 2019-9-17 08:10 | 只看該作者
謝謝樓主分享
回復(fù)

使用道具 舉報(bào)

19#
ID:457185 發(fā)表于 2019-11-12 17:25 | 只看該作者
參考一下,現(xiàn)在還在嫌九軸陀螺儀太貴了
回復(fù)

使用道具 舉報(bào)

20#
ID:359272 發(fā)表于 2019-11-13 08:01 | 只看該作者
多謝分享
回復(fù)

使用道具 舉報(bào)

21#
ID:380802 發(fā)表于 2019-12-26 01:48 | 只看該作者
很好的資源,感謝樓主
回復(fù)

使用道具 舉報(bào)

22#
ID:660878 發(fā)表于 2019-12-27 14:11 | 只看該作者
學(xué)習(xí)了謝謝樓主
回復(fù)

使用道具 舉報(bào)

23#
ID:569027 發(fā)表于 2020-1-10 09:34 | 只看該作者
我測試過了,非常好用!謝謝你真樣的做學(xué)問的人
回復(fù)

使用道具 舉報(bào)

24#
ID:407977 發(fā)表于 2020-6-7 10:07 | 只看該作者
剛剛試了,很好用。
回復(fù)

使用道具 舉報(bào)

25#
ID:881974 發(fā)表于 2021-3-31 08:09 | 只看該作者
為什么我試就不行
回復(fù)

使用道具 舉報(bào)

26#
ID:90970 發(fā)表于 2021-4-8 11:49 | 只看該作者
6050是九軸的么?不是吧
回復(fù)

使用道具 舉報(bào)

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 亚洲国产视频一区二区 | 亚洲高清电影 | 国产精品色 | 亚洲国产精品人人爽夜夜爽 | 一区二区三区四区在线免费观看 | 九九在线 | 国产一区二区三区在线 | 亚洲狠狠丁香婷婷综合久久久 | 国产小视频在线 | 久久久精品视频免费看 | 日本手机看片 | 欧美国产日韩精品 | va精品 | 一区二区福利视频 | 麻豆国产精品777777在线 | 激情一区二区三区 | 亚洲a视频 | 99热精品6 | 久久婷婷香蕉热狠狠综合 | 成人影院网站ww555久久精品 | 欧美乱大交xxxxx另类电影 | 欧美视频在线观看 | 亚洲午夜在线 | 精品欧美色视频网站在线观看 | 欧美成人精品一区二区男人看 | 精品一区二区三区四区在线 | 开操网 | 99热在线播放 | 欧美一级三级在线观看 | 秋霞在线一区 | 日日夜夜精品视频 | 91免费在线看 | 亚洲精品日本 | 久久国产精品视频 | 日韩午夜影院 | 先锋资源在线 | 欧美精品一区二区三区视频 | 国产一区二区视频在线 | 日韩精品一区二区在线观看 | 久久亚| 久草a√ |