找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

帖子
查看: 3878|回復: 0
打印 上一主題 下一主題
收起左側

mpu6050顯示加速度計和陀螺儀的10位原始數據 51單片機和arduino源碼

[復制鏈接]
跳轉到指定樓層
樓主
ID:222908 發(fā)表于 2017-8-3 08:54 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
其中包含了1602,和串口的顯示。


單片機源程序如下:
  1. //****************************************
  2. // Update to MPU6050 by shinetop
  3. // MCU: STC89C52
  4. // 2012.3.1
  5. // 功能: 顯示加速度計和陀螺儀的10位原始數據
  6. //****************************************
  7. // GY-52 MPU3050 IIC測試程序
  8. // 使用單片機STC89C51
  9. // 晶振:11.0592M
  10. // 顯示:LCD1602
  11. // 編譯環(huán)境 Keil uVision2
  12. // 參考宏晶網站24c04通信程序
  13. // 時間:2011年9月1日
  14. // QQ:531389319
  15. //****************************************
  16. #include <REG52.H>       
  17. #include <math.h>    //Keil library  
  18. #include <stdio.h>   //Keil library       
  19. #include <INTRINS.H>
  20. typedef unsigned char  uchar;
  21. typedef unsigned short ushort;
  22. typedef unsigned int   uint;
  23. //****************************************
  24. // 定義51單片機端口
  25. //****************************************
  26. #define DataPort P0                //LCD1602數據端口
  27. sbit    SCL=P1^0;                        //IIC時鐘引腳定義
  28. sbit    SDA=P1^1;                        //IIC數據引腳定義
  29. sbit    LCM_RS=P2^0;                //LCD1602命令端口               
  30. sbit    LCM_RW=P2^1;                //LCD1602命令端口               
  31. sbit    LCM_EN=P2^2;                //LCD1602命令端口
  32. //****************************************
  33. // 定義MPU6050內部地址
  34. //****************************************
  35. #define        SMPLRT_DIV                0x19        //陀螺儀采樣率,典型值:0x07(125Hz)
  36. #define        CONFIG                        0x1A        //低通濾波頻率,典型值:0x06(5Hz)
  37. #define        GYRO_CONFIG                0x1B        //陀螺儀自檢及測量范圍,典型值:0x18(不自檢,2000deg/s)
  38. #define        ACCEL_CONFIG        0x1C        //加速計自檢、測量范圍及高通濾波頻率,典型值:0x01(不自檢,2G,5Hz)
  39. #define        ACCEL_XOUT_H        0x3B
  40. #define        ACCEL_XOUT_L        0x3C
  41. #define        ACCEL_YOUT_H        0x3D
  42. #define        ACCEL_YOUT_L        0x3E
  43. #define        ACCEL_ZOUT_H        0x3F
  44. #define        ACCEL_ZOUT_L        0x40
  45. #define        TEMP_OUT_H                0x41
  46. #define        TEMP_OUT_L                0x42
  47. #define        GYRO_XOUT_H                0x43
  48. #define        GYRO_XOUT_L                0x44       
  49. #define        GYRO_YOUT_H                0x45
  50. #define        GYRO_YOUT_L                0x46
  51. #define        GYRO_ZOUT_H                0x47
  52. #define        GYRO_ZOUT_L                0x48
  53. #define        PWR_MGMT_1                0x6B        //電源管理,典型值:0x00(正常啟用)
  54. #define        WHO_AM_I                        0x75        //IIC地址寄存器(默認數值0x68,只讀)
  55. #define        SlaveAddress        0xD0        //IIC寫入時的地址字節(jié)數據,+1為讀取
  56. //****************************************
  57. //定義類型及變量
  58. //****************************************
  59. uchar dis[6];                                                        //顯示數字(-511至512)的字符數組
  60. int        dis_data;                                                //變量
  61. //int        Temperature,Temp_h,Temp_l;        //溫度及高低位數據
  62. //****************************************
  63. //函數聲明
  64. //****************************************
  65. void  delay(unsigned int k);                                                                                //延時                                               
  66. void  lcd_printf(uchar *s,int temp_data);

  67. //MPU6050操作函數
  68. void  InitMPU6050();                                                                                                        //初始化MPU6050
  69. void  Delay5us();
  70. void  I2C_Start();
  71. void  I2C_Stop();
  72. void  I2C_SendACK(bit ack);
  73. bit   I2C_RecvACK();
  74. void  I2C_SendByte(uchar dat);
  75. uchar I2C_RecvByte();
  76. void  I2C_ReadPage();
  77. void  I2C_WritePage();
  78. void  display_ACCEL_x();
  79. void  display_ACCEL_y();
  80. void  display_ACCEL_z();
  81. uchar Single_ReadI2C(uchar REG_Address);                                                //讀取I2C數據
  82. void  Single_WriteI2C(uchar REG_Address,uchar REG_data);        //向I2C寫入數據
  83. //****************************************
  84. //整數轉字符串
  85. //****************************************
  86. void lcd_printf(uchar *s,int temp_data)
  87. {
  88.         if(temp_data<0)
  89.         {
  90.                 temp_data=-temp_data;
  91.                 *s='-';
  92.         }
  93.         else *s=' ';

  94.         *++s =temp_data/10000+0x30;
  95.         temp_data=temp_data%10000;     //取余運算

  96.         *++s =temp_data/1000+0x30;
  97.         temp_data=temp_data%1000;     //取余運算

  98.         *++s =temp_data/100+0x30;
  99.         temp_data=temp_data%100;     //取余運算
  100.         *++s =temp_data/10+0x30;
  101.         temp_data=temp_data%10;      //取余運算
  102.         *++s =temp_data+0x30;        
  103. }
  104. //****************************************

  105. void  SeriPushSend(uchar send_data)
  106. {
  107.     SBUF=send_data;  
  108.         while(!TI);TI=0;          
  109. }
  110. //****************************************
  111. //延時
  112. //****************************************
  113. void delay(unsigned int k)       
  114. {                                               
  115.         unsigned int i,j;                               
  116.         for(i=0;i<k;i++)
  117.         {                       
  118.                 for(j=0;j<121;j++);
  119.         }                                               
  120. }

  121. //**************************************
  122. //延時5微秒(STC90C52RC@12M)
  123. //不同的工作環(huán)境,需要調整此函數
  124. //當改用1T的MCU時,請調整此延時函數
  125. //**************************************
  126. void Delay5us()
  127. {
  128.         _nop_();_nop_();_nop_();_nop_();
  129.         _nop_();_nop_();_nop_();_nop_();
  130.         _nop_();_nop_();_nop_();_nop_();
  131.         _nop_();_nop_();_nop_();_nop_();
  132.         _nop_();_nop_();_nop_();_nop_();
  133.         _nop_();_nop_();_nop_();_nop_();
  134. }
  135. //**************************************
  136. //I2C起始信號
  137. //**************************************
  138. void I2C_Start()
  139. {
  140.     SDA = 1;                    //拉高數據線
  141.     SCL = 1;                    //拉高時鐘線
  142.     Delay5us();                 //延時
  143.     SDA = 0;                    //產生下降沿
  144.     Delay5us();                 //延時
  145.     SCL = 0;                    //拉低時鐘線
  146. }
  147. //**************************************
  148. //I2C停止信號
  149. //**************************************
  150. void I2C_Stop()
  151. {
  152.     SDA = 0;                    //拉低數據線
  153.     SCL = 1;                    //拉高時鐘線
  154.     Delay5us();                 //延時
  155.     SDA = 1;                    //產生上升沿
  156.     Delay5us();                 //延時
  157. }
  158. //**************************************
  159. //I2C發(fā)送應答信號
  160. //入口參數:ack (0:ACK 1:NAK)
  161. //**************************************
  162. void I2C_SendACK(bit ack)
  163. {
  164.     SDA = ack;                  //寫應答信號
  165.     SCL = 1;                    //拉高時鐘線
  166.     Delay5us();                 //延時
  167.     SCL = 0;                    //拉低時鐘線
  168.     Delay5us();                 //延時
  169. }
  170. //**************************************
  171. //I2C接收應答信號
  172. //**************************************
  173. bit I2C_RecvACK()
  174. {
  175.     SCL = 1;                    //拉高時鐘線
  176.     Delay5us();                 //延時
  177.     CY = SDA;                   //讀應答信號
  178.     SCL = 0;                    //拉低時鐘線
  179.     Delay5us();                 //延時
  180.     return CY;
  181. }
  182. //**************************************
  183. //向I2C總線發(fā)送一個字節(jié)數據
  184. //**************************************
  185. void I2C_SendByte(uchar dat)
  186. {
  187.     uchar i;
  188.     for (i=0; i<8; i++)         //8位計數器
  189.     {
  190.         dat <<= 1;              //移出數據的最高位
  191.         SDA = CY;               //送數據口
  192.         SCL = 1;                //拉高時鐘線
  193.         Delay5us();             //延時
  194.         SCL = 0;                //拉低時鐘線
  195.         Delay5us();             //延時
  196.     }
  197.     I2C_RecvACK();
  198. }
  199. //**************************************
  200. //從I2C總線接收一個字節(jié)數據
  201. //**************************************
  202. uchar I2C_RecvByte()
  203. {
  204.     uchar i;
  205.     uchar dat = 0;
  206.     SDA = 1;                    //使能內部上拉,準備讀取數據,
  207.     for (i=0; i<8; i++)         //8位計數器
  208.     {
  209.         dat <<= 1;
  210.         SCL = 1;                //拉高時鐘線
  211.         Delay5us();             //延時
  212.         dat |= SDA;             //讀數據               
  213.         SCL = 0;                //拉低時鐘線
  214.         Delay5us();             //延時
  215.     }
  216.     return dat;
  217. }
  218. //**************************************
  219. //向I2C設備寫入一個字節(jié)數據
  220. //**************************************
  221. void Single_WriteI2C(uchar REG_Address,uchar REG_data)
  222. {
  223.     I2C_Start();                  //起始信號
  224.     I2C_SendByte(SlaveAddress);   //發(fā)送設備地址+寫信號
  225.     I2C_SendByte(REG_Address);    //內部寄存器地址,
  226.     I2C_SendByte(REG_data);       //內部寄存器數據,
  227.     I2C_Stop();                   //發(fā)送停止信號
  228. }
  229. //**************************************
  230. //從I2C設備讀取一個字節(jié)數據
  231. //**************************************
  232. uchar Single_ReadI2C(uchar REG_Address)
  233. {
  234.         uchar REG_data;
  235.         I2C_Start();                   //起始信號
  236.         I2C_SendByte(SlaveAddress);    //發(fā)送設備地址+寫信號
  237.         I2C_SendByte(REG_Address);     //發(fā)送存儲單元地址,從0開始       
  238.         I2C_Start();                   //起始信號
  239.         I2C_SendByte(SlaveAddress+1);  //發(fā)送設備地址+讀信號
  240.         REG_data=I2C_RecvByte();       //讀出寄存器數據
  241.         I2C_SendACK(1);                //接收應答信號
  242.         I2C_Stop();                    //停止信號
  243.         return REG_data;
  244. }
  245. //**************************************
  246. //初始化MPU6050
  247. //**************************************
  248. void InitMPU6050()
  249. {
  250.         Single_WriteI2C(PWR_MGMT_1, 0x00);        //解除休眠狀態(tài)
  251.         Single_WriteI2C(SMPLRT_DIV, 0x07);
  252.         Single_WriteI2C(CONFIG, 0x06);
  253.         Single_WriteI2C(GYRO_CONFIG, 0x18);
  254.         Single_WriteI2C(ACCEL_CONFIG, 0x01);
  255. }
  256. //**************************************
  257. //合成數據
  258. //**************************************
  259. int GetData(uchar REG_Address)
  260. {
  261.         uchar H,L;
  262.         H=Single_ReadI2C(REG_Address);
  263.         L=Single_ReadI2C(REG_Address+1);
  264.         return (H<<8)+L;   //合成數據
  265. }
  266. //**************************************
  267. //在1602上顯示10位數據
  268. //**************************************
  269. void Display10BitData(int value,uchar x,uchar y)
  270. {  uchar i;
  271. //        value/=64;                                                        //轉換為10位數據
  272.         lcd_printf(dis, value);                        //轉換數據顯示
  273.         for(i=0;i<6;i++)
  274.         {
  275.     SeriPushSend(dis[i]);
  276.     }

  277.   //         DisplayListChar(x,y,dis,4);        //啟始列,行,顯示數組,顯示長度
  278. }
  279. //**************************************
  280. //顯示溫度
  281. //**************************************
  282. //void display_temp()
  283. //{
  284. //        Temp_h=Single_ReadI2C(TEMP_OUT_H); //讀取溫度
  285. //        Temp_l=Single_ReadI2C(TEMP_OUT_L); //讀取溫度
  286. //        Temperature=Temp_h<<8|Temp_l;     //合成溫度
  287. //        Temperature = 35+ ((double) (Temperature + 13200)) / 280; // 計算出溫度
  288. //        lcd_printf(dis,Temperature);     //轉換數據顯示
  289. //        DisplayListChar(11,1,dis,4);     //啟始列,行,顯示數組,顯示位數
  290. //}

  291. void init_uart()
  292. {
  293.         TMOD=0x21;                               
  294. ……………………

  295. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼

所有資料51hei提供下載:
mpu-6050資料.rar (2.86 MB, 下載次數: 32)


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

使用道具 舉報

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

本版積分規(guī)則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表