单片机数字温度计设计用C语言写程序

单片机数字温度计设计用C语言写程序,第1张

#include <reg51.h>

#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、点左下角的三角形开始按钮,可以看到仿真结果。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11193932.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-14
下一篇 2023-05-14

发表评论

登录后才能评论

评论列表(0条)

保存