1、sbit dula=P26; /数码管段选线sbit wela=P27; /数码管位选线sbit beep=P23;uint temper;uchar a1,a2,a3,a4,a5,n;uint aaa,num;uint warn_l=3000; /低温-40报警,测试温度乘以100uint warn_h=10000; /高温100报警,测试温度乘以100float ttt;void disp(uchar num0,uchar num1,uchar num2,uchar num3,uchar num4,uchar num5);const uchar table=0x3f,0x06,0x5b,0
2、x4f,0x66,0x6d,0x7d, 0x07,0x7f,0x6f,0x40,0x00;/不带小数点0-9编码const uchar table1=0xbf,0x86,0xdb,0xcf,0xe6,0xed,0xfd, 0x87,0xff,0xef; /带小数点0-9编码uchar data temp_data2=0x00,0x00; /读出温度暂放void delay(uint z) uint x,y; for(x=z;x0;x-) for(y=110;yy-);/*18B20复位初始化函数1、将数据线拉高到12、延时2us(该时间要求不是很严格,但是要尽可能短一点)3、将数据线拉低到04
3、、延时750us(该时间范围可以在480960us)5、将数据线拉高到16、延时等待(70us),如果初始化成功则在1560us内产生一个由18B20返回的低电平0, 据该状态可以确定它的存在。但是应注意,不能无限的等待,不然会使程序进入死循环,所以要进行超时判断。7、若CPU读到数据线上的低电平0后,还要进行延时,其延时时间从发出高电平算起(第5步的时间算起最少要480us)。8、将数据线再次拉高到1后结束*/void dsreset() uchar st=1; DQ=1; /拉高数据线 _nop_();_nop_(); while(st) DQ=0; /控制器向DS18B20发低电平脉冲
4、delayus(81); /延时750us左右 DQ=1; /控制器拉高总线 delay70us(); /延时70us if(DQ=1)st=1; else st=0; delayus(54); /延时500us等待 向DS18B20写一个字节函数1、将数据线置低电平02、延时15us3、按从低位到高位的顺序发送数据(一次只发送一位)4、延时45us6、重复15步骤,直到发送完整个字节7、最后将数据线拉高到1 void tempwritebyte(uchar date) uchar i,temp; /因为写之前需要置0,所以先置为高电平 for(i=8;ii-) /一位一位的写 temp=da
5、te&0x01; /取数据最低位 delay20us(); /延时20us if(temp=1) /判断数据为1还是0 DQ=1; /如果为1则发送1,即DQ=1;如果是0则保持,因为之前DQ已经置为0,所以不用判断。 delay45us(); date=date1; 读1个字节数据函数2、延时2us4、延时6us6、延时4us7、读数据线的状态得到一个状态位,并进行数据处理。8、延时30us9、重复17步骤,直到读取完一个字节(一个字节共8位需要循环8次)。uchar tempread() /uchar为带返回值的函数,void不带 uchar i,date; static bit j; /
6、定义静态变量 位i-) /读出的数据最低位在最前面,这样刚好一个字节在date里 /将数据线拉高到1 _nop_(); /延时2us /将数据线拉低到0/延时6us /将数据线拉高到1/延时4us j=DQ; if(j=1) date=date|0x80;/1000 0000 delay30us(); return(date);void get_tem() dsreset(); /复位 tempwritebyte(0xCC); /跳过ROM tempwritebyte(0x44); /温度转换 /每次操作ROM之前要先复位,然后执行跳过或其他指令 tempwritebyte(0xBE); /读
7、暂存器 temp_data0=tempread(); /第0位,温度值低8位;RAM共9个字节,从0开始自动读 temp_data1=tempread(); /第1位,温度值高8位 aaa=temp_data1; aaa63488) / 温度值正负判断63448=1111 1000 0000 0000 aaa=65536-aaa; n=1; / 负温度求补码,标志位置1 ttt=aaa*6.25; /0.0625*100=6.25 temper=(int)ttt; a1=temper/10000; /对1000求模,取万位 a2=temper%10000/1000; /对10000求余对100
8、0求模,取千位 a3=temper%1000/100; /对1000求余再对100求模,取百位 a4=temper%100/10; /取小数十位 a5=temper%10; /取个位 for(num=100;numnum-) if(n=1) /负温度 if(tttwarn_l) /超温报警 beep=0; delay(100); beep=1; if(a2!=0)disp(11,10,a2,a3,a4,a5); else disp(11,11,10,a3,a4,a5); else /正温度warn_h) /超温报警 if(a1=0&a2=0)disp(11,11,11,a3,a4,a5);a2
9、!=0)disp(11,11,a2,a3,a4,a5); if(a1!=0)disp(11,a1,a2,a3,a4,a5);void disp(uchar num0,uchar num1,uchar num2,uchar num3,uchar num4,uchar num5) wela=1; P0=0xFE; wela=0; dula=1; P0=tablenum0;/显示第一个数码管显示-号 dula=0; delay(2); P0=0xFD; P0=tablenum1;/显示第二个数码管 P0=0xFB; P0=tablenum2;/显示第三个数码管 P0=0xF7; P0=table1num3;/显示第四个数码管 P0=0xEF; P0=tablenum4;/显示第五个数码管 P0=0xDF; P0=tablenum5;/显示第六个数码管 dula=0
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1