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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 5144|回復: 6
收起左側

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

[復制鏈接]
ID:33449 發(fā)表于 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數(shù)據(jù)端口

  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數(shù)據(jù)引腳定義
  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. //不同的工作環(huán)境,需要調整此函數(shù),注意時鐘過快時需要修改
  88. //當改用1T的MCU時,請調整此延時函數(shù)
  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. 不同的工作環(huán)境,需要調整此函數(shù)
  101. 當改用1T的MCU時,請調整此延時函數(shù)
  102. **************************************/
  103. void Delay5ms()
  104. {
  105.     WORD n = 560;
  106.     while (n--);
  107. }
  108. /**************************************
  109. 起始信號
  110. **************************************/
  111. void BMP085_Start()
  112. {
  113.     SDA = 1;                    //拉高數(shù)據(jù)線
  114.     SCL = 1;                    //拉高時鐘線
  115.     Delay5us();                 //延時
  116.     SDA = 0;                    //產(chǎn)生下降沿
  117.     Delay5us();                 //延時
  118.     SCL = 0;                    //拉低時鐘線
  119. }
  120. /**************************************
  121. 停止信號
  122. **************************************/
  123. void BMP085_Stop()
  124. {
  125.     SDA = 0;                    //拉低數(shù)據(jù)線
  126.     SCL = 1;                    //拉高時鐘線
  127.     Delay5us();                 //延時
  128.     SDA = 1;                    //產(chǎn)生上升沿
  129.     Delay5us();                 //延時
  130. }

  131. /**************************************
  132. 發(fā)送應答信號
  133. 入口參數(shù):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總線發(fā)送一個字節(jié)數(shù)據(jù)
  157. **************************************/
  158. void BMP085_SendByte(BYTE dat)
  159. {
  160.     BYTE i;
  161.     for (i=0; i<8; i++)         //8位計數(shù)器
  162.     {
  163.         dat <<= 1;              //移出數(shù)據(jù)的最高位
  164.         SDA = CY;               //送數(shù)據(jù)口
  165.         SCL = 1;                //拉高時鐘線
  166.         Delay5us();             //延時
  167.         SCL = 0;                //拉低時鐘線
  168.         Delay5us();             //延時
  169.     }
  170.     BMP085_RecvACK();
  171. }
  172. /**************************************
  173. 從IIC總線接收一個字節(jié)數(shù)據(jù)
  174. **************************************/
  175. BYTE BMP085_RecvByte()
  176. {
  177.     BYTE i;
  178.     BYTE dat = 0;
  179.     SDA = 1;                    //使能內部上拉,準備讀取數(shù)據(jù),
  180.     for (i=0; i<8; i++)         //8位計數(shù)器
  181.     {
  182.         dat <<= 1;
  183.         SCL = 1;                //拉高時鐘線
  184.         Delay5us();             //延時
  185.         dat |= SDA;             //讀數(shù)據(jù)              
  186.         SCL = 0;                //拉低時鐘線
  187.         Delay5us();             //延時
  188. }
  189.     return dat;
  190. }
  191. //*********************************************************
  192. //讀出BMP085內部數(shù)據(jù),連續(xù)兩個
  193. //*********************************************************
  194. short Multiple_read(uchar ST_Address)
  195. {
  196.     uchar msb, lsb;
  197.     short _data;
  198.     BMP085_Start();                          //起始信號
  199.     BMP085_SendByte(BMP085_SlaveAddress);    //發(fā)送設備地址+寫信號
  200.     BMP085_SendByte(ST_Address);             //發(fā)送存儲單元地址
  201.     BMP085_Start();                          //起始信號
  202.     BMP085_SendByte(BMP085_SlaveAddress+1);         //發(fā)送設備地址+讀信號
  203.     msb = BMP085_RecvByte();                 //BUF[0]存儲
  204.     BMP085_SendACK(0);                       //回應ACK
  205.     lsb = BMP085_RecvByte();   
  206.     BMP085_SendACK(1);                       //最后一個數(shù)據(jù)需要回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);   //發(fā)送設備地址+寫信號
  218.     BMP085_SendByte(0xF4);          // write register address
  219.     BMP085_SendByte(0x2E);       // write register data for temp
  220.     BMP085_Stop();                   //發(fā)送停止信號
  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);   //發(fā)送設備地址+寫信號
  230.     BMP085_SendByte(0xF4);          // write register address
  231.     BMP085_SendByte(0x34);         // write register data for pressure
  232.     BMP085_Stop();                    //發(fā)送停止信號
  233.     delay(10);                      // max time is 4.5ms
  234.     pressure = Multiple_read(0xF6);
  235.     pressure &= 0x0000FFFF;
  236.     return pressure;
  237. }
  238. //**************************************************************

  239. //初始化BMP085,根據(jù)需要請參考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)                        //循環(huán)
  322.   {
  323.     bmp085Convert();
  324.         delay(100);
  325.   }
  326. }
復制代碼

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

評分

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

查看全部評分

回復

使用道具 舉報

ID:79544 發(fā)表于 2019-3-28 09:37 | 顯示全部樓層
很詳細的注釋程序,感謝分享
回復

使用道具 舉報

ID:502076 發(fā)表于 2019-3-31 23:13 | 顯示全部樓層
我也希望使用這個程序。
回復

使用道具 舉報

ID:507691 發(fā)表于 2019-4-26 16:19 | 顯示全部樓層
騰飛的龍 發(fā)表于 2019-3-28 09:37
很詳細的注釋程序,感謝分享

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

使用道具 舉報

ID:507691 發(fā)表于 2019-4-26 16:22 | 顯示全部樓層
我顯示出來壓強會有波動,高度差更多,有什么辦法解決嗎
有人知道卡爾曼濾波怎么用到這嗎
回復

使用道具 舉報

ID:645297 發(fā)表于 2019-11-28 19:48 | 顯示全部樓層
里面有仿真嘛
回復

使用道具 舉報

ID:787757 發(fā)表于 2020-6-23 15:42 來自手機 | 顯示全部樓層
具體的連線怎么連?
回復

使用道具 舉報

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

本版積分規(guī)則

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

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

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 一级黄色片免费 | 亚洲国产精品一区二区www | 天天精品在线 | 成人久久18免费网站 | 中文字幕在线视频一区二区三区 | 99tv| 久久亚洲精品久久国产一区二区 | 男女网站在线观看 | 精品美女视频在免费观看 | 久久夜色精品国产 | 黄色中文字幕 | 午夜欧美| 成人精品免费视频 | 国产精品久久久久久久久久久免费看 | 国产午夜视频 | 久久久久九九九女人毛片 | 久久精品国产久精国产 | 国产精品美女久久久久aⅴ国产馆 | 久久在线| 99久热在线精品视频观看 | 国产综合av | 欧美一a一片一级一片 | 男女激情网站免费 | 东京久久| 黄网在线观看 | 亚洲成人精品久久 | 影音先锋中文字幕在线观看 | 伊人久久精品一区二区三区 | 中文字幕一区二区三区在线乱码 | 亚洲啊v在线 | 91在线精品一区二区 | 91精品久久久久久久久99蜜臂 | 国产成人亚洲精品 | 日韩一区二区福利视频 | 91在线视频播放 | 999视频 | 无人区国产成人久久三区 | 久久久久国产 | 久久精品国产亚洲一区二区三区 | 亚洲欧美国产毛片在线 | 欧美日本韩国一区二区三区 |