#define uchar unsigned char
sbit BEEP=P3^7
//接控制继电器
sbit DQ = P3^6
//接温度传感器18B20
uchar t[2],number=0,*pt
//温度值
uchar TempBuffer1[4]={0,0,0,0}
uchar Tmax=50,Tmin=10
uchar distab[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e,0xff,0xfe,0xf7}
uchar currtemp
void t0isr() interrupt 1
{
TH0=(65536-5000)/256
TL0=(65536-5000)%256
P2=1<<number
if(number==2)P0=distab[TempBuffer1[0]]&0x7f
else P0=distab[TempBuffer1[0]]
number++
if(number>3)number=0
}
void delay_18B20(unsigned int i)
{
while(i--)
}
/**********ds18b20初始化函数**********************/
void Init_DS18B20(void)
{
bit x=0
do{
DQ=1
delay_18B20(8)
DQ = 0 //单片机将DQ拉低
delay_18B20(90)//精确延时 大于 480us
DQ = 1 //拉高总线
delay_18B20(14)
x=DQ //稍做延时后 如果x=0则初始化成功 x=1则初始化失败,继续初始化
}while(x)
delay_18B20(20)
}
/***********ds18b20读一个字节**************/
unsigned char ReadOneChar(void)
{
unsigned char i=0
unsigned char dat = 0
for (i=8i>0i--)
{
DQ = 0// 给脉冲信号
dat>>=1
DQ = 1// 给脉冲信号
if(DQ)
dat|=0x80
delay_18B20(4)
}
return(dat)
}
/*************ds18b20写一个字节****************/
void WriteOneChar(unsigned char dat)
{
unsigned char i=0
for (i=8i>0i--)
{
DQ = 0
DQ = dat&0x01
delay_18B20(5)
DQ = 1
dat>>=1
}
}
/**************读取ds18b20当前温度************/
unsigned char *ReadTemperature(unsigned char rs)
{
unsigned char tt[2]
delay_18B20(80)
Init_DS18B20()
WriteOneChar(0xCC) //跳过读序号列号的 *** 作
WriteOneChar(0x44)
//启动温度转换
delay_18B20(80)
Init_DS18B20()
WriteOneChar(0xCC)
//跳过读序号列号的 *** 作
WriteOneChar(0xBE)
//读取温度寄存器等(共可读9个寄存器)前两个就是温度
tt[0]=ReadOneChar() //读取温度值低位
tt[1]=ReadOneChar() //读取温度值高位
return(tt)
}
void covert1(void)
//将温度转换为LED显示的数据
{
uchar x=0x00,y=0x00
t[0]=*pt
pt++
t[1]=*pt
if(t[1]&0x080) //判断正负温度
{
TempBuffer1[0]=0x0c
//c代表负
t[1]=~t[1]
/*下面几句把负数的补码*/
t[0]=~t[0]
/*换算成绝对值*********/
x=t[0]+1
t[0]=x
if(x==0x00)t[1]++
}
else TempBuffer1[0]=0x0a
//A代表正
t[1]<<=4
//将高字节左移4位
t[1]=t[1]&0xf0
x=t[0]
//将t[0]暂存到X,因为取小数部分还要用到它
x>>=4
//右移4位
x=x&0x0f
//和前面两句就是取出t[0]的高四位
y=t[1]|x
//将高低字节的有效值的整数部分拼成一个字节
TempBuffer1[1]=(y%100)/10
TempBuffer1[2]=(y%100)%10
t[0]=t[0]&0x0f
//小数部分
TempBuffer1[3]=t[0]*10/16
if(currtemp<Tmin || currtemp>Tmax)BEEP=1
else BEEP=0
}
void convert(char tmp)
{
uchar a
if(tmp<0)
{
TempBuffer1[0]=0x0c
a=~tmp+1
}
else
{
TempBuffer1[0]=0x0a
a=tmp
}
TempBuffer1[1]=(a%100)/10
TempBuffer1[2]=(a%100)%10
}
main()
{
TMOD=0x01
TH0=(65536-5000)/256
TL0=(65536-5000)%256
TR0=1
ET0=1
EA=1
out=1
flag=0
ReadTemperature(0x3f)
delay_18B20(50000)
//延时等待18B20数据稳定
while(1)
{
pt=ReadTemperature(0x7f)//读取温度,温度值存放在一个两个字节的数组中
if(dismod==0)covert1()
delay_18B20(30000)
}
}
1、PROTEUS安装好后,默认不会在桌面上产生快捷方式。先打开开始菜单,依次点击“程序、Proteus7Professional、ISIS7Professional”打开PROTEUS。
2、单击图中的P,添加单片机等元件。
3、用关键字搜索,89C51,再加几个LED,因为是仿真就不用加限流电阻和晶振复位的元件了。
4、把元件排列放好,再放一个电源。
5、连好导线,只要把鼠标放在管脚上就会自动变成连线图标,十分方便。
6、右键点击单片机,在菜单中选择“EDITPROPERTIES”。
7、点选图中红框,然后选中要装载的HEX文件。
8、在编译器KEIL中写程序,然后编译成HEX文件。
9、点左下角的三角形开始按钮,可以看到仿真结果。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)