当前位置:首页 » 课程大全 » 单片机课程设计报告数字温度计

单片机课程设计报告数字温度计

发布时间: 2021-02-21 16:19:03

⑴ 单片机课程设计 数字温度计

我可以来为你提供所有你源所需要的,用DS18B20做的温度传感器,三个按键,
使用说明:
1.电源供电为5V直流,使用时将电源插头插到电源座上。数码管会点亮同时蜂鸣器鸣叫1~2S,开机成功。

2.系统板上还有一个10 PIN的ISP下载接口,用于89S52单片机在线下载程序。

3.系统板上有3个功能按键,分别为:菜单、加、减;菜单键用于切换要设置的参数,菜单键按第一下设置的上限温度,用加、减键设定,同时数码管显示upxx(xx为温度上限值)。最高可以设置到125度最低可以到—55度;

4.菜单键按第二下设置的下限温度,用加、减键设定,同时数码管显示doxx(xx为温度下限值)。同样最高可以设置到125度最低可以到—55度;

5.系统默认的温度上限值是+31度,下限值是+10度,用户可以通过按键修改。

6.当所测温度超过设定的范围,蜂鸣器报警,直到温度回到设定范围内蜂鸣器才会停止报警。

C程序,原理图都有

⑵ 单片机课程设计—数字温度计

我不懂啊

⑶ 课程设计 单片机做数字温度计

给你个C51编写的DS18B20程序,自己去看,很简单的,上下限报警,就加个判断就OK了,还是自己去做一部分,如果有人全帮你做了,他就没安好心,恰恰是在害你,害中国的青年!
代码如下:
/*DS18B20数字温度传感器*/
#include<reg51.h>
#define uchar unsigned char
#define uint unsigned int
extern void _nop_(void);
#define nop1 _nop_()
#define nop nop1;nop1;
sbit DQ=P3^2;
uchar code table[]={
0x09,0x7d,0x07,0x15,0x71,
0x91,0x81,0x3d,0x01,0x11,
0x21,0xc1,0x8b,0x45,0x83,0xa3,0xff};
uchar dis[]={0,0,0,0};

void delay(uchar z)
{
uchar x,y,j;
for(x=0;x<z;x++)
{for(y=200;y>0;y--)
{for(j=0;j<10;j++);
}
}

}

void delay_us(del)
{
while(del>0)
{ del--;
}
}

void init_DS18B20()
{
DQ = 1; //DQ复位
delay_us(3); //稍做延时
DQ=0; //复位脉冲
delay_us(40); //延时约480us
DQ=1;
//延时约25us
while(DQ); //检测存在脉冲
delay_us(13);
}

void write_onechar(uchar t)
{
uchar i;
DQ=1;
for(i=0;i<8;i++)
{
DQ=0;
//delay_us(2);
nop;//基本不延时都可以的
DQ=(bit)(t&0x01);
delay_us(2);//延时15us~60us,让总线去采样输入位,低电平为0
DQ=1;//写下一位
nop;
t=t>>1;
}
}

uchar read_onechar()
{
uchar i,value;
EA =0;

value=0;
DQ=1;
for(i=0;i<8;i++)
{
DQ=0;
nop;
value=value>>1;
DQ = 1 ;//产生读时间隔
nop;
if(DQ)
{ value=value|0x80;
}

delay_us(1);
}
EA =1;
return value;
}

uint temperature_con()
{
uchar a;
int b;
float tt;
a=0;
b=0;
init_DS18B20();
write_onechar(0xcc);
write_onechar(0x44);
// WriteOneChar(0xcc);
// WriteOneChar(0x44);
delay(30);//204MS延时
init_DS18B20();
write_onechar(0xcc);
write_onechar(0xbe);
//WriteOneChar(0xcc);
//WriteOneChar(0xbe);
a=read_onechar();
b=read_onechar();

b=b<<8; //用来移动的B要是16位的,否则移位就没有意义了
b=b|a;
tt=b*0.0625;//为了计算精度t要为浮点型
tt= tt*10+0.5; //放大10倍输出并四舍五入
return(tt);
}

void display(int aa)
{
uchar i;
SCON=0;
dis[0]=16;
dis[1]=aa/100;
dis[2]=aa%100/10;
dis[3]=aa%100%10;
for(i=0;i<4;i++)
{
if(i==2)
SBUF=(table[dis[i]]-1);//小数点是查表值减一
else
SBUF=table[dis[i]];
while(TI==0);
TI=0;
}
}

main(

)
{
uint value=0;

value=temperature_con();
display(value);
}

⑷ 用单片机设计数字温度计

我以前玩了一下,大体上我你说的差不多,你可以参考一下,我当时是用汇编写的,现在用C语言。我发给你了。
其实很简单,你可以用4个74HC595串连做一个LED静态显示电路,或者用1602字符液晶也行,单片机最小系统用一个IO口直接和DS18B20连接就行了。设定温度的话有两种方式:
一是用拔码盘来设定温度,很多的仪器仪表上也有用到(8421BCD码的拔码盘很好买,要多少位可以自由组合,像你这个上下限各用4位组成一组,共2组),这种方法是硬件比较麻烦,但是软件写起来很简单,只要将拔码盘的值读进来转换一下再和DS18B20的数据对比一下就知道有没有有超过上下限了。
二是用几个按键来设置,如果用按键设置的话,建议用内部带有EEPROM存储器的单片机,用来存储设置的上下限值,EEPROM存储器掉电不丢失,当然你也可以用外部的EEPROM存储器,像IIC总线接口的AT24CXX系列的就可以。

⑸ 课程设计:基于单片机的数字温度计的设计

说实话,自己做复吧,制不难的,理工科的嘛,不多动手出来不好混的。

题目也有点问题,既然是数字温度计,为什么还要用AD?
采用8031芯片用与中断程序
通过8155芯片用于8位LED动态显示电路
这两个很少用吧,我记得就在微机原理的试验箱上见过...

你可以搜索DS18B20,大家在学校最常用的数字温度计,51的程序也一大堆,搜索下就有了。

⑹ 单片机课程设计,数字温度计。

1.实验任务

用可调电阻调节电压值作为模拟温度的输入量,当温度低于30℃时,发出长嘀报警声和光报警,当温度高于60℃时,发出短嘀报警声和光报警。测量的温度范围在0-99℃。

2.电路原理图

(图)见插图

3.系统板上硬件连线

a)把“单片机系统”区域中的P1.0-P1.7与“动态数码显示”区域中的ABCDEFGH端口用8芯排线连接。

b)把“单片机系统”区域中的P2.0-P2.7与“动态数码显示”区域中的S1S2S3S4S5S6S7S8端口用8芯排线连接。

c)把“单片机系统”区域中的P3.0与“模数转换模块”区域中的ST端子用导线相连接。

d)把“单片机系统”区域中的P3.1与“模数转换模块”区域中的OE端子用导线相连接。

e)把“单片机系统”区域中的P3.2与“模数转换模块”区域中的EOC端子用导线相连接。

f)把“单片机系统”区域中的P3.3与“模数转换模块”区域中的CLK端子用导线相连接。

g)把“模数转换模块”区域中的A2A1A0端子用导线连接到“电源模块”区域中的GND端子上。

h)把“模数转换模块”区域中的IN0端子用导线连接到“三路可调电压模块”区域中的VR1端子上。

i)把“单片机系统”区域中的P0.0-P0.7用8芯排线连接到“模数转换模块”区域中的D0D1D2D3D4D5D6D7端子上。

j)把“单片机系统”区域中的P3.6、P3.7用导线分别连接到“八路发光二极管指示模块”区域中的L1、L2上。

k)把“单片机系统”区域中的P3.5用导线连接到“音频放大模块”区域中的SPKIN端口上。

l)把“音频放大模块“区域中的SPKOUT插入音频喇叭。

四.C语言源程序

#include<AT89X52.H>

unsignedcharcodedispbitcode[]={0xfe,0xfd,0xfb,0xf7,

0xef,0xdf,0xbf,0x7f};

unsignedcharcodedispcode[]={0x3f,0x06,0x5b,0x4f,0x66,

0x6d,0x7d,0x07,0x7f,0x6f,0x00};

unsignedchardispbuf[8]={10,10,10,10,10,10,0,0};

unsignedchardispcount;

unsignedchargetdata;

unsignedinttemp;

unsignedchari;

sbitST=P3^0;

sbitOE=P3^1;

sbitEOC=P3^2;

sbitCLK=P3^3;

sbitLED1=P3^6;

sbitLED2=P3^7;

sbitSPK=P3^5;

bitlowflag;

bithighflag;

unsignedintcnta;

unsignedintcntb;

bitalarmflag;

voidmain(void)

{

ST=0;

OE=0;

TMOD=0x12;

TH0=0x216;

TL0=0x216;

TH1=(65536-500)/256;

TL1=(65536-500)%256;

TR1=1;

TR0=1;

ET0=1;

ET1=1;

EA=1;

ST=1;

ST=0;

while(1)

{

if((lowflag==1)&&(highflag==0))

{

LED1=0;

LED2=1;

}

elseif((highflag==1)&&(lowflag==0))

{

LED1=1;

LED2=0;

}

else

{

LED1=1;

LED2=1;

}

}

}

voidt0(void)interrupt1using0

{

CLK=~CLK;

}

voidt1(void)interrupt3using0

{

TH1=(65536-500)/256;

TL1=(65536-500)%256;

if(EOC==1)

{

OE=1;

getdata=P0;

OE=0;

temp=getdata*25;

temp=temp/64;

i=6;

dispbuf[0]=10;

dispbuf[1]=10;

dispbuf[2]=10;

dispbuf[3]=10;

dispbuf[4]=10;

dispbuf[5]=10;

dispbuf[6]=0;

dispbuf[7]=0;

while(temp/10)

{

dispbuf[i]=temp%10;

temp=temp/10;

i++;

}

dispbuf[i]=temp;

if(getdata<77)

{

lowflag=1;

highflag=0;

}

elseif(getdata>153)

{

lowflag=0;

highflag=1;

}

else

{

lowflag=0;

highflag=0;

}

ST=1;

ST=0;

}

P1=dispcode[dispbuf[dispcount]];

P2=dispbitcode[dispcount];

dispcount++;

if(dispcount==8)

{

dispcount=0;

}

if((lowflag==1)&&(highflag==0))

{

cnta++;

if(cnta==800)

{

cnta=0;

alarmflag=~alarmflag;

}

if(alarmflag==1)

{

SPK=~SPK;

}

}

elseif((lowflag==0)&&(highflag==1))

{

cntb++;

if(cntb==400)

{

cntb=0;

alarmflag=~alarmflag;

}

if(alarmflag==1)

{

SPK=~SPK;

}

}

else

{

alarmflag=0;

cnta=0;

cntb=0;

}

}

热点内容
武汉大学学生会辅导员寄语 发布:2021-03-16 21:44:16 浏览:612
七年级学生作文辅导学案 发布:2021-03-16 21:42:09 浏览:1
不屑弟高考成绩 发布:2021-03-16 21:40:59 浏览:754
大学毕业证会有成绩单 发布:2021-03-16 21:40:07 浏览:756
2017信阳学院辅导员招聘名单 发布:2021-03-16 21:40:02 浏览:800
查询重庆2018中考成绩查询 发布:2021-03-16 21:39:58 浏览:21
结业考试成绩怎么查询 发布:2021-03-16 21:28:40 浏览:679
14中医医师资格笔试考试成绩查分 发布:2021-03-16 21:28:39 浏览:655
名著赏析课程标准 发布:2021-03-16 21:27:57 浏览:881
北京大学商业领袖高端培训课程 发布:2021-03-16 21:27:41 浏览:919