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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 5169|回復: 6
打印 上一主題 下一主題
收起左側

單片機+BMP180+LCD1602溫度氣壓高度計源程序

[復制鏈接]
跳轉到指定樓層
樓主
ID:33449 發表于 2018-11-3 10:36 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
89c90單片機做的1602液晶顯示BMP180氣壓

單片機源程序如下:
  1. #include  <REG52.H>
  2. #include  <math.h>    //Keil library
  3. #include  <stdlib.h>  //Keil library
  4. #include  <stdio.h>   //Keil library
  5. #include  <INTRINS.H> //Keil library

  6. #define   uchar unsigned char
  7. #define   uint unsigned int
  8. #define BMP085_SlaveAddress   0xee  //定義器件在IIC總線中的從地址                              
  9. #define OSS 0// Oversampling Setting (note: code is not set up to use other OSS values)
  10. #define   DataPort P0    //LCD1602數據端口

  11. sbit      LCM_RS=P2^4;   //LCD1602命令端口               
  12. sbit      LCM_RW=P2^5;   //LCD1602命令端口               
  13. sbit      LCM_EN=P2^6;   //LCD1602命令端口
  14. sbit  SCL=P1^0;      //IIC時鐘引腳定義
  15. sbit   SDA=P1^1;      //IIC數據引腳定義
  16. int  dis_data;                              //變量
  17. typedef unsigned char  BYTE;
  18. typedef unsigned short WORD;
  19. long  temperature;//溫度值
  20. long  pressure;//壓力值
  21. long  height;//相對海拔高度值
  22. short ac1;
  23. short ac2;
  24. short ac3;
  25. unsigned short ac4;
  26. unsigned short ac5;
  27. unsigned short ac6;
  28. short b1;
  29. short b2;
  30. short mb;
  31. short mc;
  32. short md;

  33. void delay(unsigned int k)        
  34. {                                                
  35. unsigned int i,j;                                
  36. for(i=0;i<k;i++)
  37. {                        
  38. for(j=0;j<121;j++)                        
  39. {;}}                                                
  40. }
  41. /*******************************/
  42. void WaitForEnable(void)        
  43. {                                       
  44. DataPort=0xff;               
  45. LCM_RS=0;LCM_RW=1;_nop_();
  46. LCM_EN=1;_nop_();_nop_();
  47. while(DataPort&0x80);        
  48. LCM_EN=0;                                
  49. }                                       
  50. /*******************************/
  51. void WriteCommandLCM(uchar CMD,uchar Attribc)
  52. {                                       
  53. if(Attribc)WaitForEnable();        
  54. LCM_RS=0;LCM_RW=0;_nop_();
  55. DataPort=CMD;_nop_();        
  56. LCM_EN=1;_nop_();_nop_();LCM_EN=0;
  57. }                                       
  58. /*******************************/
  59. void WriteDataLCM(uchar dataW)
  60. {                                       
  61. WaitForEnable();               
  62. LCM_RS=1;LCM_RW=0;_nop_();
  63. DataPort=dataW;_nop_();        
  64. LCM_EN=1;_nop_();_nop_();LCM_EN=0;
  65. }               
  66. /***********************************/
  67. void InitLcd()                                
  68. {                        
  69. WriteCommandLCM(0x38,1);        
  70. WriteCommandLCM(0x08,1);        
  71. WriteCommandLCM(0x01,1);        
  72. WriteCommandLCM(0x06,1);        
  73. WriteCommandLCM(0x0c,1);
  74. }                        
  75. /***********************************/
  76. void DisplayOneChar(uchar X,uchar Y,uchar DData)
  77. {                                                
  78. Y&=1;                                                
  79. X&=15;                                                
  80. if(Y)X|=0x40;                                       
  81. X|=0x80;                        
  82. WriteCommandLCM(X,0);               
  83. WriteDataLCM(DData);               
  84. }                                                
  85. ///**************************************
  86. //延時5微秒(STC90C52RC@12M)
  87. //不同的工作環境,需要調整此函數,注意時鐘過快時需要修改
  88. //當改用1T的MCU時,請調整此延時函數
  89. //**************************************/
  90. //void Delay5us();
  91. void Delay5us()
  92. {
  93. _nop_();_nop_();_nop_();_nop_();
  94. _nop_();_nop_();_nop_();_nop_();
  95. _nop_();_nop_();_nop_();_nop_();
  96. _nop_();_nop_();_nop_();_nop_();
  97. }
  98. /**************************************
  99. 延時5毫秒(STC90C52RC@12M)
  100. 不同的工作環境,需要調整此函數
  101. 當改用1T的MCU時,請調整此延時函數
  102. **************************************/
  103. void Delay5ms()
  104. {
  105.     WORD n = 560;
  106.     while (n--);
  107. }
  108. /**************************************
  109. 起始信號
  110. **************************************/
  111. void BMP085_Start()
  112. {
  113.     SDA = 1;                    //拉高數據線
  114.     SCL = 1;                    //拉高時鐘線
  115.     Delay5us();                 //延時
  116.     SDA = 0;                    //產生下降沿
  117.     Delay5us();                 //延時
  118.     SCL = 0;                    //拉低時鐘線
  119. }
  120. /**************************************
  121. 停止信號
  122. **************************************/
  123. void BMP085_Stop()
  124. {
  125.     SDA = 0;                    //拉低數據線
  126.     SCL = 1;                    //拉高時鐘線
  127.     Delay5us();                 //延時
  128.     SDA = 1;                    //產生上升沿
  129.     Delay5us();                 //延時
  130. }

  131. /**************************************
  132. 發送應答信號
  133. 入口參數:ack (0:ACK 1:NAK)
  134. **************************************/
  135. void BMP085_SendACK(bit ack)
  136. {
  137.     SDA = ack;                  //寫應答信號
  138.     SCL = 1;                    //拉高時鐘線
  139.     Delay5us();                 //延時
  140.     SCL = 0;                    //拉低時鐘線
  141.     Delay5us();                 //延時
  142. }
  143. /**************************************
  144. 接收應答信號
  145. **************************************/
  146. bit BMP085_RecvACK()
  147. {
  148.     SCL = 1;                    //拉高時鐘線
  149.     Delay5us();                 //延時
  150.     CY = SDA;                   //讀應答信號
  151.     SCL = 0;                    //拉低時鐘線
  152.     Delay5us();                 //延時
  153.     return CY;
  154. }
  155. /**************************************
  156. 向IIC總線發送一個字節數據
  157. **************************************/
  158. void BMP085_SendByte(BYTE dat)
  159. {
  160.     BYTE i;
  161.     for (i=0; i<8; i++)         //8位計數器
  162.     {
  163.         dat <<= 1;              //移出數據的最高位
  164.         SDA = CY;               //送數據口
  165.         SCL = 1;                //拉高時鐘線
  166.         Delay5us();             //延時
  167.         SCL = 0;                //拉低時鐘線
  168.         Delay5us();             //延時
  169.     }
  170.     BMP085_RecvACK();
  171. }
  172. /**************************************
  173. 從IIC總線接收一個字節數據
  174. **************************************/
  175. BYTE BMP085_RecvByte()
  176. {
  177.     BYTE i;
  178.     BYTE dat = 0;
  179.     SDA = 1;                    //使能內部上拉,準備讀取數據,
  180.     for (i=0; i<8; i++)         //8位計數器
  181.     {
  182.         dat <<= 1;
  183.         SCL = 1;                //拉高時鐘線
  184.         Delay5us();             //延時
  185.         dat |= SDA;             //讀數據              
  186.         SCL = 0;                //拉低時鐘線
  187.         Delay5us();             //延時
  188. }
  189.     return dat;
  190. }
  191. //*********************************************************
  192. //讀出BMP085內部數據,連續兩個
  193. //*********************************************************
  194. short Multiple_read(uchar ST_Address)
  195. {
  196.     uchar msb, lsb;
  197.     short _data;
  198.     BMP085_Start();                          //起始信號
  199.     BMP085_SendByte(BMP085_SlaveAddress);    //發送設備地址+寫信號
  200.     BMP085_SendByte(ST_Address);             //發送存儲單元地址
  201.     BMP085_Start();                          //起始信號
  202.     BMP085_SendByte(BMP085_SlaveAddress+1);         //發送設備地址+讀信號
  203.     msb = BMP085_RecvByte();                 //BUF[0]存儲
  204.     BMP085_SendACK(0);                       //回應ACK
  205.     lsb = BMP085_RecvByte();   
  206.     BMP085_SendACK(1);                       //最后一個數據需要回NOACK
  207.     BMP085_Stop();                           //停止信號
  208.     Delay5ms();
  209.     _data = msb << 8;
  210.     _data |= lsb;
  211.     return _data;
  212. }
  213. //********************************************************************
  214. long bmp085ReadTemp(void)
  215. {
  216.     BMP085_Start();                  //起始信號
  217.     BMP085_SendByte(BMP085_SlaveAddress);   //發送設備地址+寫信號
  218.     BMP085_SendByte(0xF4);          // write register address
  219.     BMP085_SendByte(0x2E);       // write register data for temp
  220.     BMP085_Stop();                   //發送停止信號
  221.     delay(10);// max time is 4.5ms
  222.     return (long) Multiple_read(0xF6);
  223. }
  224. //*************************************************************
  225. long bmp085ReadPressure(void)
  226. {
  227.     long pressure = 0;
  228.     BMP085_Start();                   //起始信號
  229.     BMP085_SendByte(BMP085_SlaveAddress);   //發送設備地址+寫信號
  230.     BMP085_SendByte(0xF4);          // write register address
  231.     BMP085_SendByte(0x34);         // write register data for pressure
  232.     BMP085_Stop();                    //發送停止信號
  233.     delay(10);                      // max time is 4.5ms
  234.     pressure = Multiple_read(0xF6);
  235.     pressure &= 0x0000FFFF;
  236.     return pressure;
  237. }
  238. //**************************************************************

  239. //初始化BMP085,根據需要請參考pdf進行修改**************
  240. void Init_BMP085()
  241. {
  242.     ac1 = Multiple_read(0xAA);
  243.     ac2 = Multiple_read(0xAC);
  244.     ac3 = Multiple_read(0xAE);
  245.     ac4 = Multiple_read(0xB0);
  246.     ac5 = Multiple_read(0xB2);
  247.     ac6 = Multiple_read(0xB4);
  248.     b1 =  Multiple_read(0xB6);
  249.     b2 =  Multiple_read(0xB8);
  250.     mb =  Multiple_read(0xBA);
  251.     mc =  Multiple_read(0xBC);
  252.     md =  Multiple_read(0xBE);
  253. }
  254. //***********************************************************************
  255. void bmp085Convert()//換算
  256. {
  257.   unsigned int ut;
  258.   unsigned long up;
  259.   long x1, x2, b5, b6, x3, b3, p;
  260.   unsigned long b4, b7;
  261.   ut = bmp085ReadTemp();   // 讀取溫度
  262.   up = bmp085ReadPressure();  // 讀取壓強
  263.   x1 = (((long)ut - (long)ac6)*(long)ac5) >> 15;
  264.   x2 = ((long) mc << 11) / (x1 + md);
  265.   b5 = x1 + x2;
  266.   temperature = ((b5 + 8) >> 4);
  267.   b6 = b5 - 4000;
  268.   // Calculate B3
  269.   x1 = (b2 * (b6 * b6)>>12)>>11;
  270.   x2 = (ac2 * b6)>>11;
  271.   x3 = x1 + x2;
  272.   b3 = (((((long)ac1)*4 + x3)<<OSS) + 2)>>2;
  273.   // Calculate B4
  274.   x1 = (ac3 * b6)>>13;
  275.   x2 = (b1 * ((b6 * b6)>>12))>>16;
  276.   x3 = ((x1 + x2) + 2)>>2;
  277.   b4 = (ac4 * (unsigned long)(x3 + 32768))>>15;
  278.   b7 = ((unsigned long)(up - b3) * (50000>>OSS));
  279.   if (b7 < 0x80000000)
  280.     p = (b7<<1)/b4;
  281.   else
  282.     p = (b7/b4)<<1;
  283.   x1 = (p>>8) * (p>>8);
  284.   x1 = (x1 * 3038)>>16;
  285.   x2 = (-7357 * p)>>16;
  286.   pressure = p+((x1 + x2 + 3791)>>4);
  287.   height=(101325-pressure)*843/100;
  288.   DisplayOneChar(0,0,'T');//溫度部分
  289.   DisplayOneChar(1,0,':');
  290.   DisplayOneChar(4,0,'.');
  291.   DisplayOneChar(6,0,0XDF);
  292.   DisplayOneChar(7,0,'C');
  293.   DisplayOneChar(9,0,'H');//海拔部分
  294.   DisplayOneChar(13,0,'.');
  295.   DisplayOneChar(15,0,'m');
  296.   DisplayOneChar(0,1,'P');//氣壓部分
  297.   DisplayOneChar(1,1,':');
  298.   DisplayOneChar(5,1,'.');
  299.   DisplayOneChar(7,1,'K');
  300.   DisplayOneChar(8,1,'p');
  301.   DisplayOneChar(2,0,temperature/100+48);
  302.   DisplayOneChar(3,0,temperature%100/10+48);
  303.   DisplayOneChar(5,0,temperature%10+48);
  304.   DisplayOneChar(10,0,height/10000+48);
  305.   DisplayOneChar(11,0,height%10000/1000+48);
  306.   DisplayOneChar(12,0,height%1000/100+48);
  307.   DisplayOneChar(14,0,height%100/10+48);
  308.   DisplayOneChar(2,1,pressure/100000+48);
  309.   DisplayOneChar(3,1,pressure%100000/10000+48);
  310.   DisplayOneChar(4,1,pressure%10000/1000+48);
  311.   DisplayOneChar(6,1,pressure%1000/100+48);
  312. }
  313. //*********************************************************
  314. //******主程序********
  315. //*********************************************************
  316. void main()
  317. {
  318.   delay(50);                           //上電延時               
  319.   InitLcd();                      //液晶初始化
  320.   Init_BMP085();                  //初始化BMP085
  321.   while(1)                        //循環
  322.   {
  323.     bmp085Convert();
  324.         delay(100);
  325.   }
  326. }
復制代碼

所有資料51hei提供下載:
LCD1602做的溫度氣壓高度計單片機程序.rar (42.17 KB, 下載次數: 93)


評分

參與人數 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

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

使用道具 舉報

沙發
ID:79544 發表于 2019-3-28 09:37 | 只看該作者
很詳細的注釋程序,感謝分享
回復

使用道具 舉報

板凳
ID:502076 發表于 2019-3-31 23:13 | 只看該作者
我也希望使用這個程序。
回復

使用道具 舉報

地板
ID:507691 發表于 2019-4-26 16:19 | 只看該作者
騰飛的龍 發表于 2019-3-28 09:37
很詳細的注釋程序,感謝分享

你的顯示是好的嘛
壓強有波動嗎
高度不會一直變化嗎
回復

使用道具 舉報

5#
ID:507691 發表于 2019-4-26 16:22 | 只看該作者
我顯示出來壓強會有波動,高度差更多,有什么辦法解決嗎
有人知道卡爾曼濾波怎么用到這嗎
回復

使用道具 舉報

6#
ID:645297 發表于 2019-11-28 19:48 | 只看該作者
里面有仿真嘛
回復

使用道具 舉報

7#
ID:787757 發表于 2020-6-23 15:42 來自手機 | 只看該作者
具體的連線怎么連?
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产精品99久久久久久久久 | 99re99| 精产国产伦理一二三区 | 国产精品久久久久久久久久免费看 | 亚洲精品视频在线观看免费 | www.欧美| 亚洲福利一区二区 | 日韩精品一区二区三区视频播放 | 中文在线亚洲 | 国产专区视频 | 国产精品乱码一区二区三区 | 国产福利在线视频 | 欧美日韩视频在线第一区 | 成人在线观看网址 | 久久久女女女女999久久 | 91免费看片 | 日日干干夜夜 | 国产在线中文字幕 | 最近最新中文字幕 | 亚洲国产成人久久综合一区,久久久国产99 | 狠狠色综合久久丁香婷婷 | 欧美成人激情 | 欧美日韩一区二区三区不卡视频 | 一区二区三区四区视频 | 伊人精品国产 | 7777在线视频 | 91小视频在线| 成人一区二区三区 | 午夜影院免费体验区 | 亚洲精品久久久久久久不卡四虎 | 人妖av | 91精品中文字幕一区二区三区 | 久久夜视频 | 黄色免费av | 少妇精品久久久久久久久久 | 亚洲一区二区中文字幕 | 日韩精品1区2区3区 爱爱综合网 | 福利久久 | 日韩免费中文字幕 | 乳色吐息在线观看 | 日韩在线观看中文字幕 |