功能描述

1、採用51單片機作為主控芯片;
2、採用12864液晶顯示:温度、濕度、光照、設置菜單;
3、採用DHT11檢測温度、濕度;
4、採用光敏電阻+TLC549檢測光照;
5、通過按鍵進入設置菜單,設置各項上下限,超限報警(液晶顯示+蜂鳴器);
6、支持串口通信,通過發送端指令 接收端可顯示温濕度、光照數值;

電路設計

採用Altium Designer作為電路設計工具。Altium Designer通過把原理圖設計、PCB繪製編輯、拓撲邏輯自動佈線、信號完整性分析和設計輸出等技術的完美融合,為設計者提供了全新的設計解決方案,使設計者可以輕鬆進行設計,熟練使用這一軟件必將使電路設計的質量和效率大大提高。

0121-基於單片機-環境監測-系統設計(12864+TLC549+DHT11)(電路+仿真)_#Proteus

單片機管腳説明:

P0端口(P0.0-P0.7):P0口為一個8位漏極開路雙向I/O口,每個引腳可吸收8TTL門電流。當P1口的管腳第一次寫1時,被定義為高阻輸入。P0能夠用於外部程序數據存儲器,它可以被定義為數據/地址的第八位。在FIASH編程時,P0 口作為原碼輸入口,當FIASH進行校驗時,P0輸出原碼,此時P0外部必須被拉高。

P1端口(P1.0-P1.7):P1口是一個內部提供上拉電阻的8位雙向I/O口,P1口緩衝器能接收輸出4TTL門電流。P1口管腳寫入1後,被內部上拉為高電平,可用作輸入,P1口被外部下拉為低電平時,將輸出電流,這是由於內部上拉的緣故。在FLASH編程和校驗時,P1口作為第八位地址接收。

P2端口(P2.0-P2.7):P2口為一個內部上拉電阻的8位雙向I/O口,P2口緩衝器可接收,輸出4個TTL門電流,當P2口被寫“1”時,其管腳被內部上拉電阻拉高,且作為輸入。並因此作為輸入時,P2口的管腳被外部拉低,將輸出電流。這是由於內部上拉的緣故。P2口,用於外部程序存儲器或16位地址外部數據存儲器進行存取時,P2口輸出地址的高八位。在給出地址“1”時,它利用內部上拉優勢,當對外部八位地址數據存儲器進行讀寫時,P2口輸出其特殊功能寄存器的內容。P2口在FLASH編程和校驗時接收高八位地址信號和控制信號。

P3端口(P3.0-P3.7):P3口管腳是一個帶有內部上拉電阻的8位的雙向I/O端口,可接收輸出4個TTL門電流。當P3口寫入“1”後,它們被內部上拉為高電平,並用作輸入。作為輸入端時,由於外部下拉為低電平,P3口將輸出電流(ILL)。P3口同時為閃爍編程和編程校驗接收一些控制信號。

仿真設計

採用Proteus作為仿真設計工具。Proteus是一款著名的EDA工具(仿真軟件),從原理圖布圖、代碼調試到單片機與外圍電路協同仿真,一鍵切換到PCB設計,真正實現了從概念到產品的完整設計。

0121-基於單片機-環境監測-系統設計(12864+TLC549+DHT11)(電路+仿真)_#51單片機_02

主程序設計

void main()
{
    uchar i=0;
	beep=0;
	lcd_init();// 初始化
    lcd_clear(0);// 清屏
    lcd_set_line(0);// 設置起始行為0

	//設置INT0
	IT0=1;//跳變沿出發方式(下降沿)
	EX0=1;//打開INT0的中斷允許。	

	SCON=0X50;//設置為工作方式1
	TMOD=0X21;//設置計數器工作方式2
	TH1=0XFD;//9600
	TL1=0XFD;
	ES=1;//打開接收中斷
	TR1=1;//打開計數器

	TH0=(65536-10000)/256;
	TL0=(65536-10000)%256;	
	ET0=1;//打開定時器0中斷允許
	EA=1;//打開總中斷
	TR0=1;//打開定時器
    while (1)
	{
		if(!k1)//設置
		{
			if(mode<6)
				mode++;
			else
				mode=0;
			while(!k1);
		}
		if(!k2)//加
		{			
			if(mode==1)
			{
				if(temp_L<temp_H)
					temp_L++;
			}
			if(mode==2)
			{
				if(temp_H<99)
					temp_H++;
			}
			if(mode==3)
			{
				if(humi_L<humi_H)
					humi_L++;
			}
			if(mode==4)
			{
				if(humi_H<99)
					humi_H++;
			}
			if(mode==5)
			{
				if(light_L<light_H)
					light_L++;
			}
			if(mode==6)
			{
				if(light_H<99)
					light_H++;
			}
			while(!k2);
		} 
		if(!k4)//減
		{			
			if(mode==1)
			{
				if(temp_L>0)
					temp_L--;
			}
			if(mode==2)
			{
				if(temp_H>temp_L)
					temp_H--;
			}
			if(mode==3)
			{
				if(humi_L>0)
					humi_L--;
			}
			if(mode==4)
			{
				if(humi_H>humi_L)
					humi_H--;
			}
			if(mode==5)
			{
				if(light_L>0)
					light_L--;
			}
			if(mode==6)
			{
				if(light_H>light_L)
					light_H--;
			}
			while(!k4);
		} 
	}
}