目录
- 基于51单片机的智能温控风扇
- 1、主要功能
- 2、实验结果
- 3、仿真工程
- 4、原理图
- 5、程序源码
- 6、资源获取
基于51单片机的智能温控风扇
1、主要功能
基于51单片机的智能温控风扇,通过DS180温度传感器采集温度,并通过数码管显示温度,当温度高于20°时,开启风扇降温,当温度低于20°时风扇关闭。
2、实验结果
3、仿真工程
方案验证仿真软件使用的是Proteus仿真文件,Proteus软件版本为8.8;如需下载软件,可以在公众号后台回复:Proteus
4、原理图
5、程序源码
#include<reg51.h>
#include<intrins.h>
#define uchar unsigned char
#define uint unsigned int
sbit dj=P1^0;
sbit DQ=P1^6;
sbit key1=P3^5;
sbit key2=P3^6;
sbit key3=P3^7;
sbit w1=P2^4;
sbit w2=P2^5;
sbit w3=P2^6;
sbit w4=P2^7;
uchar table[22]=
{0x3F,0x06,0x5B,0x4F,0x66,
0x6D,0x7D,0x07,0x7F,0x6F,
0x77,0x7C,0x39,0x5E,0x79,0x71,
0x40,0x38,0x76,0x00,0xff,0x37};
uint wen_du;
uint shang,xia;
uchar dang;
uchar flag;
uchar d1,d2,d3;
void delay(uint ms)
{
uchar x;
for(ms;ms>0;ms--)
for(x=10;x>0;x--);
}
void delay_18B20(uint i)
{
while(i--);
}
void Init_DS18B20()
{
uchar x=0;
DQ=1;
delay_18B20(8);
DQ=0;
delay_18B20(80);
DQ=1;
delay_18B20(14);
x=DQ;
delay_18B20(20);
}
uchar ReadOneChar()
{
uchar i=0;
uchar dat=0;
for (i=8;i>0;i--)
{
DQ=0;
dat>>=1;
DQ=1;
if(DQ)
dat|=0x80;
delay_18B20(4);
}
return(dat);
}
void WriteOneChar(uchar dat)
{
uchar i=0;
for (i=8;i>0;i--)
{
DQ=0;
DQ=dat&0x01;
delay_18B20(5);
DQ=1;
dat>>=1;
}
}
void ReadTemperature()
{
uchar a=0;
uchar b=0;
uchar t=0;
Init_DS18B20();
WriteOneChar(0xCC);
WriteOneChar(0x44);
delay_18B20(100);
Init_DS18B20();
WriteOneChar(0xCC);
WriteOneChar(0xBE);
delay_18B20(100);
a=ReadOneChar();
b=ReadOneChar();
wen_du=((b*256+a)>>4);
}
void display()
{
w1=0;P0=table[d1];delay(10);
P0=0x00;w1=1;delay(1);
w2=0;P0=table[16];delay(10);
P0=0x00;w2=1;delay(1);
w3=0;P0=table[d2]; delay(10);
P0=0x00;w3=1;delay(1);
w4=0;P0=table[d3];delay(10);
P0=0x00;w4=1;delay(1);
}
void zi_keyscan()
{
if(key1==0)
{
delay(30);
if(key1==0)flag=1;
while(key1==0);
}
while(flag==1)
{
d1=18;d2=shang/10;d3=shang%10;
display();
if(key1==0)
{
delay(30);
if(key1==0)flag=2;
while(key1==0);
}
if(key2==0)
{
delay(30);
if(key2==0)
{
shang+=5;
if(shang>=100)shang=100;
}while(key2==0);
}
if(key3==0)
{
delay(30);
if(key3==0)
{
shang-=1;
if(shang<=10)shang=10;
}while(key3==0);
}
}
while(flag==2)
{
d1=17;d2=xia/10;d3=xia%10;
display();
if(key1==0)
{
delay(30);
if(key1==0)flag=0;
while(key1==0);
}
if(key2==0)
{
delay(30);
if(key2==0)
{
xia+=5;
if(xia>=95)xia=95;
}while(key2==0);
}
if(key3==0)
{
delay(30);
if(key3==0)
{
xia-=1;
if(xia<=0)xia=0;
}while(key3==0);
}
}
}
void zi_dong()
{
uchar i;
d1=dang;d2=wen_du/10;d3=wen_du%10;
zi_keyscan();
display();
if(wen_du<xia){dj=0;dang=0;}
if((wen_du>=xia)&&(wen_du<=shang))
{
dang=1;
for(i=0;i<3;i++){dj=0;display();zi_keyscan();}
for(i=0;i<6;i++){dj=1;display();zi_keyscan();}
}
if(wen_du>shang){dj=1;dang=2;}
}
void main()
{
uchar j;
dj=0;
shang=30;
xia=20;
for(j=0;j<80;j++)
ReadTemperature();
while(1)
{
ReadTemperature();
for(j=0;j<100;j++)zi_dong();
}
}
6、资源获取
项目的仿真和程序工程已经放在下面公众号里面,可以关注公众号:Kevin的学习站,输入关键字:“温控风扇”,就可以获取啦!创作不易,但您的点赞、关注、收藏就是对我最大的鼓励!
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)