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

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開始

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

單片機(jī)mpu6050三軸加速器源程序

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
程序絕對(duì)可用的


單片機(jī)源程序如下:
  1. //****************************************
  2. // 功能: 顯示加速度計(jì)和陀螺儀的10位原始數(shù)據(jù)
  3. //****************************************
  4. // GY-52 MPU3050 IIC測(cè)試程序

  5. //****************************************
  6. #include <REG52.H>        
  7. #include <math.h>    //Keil library  
  8. #include <stdio.h>   //Keil library        
  9. #include <INTRINS.H>
  10. typedef unsigned char  uchar;
  11. typedef unsigned short ushort;
  12. typedef unsigned int   uint;
  13. //****************************************
  14. // 定義51單片機(jī)端口
  15. //****************************************
  16. #define DataPort P0                //LCD1602數(shù)據(jù)端口
  17. sbit    SCL=P1^0;                        //IIC時(shí)鐘引腳定義
  18. sbit    SDA=P1^1;                        //IIC數(shù)據(jù)引腳定義
  19. sbit    LCM_RS=P2^0;                //LCD1602命令端口               
  20. sbit    LCM_RW=P2^1;                //LCD1602命令端口               
  21. sbit    LCM_EN=P2^2;                //LCD1602命令端口
  22. //****************************************
  23. // 定義MPU6050內(nèi)部地址
  24. //****************************************
  25. #define        SMPLRT_DIV                0x19        //陀螺儀采樣率,典型值:0x07(125Hz)
  26. #define        CONFIG                        0x1A        //低通濾波頻率,典型值:0x06(5Hz)
  27. #define        GYRO_CONFIG                0x1B        //陀螺儀自檢及測(cè)量范圍,典型值:0x18(不自檢,2000deg/s)
  28. #define        ACCEL_CONFIG        0x1C        //加速計(jì)自檢、測(cè)量范圍及高通濾波頻率,典型值:0x01(不自檢,2G,5Hz)
  29. #define        ACCEL_XOUT_H        0x3B
  30. #define        ACCEL_XOUT_L        0x3C
  31. #define        ACCEL_YOUT_H        0x3D
  32. #define        ACCEL_YOUT_L        0x3E
  33. #define        ACCEL_ZOUT_H        0x3F
  34. #define        ACCEL_ZOUT_L        0x40
  35. #define        TEMP_OUT_H                0x41
  36. #define        TEMP_OUT_L                0x42
  37. #define        GYRO_XOUT_H                0x43
  38. #define        GYRO_XOUT_L                0x44        
  39. #define        GYRO_YOUT_H                0x45
  40. #define        GYRO_YOUT_L                0x46
  41. #define        GYRO_ZOUT_H                0x47
  42. #define        GYRO_ZOUT_L                0x48
  43. #define        PWR_MGMT_1                0x6B        //電源管理,典型值:0x00(正常啟用)
  44. #define        WHO_AM_I                        0x75        //IIC地址寄存器(默認(rèn)數(shù)值0x68,只讀)
  45. #define        SlaveAddress        0xD0        //IIC寫入時(shí)的地址字節(jié)數(shù)據(jù),+1為讀取
  46. //****************************************
  47. //定義類型及變量
  48. //****************************************
  49. uchar dis[4];                                                        //顯示數(shù)字(-511至512)的字符數(shù)組
  50. int        dis_data;                                                //變量
  51. //int        Temperature,Temp_h,Temp_l;        //溫度及高低位數(shù)據(jù)
  52. //****************************************
  53. //函數(shù)聲明
  54. //****************************************
  55. void  delay(unsigned int k);                                                                                //延時(shí)
  56. //LCD相關(guān)函數(shù)
  57. void  InitLcd();                                                                                                                //初始化lcd1602
  58. void  lcd_printf(uchar *s,int temp_data);
  59. void  WriteDataLCM(uchar dataW);                                                                        //LCD數(shù)據(jù)
  60. void  WriteCommandLCM(uchar CMD,uchar Attribc);                                //LCD指令
  61. void  DisplayOneChar(uchar X,uchar Y,uchar DData);                        //顯示一個(gè)字符
  62. void  DisplayListChar(uchar X,uchar Y,uchar *DData,L);        //顯示字符串
  63. //MPU6050操作函數(shù)
  64. void  InitMPU6050();                                                                                                        //初始化MPU6050
  65. void  Delay5us();
  66. void  I2C_Start();
  67. void  I2C_Stop();
  68. void  I2C_SendACK(bit ack);
  69. bit   I2C_RecvACK();
  70. void  I2C_SendByte(uchar dat);
  71. uchar I2C_RecvByte();
  72. void  I2C_ReadPage();
  73. void  I2C_WritePage();
  74. void  display_ACCEL_x();
  75. void  display_ACCEL_y();
  76. void  display_ACCEL_z();
  77. uchar Single_ReadI2C(uchar REG_Address);                                                //讀取I2C數(shù)據(jù)
  78. void  Single_WriteI2C(uchar REG_Address,uchar REG_data);        //向I2C寫入數(shù)據(jù)
  79. //****************************************
  80. //整數(shù)轉(zhuǎn)字符串
  81. //****************************************
  82. void lcd_printf(uchar *s,int temp_data)
  83. {
  84.         if(temp_data<0)
  85.         {
  86.                 temp_data=-temp_data;
  87.                 *s='-';
  88.         }
  89.         else *s=' ';
  90.         *++s =temp_data/100+0x30;
  91.         temp_data=temp_data%100;     //取余運(yùn)算
  92.         *++s =temp_data/10+0x30;
  93.         temp_data=temp_data%10;      //取余運(yùn)算
  94.         *++s =temp_data+0x30;         
  95. }
  96. //****************************************
  97. //延時(shí)
  98. //****************************************
  99. void delay(unsigned int k)        
  100. {                                                
  101.         unsigned int i,j;                                
  102.         for(i=0;i<k;i++)
  103.         {                        
  104.                 for(j=0;j<121;j++);
  105.         }                                                
  106. }
  107. //****************************************
  108. //LCD1602初始化
  109. //****************************************
  110. void InitLcd()                                
  111. {                        
  112.         WriteCommandLCM(0x38,1);        
  113.         WriteCommandLCM(0x08,1);        
  114.         WriteCommandLCM(0x01,1);        
  115.         WriteCommandLCM(0x06,1);        
  116.         WriteCommandLCM(0x0c,1);
  117.         DisplayOneChar(0,0,'S');
  118.         DisplayOneChar(0,1,'Y');
  119. }                        
  120. //****************************************
  121. //LCD1602寫允許
  122. //****************************************
  123. void WaitForEnable(void)        
  124. {                                       
  125.         DataPort=0xff;               
  126.         LCM_RS=0;LCM_RW=1;_nop_();
  127.         LCM_EN=1;_nop_();_nop_();
  128.         while(DataPort&0x80);        
  129.         LCM_EN=0;                                
  130. }                                       
  131. //****************************************
  132. //LCD1602寫入命令
  133. //****************************************
  134. void WriteCommandLCM(uchar CMD,uchar Attribc)
  135. {                                       
  136.         if(Attribc)WaitForEnable();        
  137.         LCM_RS=0;LCM_RW=0;_nop_();
  138.         DataPort=CMD;_nop_();        
  139.         LCM_EN=1;_nop_();_nop_();LCM_EN=0;
  140. }                                       
  141. //****************************************
  142. //LCD1602寫入數(shù)據(jù)
  143. //****************************************
  144. void WriteDataLCM(uchar dataW)
  145. {                                       
  146.         WaitForEnable();               
  147.         LCM_RS=1;LCM_RW=0;_nop_();
  148.         DataPort=dataW;_nop_();        
  149.         LCM_EN=1;_nop_();_nop_();LCM_EN=0;
  150. }               
  151. //****************************************
  152. //LCD1602寫入一個(gè)字符
  153. //****************************************
  154. void DisplayOneChar(uchar X,uchar Y,uchar DData)
  155. {                                                
  156.         Y&=1;                                                
  157.         X&=15;                                                
  158.         if(Y)X|=0x40;                                       
  159.         X|=0x80;                        
  160.         WriteCommandLCM(X,0);               
  161.         WriteDataLCM(DData);               
  162. }                                                
  163. //****************************************
  164. //LCD1602顯示字符串
  165. //****************************************
  166. void DisplayListChar(uchar X,uchar Y,uchar *DData,L)
  167. {
  168.         uchar ListLength=0;
  169.         Y&=0x1;               
  170.         X&=0xF;               
  171.         while(L--)            
  172.         {                       
  173.                 DisplayOneChar(X,Y,DData[ListLength]);
  174.                 ListLength++;  
  175.                 X++;                        
  176.         }   
  177. }
  178. //**************************************
  179. //延時(shí)5微秒(STC90C52RC@12M)
  180. //不同的工作環(huán)境,需要調(diào)整此函數(shù)
  181. //當(dāng)改用1T的MCU時(shí),請(qǐng)調(diào)整此延時(shí)函數(shù)
  182. //**************************************
  183. void Delay5us()
  184. {
  185.         _nop_();_nop_();_nop_();_nop_();
  186.         _nop_();_nop_();_nop_();_nop_();
  187.         _nop_();_nop_();_nop_();_nop_();
  188.         _nop_();_nop_();_nop_();_nop_();
  189.         _nop_();_nop_();_nop_();_nop_();
  190.         _nop_();_nop_();_nop_();_nop_();
  191. }
  192. //**************************************
  193. //I2C起始信號(hào)
  194. //**************************************
  195. void I2C_Start()
  196. {
  197.     SDA = 1;                    //拉高數(shù)據(jù)線
  198.     SCL = 1;                    //拉高時(shí)鐘線
  199.     Delay5us();                 //延時(shí)
  200.     SDA = 0;                    //產(chǎn)生下降沿
  201.     Delay5us();                 //延時(shí)
  202.     SCL = 0;                    //拉低時(shí)鐘線
  203. }
  204. //**************************************
  205. //I2C停止信號(hào)
  206. //**************************************
  207. void I2C_Stop()
  208. {
  209.     SDA = 0;                    //拉低數(shù)據(jù)線
  210.     SCL = 1;                    //拉高時(shí)鐘線
  211.     Delay5us();                 //延時(shí)
  212.     SDA = 1;                    //產(chǎn)生上升沿
  213.     Delay5us();                 //延時(shí)
  214. }
  215. //**************************************
  216. //I2C發(fā)送應(yīng)答信號(hào)
  217. //入口參數(shù):ack (0:ACK 1:NAK)
  218. //**************************************
  219. void I2C_SendACK(bit ack)
  220. {
  221.     SDA = ack;                  //寫應(yīng)答信號(hào)
  222.     SCL = 1;                    //拉高時(shí)鐘線
  223.     Delay5us();                 //延時(shí)
  224.     SCL = 0;                    //拉低時(shí)鐘線
  225.     Delay5us();                 //延時(shí)
  226. }
  227. //**************************************
  228. //I2C接收應(yīng)答信號(hào)
  229. //**************************************
  230. bit I2C_RecvACK()
  231. {
  232.     SCL = 1;                    //拉高時(shí)鐘線
  233.     Delay5us();                 //延時(shí)
  234.     CY = SDA;                   //讀應(yīng)答信號(hào)
  235.     SCL = 0;                    //拉低時(shí)鐘線
  236.     Delay5us();                 //延時(shí)
  237.     return CY;
  238. }
  239. //**************************************
  240. //向I2C總線發(fā)送一個(gè)字節(jié)數(shù)據(jù)
  241. //**************************************
  242. void I2C_SendByte(uchar dat)
  243. {
  244.     uchar i;
  245.     for (i=0; i<8; i++)         //8位計(jì)數(shù)器
  246.     {
  247.         dat <<= 1;              //移出數(shù)據(jù)的最高位
  248.         SDA = CY;               //送數(shù)據(jù)口
  249.         SCL = 1;                //拉高時(shí)鐘線
  250.         Delay5us();             //延時(shí)
  251.         SCL = 0;                //拉低時(shí)鐘線
  252.         Delay5us();             //延時(shí)
  253.     }
  254.     I2C_RecvACK();
  255. }
  256. //**************************************
  257. //從I2C總線接收一個(gè)字節(jié)數(shù)據(jù)
  258. //**************************************
  259. uchar I2C_RecvByte()
  260. {
  261.     uchar i;
  262.     uchar dat = 0;
  263.     SDA = 1;                    //使能內(nèi)部上拉,準(zhǔn)備讀取數(shù)據(jù),
  264.     for (i=0; i<8; i++)         //8位計(jì)數(shù)器
  265.     {
  266.         dat <<= 1;
  267.         SCL = 1;                //拉高時(shí)鐘線
  268.         Delay5us();             //延時(shí)
  269.         dat |= SDA;             //讀數(shù)據(jù)               
  270.         SCL = 0;                //拉低時(shí)鐘線
  271.         Delay5us();             //延時(shí)
  272.     }
  273.     return dat;
  274. }
  275. //**************************************
  276. //向I2C設(shè)備寫入一個(gè)字節(jié)數(shù)據(jù)
  277. //**************************************
  278. void Single_WriteI2C(uchar REG_Address,uchar REG_data)
  279. {
  280.     I2C_Start();                  //起始信號(hào)
  281.     I2C_SendByte(SlaveAddress);   //發(fā)送設(shè)備地址+寫信號(hào)
  282.     I2C_SendByte(REG_Address);    //內(nèi)部寄存器地址,
  283.     I2C_SendByte(REG_data);       //內(nèi)部寄存器數(shù)據(jù),
  284.     I2C_Stop();                   //發(fā)送停止信號(hào)
  285. }
  286. //**************************************
  287. //從I2C設(shè)備讀取一個(gè)字節(jié)數(shù)據(jù)
  288. //**************************************
  289. uchar Single_ReadI2C(uchar REG_Address)
  290. {
  291.         uchar REG_data;
  292.         I2C_Start();                   //起始信號(hào)
  293.         I2C_SendByte(SlaveAddress);    //發(fā)送設(shè)備地址+寫信號(hào)
  294.         I2C_SendByte(REG_Address);     //發(fā)送存儲(chǔ)單元地址,從0開始        
  295.         I2C_Start();                   //起始信號(hào)
  296.         I2C_SendByte(SlaveAddress+1);  //發(fā)送設(shè)備地址+讀信號(hào)
  297.         REG_data=I2C_RecvByte();       //讀出寄存器數(shù)據(jù)
  298.         I2C_SendACK(1);                //接收應(yīng)答信號(hào)
  299.         I2C_Stop();                    //停止信號(hào)
  300.         return REG_data;
  301. }
  302. //**************************************
  303. //初始化MPU6050
  304. //**************************************
  305. void InitMPU6050()
  306. {
  307.         Single_WriteI2C(PWR_MGMT_1, 0x00);        //解除休眠狀態(tài)
  308.         Single_WriteI2C(SMPLRT_DIV, 0x07);
  309.         Single_WriteI2C(CONFIG, 0x06);
  310.         Single_WriteI2C(GYRO_CONFIG, 0x18);
  311.         Single_WriteI2C(ACCEL_CONFIG, 0x01);
  312. }
  313. //**************************************
  314. //合成數(shù)據(jù)
  315. //**************************************
  316. int GetData(uchar REG_Address)
  317. {
  318.         char H,L;
  319.         H=Single_ReadI2C(REG_Address);
  320.         L=Single_ReadI2C(REG_Address+1);
  321.         return (H<<8)+L;   //合成數(shù)據(jù)
  322. }
  323. //**************************************
  324. //在1602上顯示10位數(shù)據(jù)
  325. //**************************************
  326. void Display10BitData(int value,uchar x,uchar y)
  327. {
  328.         value/=64;                                                        //轉(zhuǎn)換為10位數(shù)據(jù)
  329.         lcd_printf(dis, value);                        //轉(zhuǎn)換數(shù)據(jù)顯示
  330.         DisplayListChar(x,y,dis,4);        //啟始列,行,顯示數(shù)組,顯示長(zhǎng)度
  331. }
  332. //**************************************
  333. //顯示溫度
  334. //**************************************
  335. //void display_temp()
  336. //{
  337. //        Temp_h=Single_ReadI2C(TEMP_OUT_H); //讀取溫度
  338. //        Temp_l=Single_ReadI2C(TEMP_OUT_L); //讀取溫度
  339. //        Temperature=Temp_h<<8|Temp_l;     //合成溫度
  340. //        Temperature = 35+ ((double) (Temperature + 13200)) / 280; // 計(jì)算出溫度
  341. //        lcd_printf(dis,Temperature);     //轉(zhuǎn)換數(shù)據(jù)顯示
  342. //        DisplayListChar(11,1,dis,4);     //啟始列,行,顯示數(shù)組,顯示位數(shù)
  343. //}
  344. //*********************************************************
  345. //主程序
  346. //*********************************************************
  347. void main()
  348. {
  349.         delay(500);                //上電延時(shí)               
  350.         InitLcd();                //液晶初始化
  351.         InitMPU6050();        //初始化MPU6050
  352.         delay(150);
  353.         while(1)
  354.         {
  355.                 Display10BitData(GetData(ACCEL_XOUT_H),2,0);        //顯示X軸加速度
  356.                 Display10BitData(GetData(ACCEL_YOUT_H),7,0);        //顯示Y軸加速度
  357.                 Display10BitData(GetData(ACCEL_ZOUT_H),12,0);        //顯示Z軸加速度
  358.                 Display10BitData(GetData(GYRO_XOUT_H),2,1);        //顯示X軸角速度
  359.                 Display10BitData(GetData(GYRO_YOUT_H),7,1);        //顯示Y軸角速度
  360.                 Display10BitData(GetData(GYRO_ZOUT_H),12,1);        //顯示Z軸角速度
  361.                 delay(500);
  362.         }
  363. }
復(fù)制代碼

所有資料51hei提供下載:
mpu6050三軸加速器程序.zip (37.62 KB, 下載次數(shù): 23)



評(píng)分

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

查看全部評(píng)分

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

使用道具 舉報(bào)

本版積分規(guī)則

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

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

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 欧美一级片 | 日韩一区不卡 | av在线免费观看网站 | 国产乱码久久久久久 | 中文字幕精品一区 | 91视频在线看| 久久久久久久久久影视 | 久久一区二区视频 | 欧美久久不卡 | 久在线视频播放免费视频 | 国产精品区一区二区三区 | 国产在线观看一区二区 | 成人网视频 | 狠狠操婷婷 | 亚洲精品日韩综合观看成人91 | 高清一区二区三区 | 午夜精品一区 | 黄网站涩免费蜜桃网站 | 亚洲欧美在线观看 | 久久青青 | 欧美涩 | 日韩中文字幕第一页 | 97精品国产97久久久久久免费 | 国产一级片精品 | h漫在线观看 | 国产成人精品网站 | 久久天堂 | 国产精品一区二区av | 国产精品一区久久久 | 国产精品性做久久久久久 | 久久精品一区二区 | 超碰在线97国产 | 日韩在线视频免费观看 | 人人爽人人爽人人片av | 国户精品久久久久久久久久久不卡 | 成人三级视频在线观看 | 国产亚洲网站 | 久久激情网| 国产一区二区日韩 | 国产精品久久久久久久久久久久久 | 成人精品一区二区三区四区 |