源文件
#include <reg52.h>//头文件
#include <stdio.h>
#include<intrins.h>
#define uchar unsigned char//宏定义
#define uint unsigned int
void display();
sbit fm=P3^7;//蜂鸣器接口
sbit ds=P3^6;//ds18b20温度传感器接口
sbit w4=P2^6;
sbit w3=P2^4;
sbit w2=P2^2;
sbit w1=P2^0;
sbit dp=P0^7;
sbit key_shezhi=P1^5;
sbit key_jia=P1^6;
sbit key_jian=P1^7;
uchar flag_0;
int wendu,t;
uint t_max=150,t_max_1=400;
void delay(uint z) //延时函数
{
uint x,y;
for(x=z;x>0;x--)
for(y=110;y>0;y--);
}
/********************************/
void pro()//按键处理函数
{
if(key_shezhi==0)
{
delay(10);
if(key_shezhi==0)
{
flag_0++;//自加1;
if(flag_0>=3)
flag_0=0;
while(!key_shezhi) ;
}
}
}
/**********************************/
uchar code table[]={
0xc0,0xf9,0xa4,0xb0, 0x99,0x92,0x82,0xf8, 0x80,0x90,0xbf
};
uchar code table1[]={
0xc7,0x89
};
uint temp,mm;uchar i;float f_temp;
/*******************************************************
温度函数
*******************************************************/
void dsreset(void) //下边是温度获取子程序
{
uint i;
ds=0;
i=103;
while(i>0)i--;
ds=1;
i=4;
while(i>0)i--;
}
bit tempreadbit(void) //读一位
{
uint i;
bit dat;
ds=0;i++;
ds=1;i++;i++;
dat=ds;
i=8;while(i>0)i--;
return(dat);
}
uchar tempread(void) //获取温度
{
uchar i,j,dat;
dat=0;
for(i=1;i<=8;i++)
{
j=tempreadbit();
dat=(j<<7)|(dat>>1);
}
return(dat);
}
void tempwritebyte(uchar dat) //写一个字节
{
uint i;
uchar j;
bit testb;
for(j=1;j<=8;j++)
{
testb=dat&0x01;
dat=dat>>1;
if(testb)
{
ds=0;
i++;i++;
ds=1;
i=8;while(i>0)i--;
}
else
{
ds=0;
i=8;while(i>0)i--;
ds=1;
i++;i++;
}
}
}
void tempchange(void) //温度转换
{
dsreset();
delay(1);
tempwritebyte(0xcc);
tempwritebyte(0x44);
}
uint get_temp() //获取温度
{
uchar a,b;
dsreset();
delay(1);
tempwritebyte(0xcc);
tempwritebyte(0xbe);
a=tempread();
b=tempread();
temp=b;
temp<<=8;
temp=temp|a;
f_temp=temp*0.0625;
temp=f_temp*10+0.5;
f_temp=f_temp+0.05;
return temp;
}
/***********************************/
void display0()
{
P0=0xff;//消隐
w2=0;//打开第二个数码管的段选
P0=table[wendu/100];
delay(1);
w2=1;
P0=0xff;
w3=0;
P0=table[wendu%100/10];
dp=0;
delay(1);
w3=1;
P0=0xff;
w4=0;
P0=table[wendu%10];
delay(1);
w4=1;
}
/***************************************/
void baojing()
{
if(wendu>=t_max&&wendu<t_max_1)
{
fm=1;
display();
}
else if(wendu>=t_max_1)
{
fm=0;
display();
}
else
{
fm=0;
display();
}
}
/**************************************/
/**************************************/
void display1()
{
P0=0xff;
w1=0;
P0=table1[0];//L
delay(1);
w1=1;
P0=0xff;
w2=0;
P0=table[t_max/100];
delay(1);
w2=1;
P0=0xff;
w3=0;
P0=table[t_max%100/10];
dp=0;
delay(1);
w3=1;
P0=0xff;
w4=0;
P0=table[t_max%10];
delay(1);
w4=1;
}
/**************************************/
void display2()
{
P0=0xff;
w1=0;
P0=table1[1];//H
delay(1);
w1=1;
P0=0xff;
w2=0;
P0=table[t_max_1/100];
delay(1);
w2=1;
P0=0xff;
w3=0;
P0=table[t_max_1%100/10];
dp=0;
delay(1);
w3=1;
P0=0xff;
w4=0;
P0=table[t_max_1%10];
delay(1);
w4=1;
}
/***************************************/
void shezhi()
{
if(flag_0==1)//当设置温度的下限位是
{
if(key_jia==0)
{
delay(10);
if(key_jia==0)
{
t_max=t_max+5;
if(t_max>=t_max_1) //防止低温度高于高温度
t_max=t_max_1-5;
// while(!key_jia);//松手检测
}
}
display();
if(key_jian==0)
{
delay(10);
if(key_jian==0)
{
t_max=t_max-5;
while(!key_jian);
}
}
}
if(flag_0==2)//当设置高限位
{
if(key_jia==0)
{
delay(10);
if(key_jia==0)
{
t_max_1=t_max_1+5;
while(!key_jia);
}
}
if(key_jian==0)
{
delay(10);
if(key_jian==0)
{
t_max_1=t_max_1-5;
if(t_max_1<=t_max) //防止高温度小于低温度
t_max_1=t_max+5;
while(!key_jian);
}
}
}
}
void display()
{
if(flag_0==0)
display0();
else if(flag_0==1)
display1();
else if(flag_0==2)
display2();
}
void main()
{
while(1)
{
tempchange();
t=get_temp();
if(t>=0&&t<=1250) //温度合法范围,不在这个范围就是没有获取到合适的值
{
wendu=t;
}
pro();
display();
shezhi();
baojing();
}
}
|