版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
1、精選優(yōu)質文檔-傾情為你奉上基于51單片機SHT11溫濕度傳感器檢測程序(含電路圖)· · 下面是原理圖:下面是SHT11與MCU連接的典型電路:下面是源代碼:#include <reg52.h>#include <intrins.h>/* 宏定義*/#define uint unsigned int#define uchar unsigned char#define noACK 0#define ACK 1#define STATUS_REG_W 0x06#define STATUS_REG_R 0x07#define MEASURE_TEMP 0x
2、03#define MEASURE_HUMI 0x05#define RESET 0x1eenum TEMP,HUMI;typedef union /定義共用同類型 unsigned int i; float f; value;/* 位定義*/sbit lcdrs=P20;sbit lcdrw=P21;sbit lcden=P22;sbit SCK = P10;sbit DATA = P11;/* 變量定義*/uchar table2="SHT11 溫濕度檢測"uchar table3="溫度為
3、: "uchar table4="濕度為:"uchar table5="."uchar wendu6;uchar shidu6;/* 1ms延時函數(shù)*/void delay(int z) int x,y; for(x=z;x>0;x-) for(y=125;y>0;y-);/* 50us延時函數(shù)*/void delay_50us(uint t) uint j; for(;t>0;t-) for(j=19;j>0;j-);/* 50ms延時函數(shù)*/void delay_50
4、ms(uint t) uint j; for(;t>0;t-) for(j=6245;j>0;j-);/* 12864液晶寫指令*/void write_12864com(uchar com) lcdrs=0; delay_50us(1); P0=com; lcden=1; delay_50us(10); lcden=0; delay_50us(2);/* 12864液晶寫數(shù)據(jù)*/ void write_dat(uchar dat) lcdrs=1; lcdrw=0; delay_50us(1); P0=dat; lcden=1; delay_50us(10);
5、 lcden=0; delay_50us(2); /* 12864液晶初始化*/void init12864lcd(void) delay_50ms(2); write_12864com(0x30); delay_50us(4); write_12864com(0x30); delay_50us(4); write_12864com(0x0f); delay_50us(4); write_12864com(0x01); delay_50us(240); write_12864com(0x06); delay_50us(10); write_12864com(0x0c); delay_
6、50us(10); /* 12864液晶顯示函數(shù)*/ void display1(void) uchar i; write_12864com(0x80); for(i=0;i<18;i+) write_dat(table2i); delay_50us(1); /* 12864液晶顯示函數(shù)*/ void display2(void) uchar i; write_12864com(0x90); for(i=0;i<18;i+) write_dat(table3i); delay_50us(1); /* 12864液晶顯示函數(shù)*/ void display
7、3(void) uchar i; write_12864com(0x88); for(i=0;i<8;i+) write_dat(table4i); delay_50us(1); /* 12864液晶顯示函數(shù)*/ void displaywendu(void) uchar i; write_12864com(0x94); for(i=0;i<3;i+) write_dat(wendui); delay_50us(1); for(i=0;i<1;i+) write_dat(table5i); delay_50us(1); for(i=4;i<5;i+) writ
8、e_dat(wendui); delay_50us(1); /* 12864液晶顯示函數(shù)*/void displayshidu(void) uchar i; write_12864com(0x8C); for(i=0;i<3;i+) write_dat(shidui); delay_50us(1); for(i=0;i<1;i+) write_dat(table5i); delay_50us(1); for(i=4;i<5;i+) write_dat(shidui); delay_50us(1); /* SHT11寫字節(jié)程序*/char s_write_b
9、yte(unsigned char value) unsigned char i,error=0; for (i=0x80;i>0;i>>=1) /高位為1,循環(huán)右移 if (i&value) DATA=1; /和要發(fā)送的數(shù)相與,結果為發(fā)送的位 else DATA=0; SCK=1; _nop_();_nop_();_nop_(); /延時3us SCK=0; DATA=1; /釋放數(shù)據(jù)線 SCK=1; error=DATA; /檢查應答信號,確認通
10、訊正常 _nop_();_nop_();_nop_(); SCK=0; DATA=1; return error; /error=1 通訊錯誤/* SHT11讀字節(jié)程序*/char s_read_byte(unsigned char ack) unsigned char i,val=0; DATA=1; /釋放數(shù)據(jù)線 for(i=0x80;i>0;i>>=1) /高位為1,循環(huán)右移 SCK=1; if(DATA) val=(val|i); /讀一位數(shù)據(jù)線的值 SCK=0; DA
11、TA=!ack; /如果是校驗,讀取完后結束通訊 ; SCK=1; _nop_();_nop_();_nop_(); /延時3us SCK=0; _nop_();_nop_();_nop_(); DATA=1; /釋放數(shù)據(jù)線 return val;/* SHT11啟動傳輸*/void s_transstart(void) DATA=1; SCK=0; /準備 _nop_(); SCK=1; _nop_(); DATA=0; _nop_(); SCK=0; _nop_();_nop_();_nop_(); SCK=1; _nop_();
12、 DATA=1; _nop_(); SCK=0;/* SHT11連接復位*/void s_connectionreset(void) unsigned char i; DATA=1; SCK=0; /準備 for(i=0;i<9;i+) /DATA保持高,SCK時鐘觸發(fā)9次,發(fā)送啟動傳輸,通迅即復位 SCK=1; SCK=0; s_transstart(); /啟動傳輸/* SHT11溫濕度檢測*/char s_measure(unsigned char *p_value, unsigned
13、0;char *p_checksum, unsigned charmode) unsigned error=0; unsigned int i; s_transstart(); /啟動傳輸 switch(mode) /選擇發(fā)送命令 case TEMP : error+=s_write_byte(MEASURE_TEMP); break; /測量溫度 case HUMI : error+=s_write_byte(MEASURE_HUMI); break; /測量濕度 defa
14、ult : break; for (i=0;i<65535;i+) if(DATA=0) break; /等待測量結束 if(DATA) error+=1; / 如果長時間數(shù)據(jù)線沒有拉低,說明測量錯誤 *(p_value) =s_read_byte(ACK); /讀第一個字節(jié),高字節(jié) (MSB) *(p_value+1)=s_read_byte(ACK); /讀第二個字節(jié),低字節(jié) (LSB) *p_checksum =s_read_byte(noACK); /read CRC校驗碼 ret
15、urn error; / error=1 通訊錯誤/* SHT11溫濕度值標度變換及溫度補償*/void calc_sth10(float *p_humidity ,float *p_temperature) const float C1=-4.0; / 12位濕度精度 修正公式 const float C2=+0.0405; / 12位濕度精度 修正公式 const float C3=-0.; / 12位濕度精度 修正公式 const floa
16、t T1=+0.01; / 14位溫度精度 5V條件 修正公式 const float T2=+0.00008; / 14位溫度精度 5V條件 修正公式 float rh=*p_humidity; / rh: 12位 濕度 float t=*p_temperature; / t: 14位 溫度 float rh_lin; / rh_lin: 濕度 linear值 float rh_true; / rh_true: 濕度 ture值 float t_C;
17、160;/ t_C : 溫度 t_C=t*0.01 - 40; /補償溫度 rh_lin=C3*rh*rh + C2*rh + C1; /相對濕度非線性補償 rh_true=(t_C-25)*(T1+T2*rh)+rh_lin; /相對濕度對于溫度依賴性補償 if(rh_true>100)rh_true=100; /濕度最大修正 if(rh_true<0.1)rh_true=0.1; /濕度最小修正 *p_temperature=t_C; /返回溫度結果 *p_humidity=rh_true; /返回濕度結果/
18、* 主函數(shù)*/void main(void) unsigned int temp,humi; value humi_val,temp_val; /定義兩個共同體,一個用于濕度,一個用于溫度 unsigned char error; /用于檢驗是否出現(xiàn)錯誤 unsigned char checksum; /CRC init12864lcd(); display1(); display2(); display3(); s_connectionreset(); /啟動連接復位 wh
19、ile(1) error=0; /初始化error=0,即沒有錯誤 error+=s_measure(unsigned char*)&temp_val.i,&checksum,TEMP); /溫度測量 error+=s_measure(unsigned char*)&humi_val.i,&checksum,HUMI); /濕度測量 if(error!=0) s_connectionreset(); /如果發(fā)生錯誤,系統(tǒng)復位 else humi_val.f=(float)humi_val.i; /轉換為
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 北京牌車輛異地過戶委托協(xié)議書范本
- 腰突的微創(chuàng)治療
- 內(nèi)蒙古赤峰市名校2024-2025學年高二上學期期中聯(lián)考地理試題(含答案)
- 【初中地理】天氣與天氣預報教學課件-2024-2025學年七年級地理上冊(湘教版2024)
- 14 B波的反射、折射和衍射 中檔版2025新課改-高中物理-選修第1冊(21講)
- 熱孔高分子材料行業(yè)相關投資計劃提議
- HF-FB防彈玻璃相關行業(yè)投資方案范本
- 酒店管理業(yè)務能力
- 機關黨委換屆選舉工作方案范文
- 第七講-應對與心理防御機制課件
- 實驗幼兒園陪餐記錄表
- JJG113_2013_標準金屬洛氏硬度塊檢定規(guī)程_解讀
- 小學數(shù)學一位數(shù)加減混合運算算術題(969道)
- 安全教育培訓記錄運輸車輛安全技術要求
- 如何做好建筑工程質量信訪投訴工作
- 巖漿礦床實習報告(四川攀枝花釩鈦磁鐵礦礦床)
- 非營利性醫(yī)院內(nèi)部治理體系
- 施工日記完結
- 防止鍋爐汽包滿水和缺水事故措施
- 【職業(yè)規(guī)劃】自動化專業(yè)大學生職業(yè)生涯規(guī)劃PPT
- 航模遙控器ET07使用說明書(全比例10通道遙控器)
評論
0/150
提交評論