‘壹’ 基于单片机的数字温度计的设计可以添加什么功能
1、多路测温;
2、可以设置高低温棚薯报警值,超过范围就报警;
3、可以通过无线模块发送到更远的终端,利腔喊于数据传输和保存;
等等等等……
你要是有能力,还可以搞语音温度报警,通过GSM传输温度信息,又是等等,等链圆者等……
‘贰’ 基于单片机的数字温度计设计要做成实物所需要的硬件有什么
你搜一下单片机最小系统,按上面所列出的东西焊接起来,然后就是温度传感器,可以选择楼上的ds18b20,这个挺好用,直接接io口加个上拉电阻就行了,当然也可以用热敏电阻,这个需要ad转换.adc0804就够了.然后就是显示 ,除了楼上的数码管之外还需要数码管驱动,用三极管8050就行了,数码管有共阳和共阴极,选的时候要注意.除了单片机最小系统外其他电路都相当简单,用一般地万用板就可以完成,就是外观不太好看而以,单片机最小系统网络一搜一大把图,直接按图上的焊接就行了,也许你还需要一个复位按钮,当然直接上电复位也可以,有段时间没有接触过单片机了,能想到的就这些了,希望对你有帮助
‘叁’ 8051单片机数字温度计单片机的设计
-55~125度,你自己修改:
;***************WAVE-E6000/T**********************
;*MCU: AT892051 *
;*MCU-crystal: 12M *
;*Version: 01 *
;*Last Updata: 2007-5-27 *
;*Author: zhaojun *
;*Description: *
;DS18B20的读写程序,数据脚P3.4 *
;温度传感器18B20汇编程序,采用器件默认的12位转化 *
;最大转化时间750微秒,显示温度-55到+125度,显示精度*
;为0.1度,显示采用4位LED共阳显示测温值 *
;*************************************************
;单片机内存分配申明!
;*************************************************
TEMPER_L EQU 40H ;用于保存读出温度的低8位
TEMPER_H EQU 41H ;用于保存读出温度的高8位
FLAG1 EQU 38H ;是否检测到DS18B20标志位
SEC EQU 20H ;数码管个位数存放内存位置
MIN EQU 21H ;数码管十位数存放内存位置
TEMPL EQU 30H ;用于保存读出温度的低8位
TEMPH EQU 31H ;用于保存读出温度的高8位
TEMPHC EQU 32H ;温度转换寄存器低8位
TEMPLC EQU 33H ;温度转换寄存器高8位
BUF1 EQU 34H ;显示缓冲寄存器小数位
BUF2 EQU 35H ;显示缓冲寄存器个数位
BUF3 EQU 36H ;显示缓冲寄存器十数位
BUF4 EQU 37H ;显示缓冲寄存器百数位
TEMPDIN BIT P3.4 ;数据脚定义
DIN BIT P1.7 ;小数点控制
;**********************************************
ORG 0000H ;主程序入口地址
AJMP MAIN ;转主程序
ORG 0003H ;外中断0中断入口
DB 00H,00H,00H,00H,00H,00H,00H;
RETI ;跳至INTEX0执行中断服务程序
ORG 000BH ;定时器T0中断入口地址
DB 00H,00H,00H,00H,00H,00H,00H ;
RETI ;跳至定时器T0执行中断服务程序
ORG 0013H ;外中断1中断入口
DB 00H,00H,00H,00H,00H,00H,00H ;
RETI ;跳至INTEX1执行中断服务程序
ORG 001BH ;定时器T1中断入口地址
DB 00H,00H,00H,00H,00H,00H,00H ;
RETI ;中断返回(不开中断)
ORG 0023H ;串行口中断入口地址
DB 00H,00H,00H,00H,00H,00H,00H ;
RETI ;中断返回(不开中断)
;**********************************************
;两位数码管来显示温度,显示范围00到99度,显示精度为1度
;因为12位转化时每一位的精度为0.0625度,我们不要求显示小数所以可以抛弃29H的低4位
;将28H中的低4位移入29H中的高4位,这样获得一个新字节,这个字节就是实际测量获得的温度
;无需乘于0.0625系数
;**********************************************
MAIN:
MOV SP, #50H ;
MOV P1, #0FFH ;
LPTEMP:
LCALL GET_TEMPER ;调用读温度子程序
LCALL CONVTEMP ;温度BCD码计算处理子程序
LCALL DISPBCD ;显示区BCD码温度值刷新子程序
;*************************************
LCALL DISPLAY ;调用数码管显示子程序
;*************************************
;CPL P3.0 ;
AJMP LPTEMP ;
;*************************************
; 这是DS18B20复位初始化子程序
;*************************************
INIT_1820:
SETB TEMPDIN
NOP
CLR TEMPDIN ;主机发出延时537微秒的复位低脉冲
MOV R1,#3
TSR1: MOV R0,#107
DJNZ R0,$
DJNZ R1,TSR1
SETB TEMPDIN ;然后拉高数据线
NOP
NOP
NOP
MOV R0,#25H
TSR2:
JNB TEMPDIN,TSR3 ;等待DS18B20回应
DJNZ R0,TSR2
LJMP TSR4 ;延时
TSR3:
SETB FLAG1 ;置标志位,表示DS1820存在
;CLR P3.7 ;检查到DS18B20就点亮P3.7LED
LJMP TSR5
TSR4:
CLR FLAG1 ;清标志位,表示DS1820不存在
;CLR P3.1
LJMP TSR7
TSR5: MOV R0,#117
TSR6: DJNZ R0,TSR6 ;时序要求延时一段时间
TSR7: SETB TEMPDIN ;
RET
;****************************************
; 读出转换后的温度值
;****************************************
GET_TEMPER:
SETB TEMPDIN ;
LCALL INIT_1820 ;先复位DS18B20
JB FLAG1,TSS2
RET ;判断DS1820是否存在?若DS18B20不存在则返回
TSS2:
;CLR P3.3 ;DS18B20已经被检测到!!
MOV A,#0CCH ;跳过ROM匹配
LCALL WRITE_1820
MOV A,#44H ;发出温度转换命令
LCALL WRITE_1820
;*****************************************
;这里通过调用显示子程序实现延时一段时间,等待AD转换结束,12位的话750微秒
;*****************************************
LCALL DISPLAY
;*****************************************
LCALL INIT_1820 ;准备读温度前先复位
MOV A,#0CCH ;跳过ROM匹配
LCALL WRITE_1820
MOV A,#0BEH ;发出读温度命令
LCALL WRITE_1820
LCALL READ_18200 ;将读出的温度数据保存到35H/36H
RET
;*******************************************
;写DS18B20的子程序(有具体的时序要求)
;*******************************************
WRITE_1820:
MOV R2,#8 ;一共8位数据
CLR C ;
WR1:
CLR TEMPDIN ;
MOV R3,#6
DJNZ R3,$
RRC A
MOV TEMPDIN,C ;
MOV R3,#23
DJNZ R3,$
SETB TEMPDIN ;
NOP
DJNZ R2,WR1 ;
SETB TEMPDIN ;
RET
;*************************************
;处理温度BCD码子程序
;*************************************
CONVTEMP: MOV A,TEMPH ;
ANL A,#80H ;
JZ TEMPC1 ; 判断温度是否在零下?
CLR C ; 温度值补码 变成原码
MOV A,TEMPL ;
CPL A
ADD A,#01H ;
MOV TEMPL,A ;
MOV A, TEMPH ; -
CPL A ;
ADDC A,#00H ;
MOV TEMPH,A ; TEMPHC HI=符号位
MOV TEMPHC,#0BH ; 置"-"标志
SJMP TEMPC11 ;
TEMPC1: MOV TEMPHC,#0AH ; 置"+"标志
;**************************************
TEMPC11: MOV A,TEMPHC ; 计算小数位温度BCD值
SWAP A
MOV TEMPHC,A ;
MOV A,TEMPL ;
ANL A,#0FH ; 乘0.0625
MOV DPTR,#TEMPDOTTAB ;
MOVC A,@A+DPTR ;
MOV TEMPLC,A ; TEMPLC LOW= 小数部分 BCD
;**************************************
MOV A,TEMPL ; 计算整数位温度BCD值
ANL A,#0F0H ;
SWAP A ;
MOV TEMPL,A ;
MOV A,TEMPH ;
ANL A,#0FH ;
SWAP A ;
ORL A,TEMPL ;
MOV TEMPER_L ,A ;
LCALL HEX2BCD1 ; 调用单字节十六进制转BCD子程序
;************************************
MOV TEMPL,A ;
ANL A,#0F0H ;
SWAP A ;
ORL A,TEMPHC ; TEMPHC LOW = 十位数 BCD
MOV TEMPHC,A ;
MOV A,TEMPL ;
ANL A,#0FH ;
SWAP A ; TEMPLC HI = 个位数 BCD
ORL A,TEMPLC ;
MOV TEMPLC,A ;
MOV A,R7 ;
JZ TEMPOUT ;
ANL A,#0FH ;
SWAP A ;
MOV R7,A ;
MOV A,TEMPHC ; TEMPHC HI = 百位数 BCD
ANL A,#0FH ;
ORL A,R7 ;
MOV TEMPHC,A ;
TEMPOUT: RET ;
;**************************************
;小数部分分码表
;**************************************
TEMPDOTTAB: DB 00H,01H,01H,02H,03H,03H,04H,04H,05H,06H
DB 06H,07H,08H,08H,09H,09H ;
;**************************************
;显示区 BCD 码温度值刷新子程序
;**************************************
DISPBCD: MOV A,TEMPLC ; 温度数据移入显示寄存器
ANL A,#0FH ;
MOV BUF1,A ; 显示小数
MOV A,TEMPLC ;
SWAP A ;
ANL A,#0FH ;
MOV BUF2,A ; 显示个位
MOV A,TEMPHC ;
ANL A,#0FH ;
MOV BUF3,A ; 显示十位
MOV A,TEMPHC ;
SWAP A ;
ANL A,#0FH ;
MOV BUF4,A ; 显示百位
MOV A,TEMPHC ;
ANL A,#0F0H ;
CJNE A,#10H,DISPBCD0 ; 百位数=0?
SJMP DISPOUT ;
DISPBCD0:
MOV A, TEMPHC ;
ANL A, #0FH ;
JNZ DISPOUT ; 十位数是0?
MOV A,TEMPHC ;
SWAP A ;
ANL A,#0FH ;
MOV BUF4,0AH ; 符号位不显示
MOV BUF3,A ; 十位数显示符号
DISPOUT: RET ;
;*************************************
;单字节十六进制转BCD
;*************************************
HEX2BCD1:MOV B,#64H ; 十六进制 ->BCD
DIV AB ; B=A%100
MOV R7,A ; R7=百位数
MOV A,#0AH ;
XCH A,B ;
DIV AB ; B=A%B
SWAP A ;
ORL A,B ;
RET ;
;*************************************
; Calculate CRC-8 Values, Uses The
;CCITT-8 Polynomial,Expressed As
; X^8+X^5+X^4+1
;*************************************
CRC8CAL: PUSH ACC ;
MOV R7,#08H ; Number Bits Byte
CRC8LOOP1:
XRL A,B ; Calculate CRC
RRC A ; Move T0 Carry
MOV A,B ; Get The Last CRC Value
JNC CRC8LOOP2 ; Skip If Data==0
XRL A,#18H ; Update The CRC Value
CRC8LOOP2:
RRC A ; Position The New CRC
MOV B,A ; Store The New CRC
POP ACC ; Get The Remaining Bits
RR A ; Possition The Next Bit
PUSH ACC ; Save The Remaining Bits
DJNZ R7,CRC8LOOP1 ; Repeat For 9 Bits
POP ACC ;
RET ;
;******************************************
;读DS18B20的程序,从DS18B20中读出9个字节数据
;开始的两个字节为温度数据
;******************************************
READ_18200:
MOV R4,#9 ; 将温度高位和低位从DS18B20中读出
MOV R1,#TEMPER_L ; 低位存入29H(TEMPER_L),高位存入28H(TEMPER_H)
MOV B, #00H ;
;************************************
RE00:
MOV R2,#8 ; 数据一共有8位
RE01:
CLR C
SETB TEMPDIN ;
NOP
NOP
CLR TEMPDIN ;
NOP
NOP
NOP
SETB TEMPDIN ;
MOV R3,#9
RE10:
DJNZ R3,RE10 ;
MOV C,TEMPDIN ;
MOV R3,#23
RE20:
DJNZ R3,RE20 ;
RRC A
DJNZ R2,RE01 ;
;************************************
MOV @R1,A ;
INC R1 ;
LCALL CRC8CAL ;
DJNZ R4,RE00 ;
MOV A,B ;
JNZ READ_OUT ;
MOV TEMPL,TEMPER_L ;
MOV TEMPH,TEMPER_H ;
READ_OUT: RET
;*****************************************
;显示子程序
;*****************************************
DISPLAY:
MOV DPTR,#NUMTAB ; 指定查表启始地址
MOV R0,#4
DP11: MOV R1,#250 ; 显示1000次
DPLP: SETB P1.7
MOV A,BUF1 ; 取小位数
MOVC A,@A+DPTR ; 查小位数的7段代码
MOV P1,A ; 送出小位的7段代码
CLR P3.0 ; 开小位显示
ACALL DL1ms ; 显示1ms
SETB P3.0 ;
MOV A,BUF2 ; 取个位数
MOVC A,@A+DPTR ; 查个位数的7段代码
MOV P1,A ; 送出个位的7段代码
CLR P1.7
CLR P3.1 ; 开个位显示
ACALL DL1ms ; 显示1ms
SETB P3.1 ;
SETB P1.7
MOV A,BUF3 ; 取十位数
MOVC A,@A+DPTR ; 查十位数的7段代码
MOV P1,A ; 送出十位的7段代码
CLR P3.2 ; 开十位显示
ACALL DL1ms ; 显示1ms
SETB P3.2 ;
SETB P1.7
MOV A,BUF4 ; 取百位数
MOVC A,@A+DPTR ; 查百位数的7段代码
MOV P1,A ; 送出百位的7段代码
CLR P3.3 ; 开百位显示
ACALL DL1ms ; 显示1ms
SETB P3.3 ;
DJNZ R1,DPLP ; 250次没完循环
DJNZ R0,DP11 ; 4个100次没完循环
RET
;****************************************
;0.2MS延时(按12MHZ算)
;****************************************
DL1MS: MOV R7,#100
DJNZ R7,$
RET
;****************************************
;7段数码管0~9数字的共阳显示代码
;****************************************
NUMTAB: DB 0C0H,0F9H,0A4H,0B0H,99H,92H,82H,0F8H,80H,90H,0FFH,0BFH ;
; "0" "1" "2" "3" "4" "5" "6" "7" "8" "9" "不亮" "-"
;****************************************
END
‘肆’ 基于单片机的数字温度计设计好做么
这种设计相对来说比较好做。
首先选择用什么洞此庆系列的单片机。目前常用的有51单片机,AVR单片机,MSP430单片机等等。
接下来选择用什么传感器。
采用有温敏电阻,通过对直流电压分压,测量其直流电压的变化,也就是AD检测,再纳握把电压值转换成温度值;(这种方式要求单片机具有AD检测功能,否则需要外接AD转换芯片。)
采用温度模块,例如常用的DS18B20,不需要AD检测,只需要进行I2C读写取扒仔得温度值;
最后确定如何显示检测到的数值。
常用的有:
1.数码管,可以显示段码数字或简单字符。
2.LCD1602液晶屏,可以显示两行16*2个英文字母和数字;
3.LCD12864液晶屏,可以显示四行8*4个汉字。也可以显示字母及数字,当然也可以显示自定义图形。
以上选择需要合理搭配。
接着就是绘制原理图和PCB图、采集元件、焊接,编写程序,调试。
‘伍’ 单片机数字温度计设计用C语言写程序
#include<reg51.h>
#defineucharunsignedchar
sbitBEEP=P3^7; //接控制继电器
sbitDQ=P3^6; //接温度传感器18B20
uchart[2],number=0,*pt; //温度值
ucharTempBuffer1[4]={0,0,0,0};
ucharTmax=50,Tmin=10;
uchardistab[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e,0xff,0xfe,0xf7};
ucharcurrtemp;
voidt0isr()interrupt1
{
TH0=(65536-5000)/256;
TL0=(65536-5000)%256;
P2=1<<number;
if(number==2)P0=distab[TempBuffer1[0]]&0x7f;
elseP0=distab[TempBuffer1[0]];
number++;
if(number>3)number=0;
}
voiddelay_18B20(unsignedinti)
{
while(i--);
}
/**********ds18b20初始化函数**********************/
voidInit_DS18B20(void)
{
bitx=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读一个字节**************/
unsignedcharReadOneChar(void)
{
unsignedchari=0;
unsignedchardat=0;
for(i=8;i>0;i--)
{
DQ=0;//给脉冲信号
dat>>=1;
DQ=1;//给脉冲信号
if(DQ)
dat|=0x80;
delay_18B20(4);
}
return(dat);
}
/*************ds18b20写一个字节****************/
voidWriteOneChar(unsignedchardat)
{
unsignedchari=0;
for(i=8;i>0;i--)
{
DQ=0;
DQ=dat&0x01;
delay_18B20(5);
DQ=1;
dat>>=1;
}
}
/**************读取ds18b20当前温度************/
unsignedchar*ReadTemperature(unsignedcharrs)
{
unsignedchartt[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);
}
voidcovert1(void) //将温度转换为LED显示的数据
{
ucharx=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]++;
}
elseTempBuffer1[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;
elseBEEP=0;
}
voidconvert(chartmp)
{
uchara;
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);
}
}
‘陆’ 数字温度计单片机课程设计
用DS18B20来做就简单了,DS18B20是数字器件,测温范围:-55℃到+125℃,精度误差小于0.5℃,MCS51单片机可直接读出温度值,中途的信号放大、A/D转换都不需要。程序网上海了。
‘柒’ 求基于51单片机的温度计设计 测温传感器使用DS1631.只要C语言程序
真好,前些天写的程此滚序复制上来给你看看吧,注释比较少有点乱。功能是读取DS18b20的温度1602显示,顺便显示了几个自定义字符。
#include<reg52.h>
#include<stdio.h>
sbitrs=P2^4;
sbitrw=P2^5;
sbiten=P2^6;
sbitdq=P1^0;
bitmark;
unsignedinttemp=0;
unsignedcharcodedat1[]="wellcomestudyC";
unsignedcharcodeERROR[]="ERROR";
unsignedcharmo[]={0x10,0x07,0x0C,0x08,0x08,0x0C,0x07,0x00,
0x00,0x0F,0x09,0x09,0x0F,0x09,0x09,0x0F,
0x00,0x0F,0x09,0x0F,0x09,0x0F,0x11,0x13,
0x1F,0x15,0x15,0x1F,0x1F,0x15,0x15,0x1F,
0x00,0x1F,0x04,0x04,0x04,0x04,0x1F,0x00,
0x00,0x04,0x04,0x04,0x0A,0x11,0x11,0x00,
0x00,0x1F,0x04,0x0F,0x05,0x05,0x1F,0x00,
0x10,0x07,0x0C,0x08,0x08,0x0C,0x07,0x00};
charcodetab[16]="0123456789ABCDEF";
/*1ms延时子程序*/
voiddelay_1ms(unsignedchartime)
{
unsignedchara,b;
for(a=time;a>0;a--)
for(b=200;b>0;b--);
}
/*2us延时子程序*/
voiddelay2us(unsignedchart)
{
while(--t);
}
/*1602命令写入子程序*/
voidwcom(unsignedcharcom)
{
rs=0;
rw=0;
P0=com;
delay_1ms(3);
en=1;
en=0;
}
/*1602数据写入子程序*/
voidwdat(unsignedchardat)
{
rs=1;
rw=0;
P0=dat;
delay_1ms(3);
en=1;
en=0;
}
/*1602初始化*/
voidstart()
{
wcom(0x38);
wcom(0x0c);
wcom(0x06);
wcom(0x01);
}
//1602显示用户自定义字符子程序
voiddisplay()
{
unsignedcharm=0;
for(m=0;m<64;m++)
{
wcom(0x40+m);//设定自定义字模数据的存储地址
wdat(mo[m]);
}
wcom(0xc8);//显示自定义字符“C”
for(m=0;m<8;m++)
{
wdat(0x00+m);
delay_1ms(255);
}
}
/*18b20复位子程序*/
bitds18b20(void)
{
bitflag;
dq=1;
delay2us(10);
dq=0;
delay2us(200);
delay2us(200);
dq=1;
delay2us(50);
flag=dq;
delay2us(25);
returnflag;
}
/*向18b20写入一个字节的数据*/
voidwrite_dat(unsignedchardat)
{
unsignedchari;
for(i=0;i<8;i++)
{
dq=0;
delay2us(2);
dq=dat&0x01;
delay2us(22);
dq=1;
dat>>前哪=1;
}
}
/*读取18b20一个字节的数据*/
unsignedcharread_dat(void)
{
unsignedchari,dat=0;
for(i=0;i<8;i++)
{
dq=0;
dat>>=1;
dq=1;
if(dq)
dat|=0x80;
delay2us(25);
}
return(dat);
}
/*读取温慧扒码度*/
voidget_temp(void)
{
unsignedinta,b;
ds18b20();
write_dat(0xcc);
write_dat(0x44);
delay_1ms(2);
ds18b20();
write_dat(0xcc);
write_dat(0xbe);
a=read_dat();
b=read_dat();
/*********************温度数据处理程序段*/
if((b&0xf8)==0xf8)
{
mark=1;
b<<=8;
temp=((~(a+b))+1)*0.625;
}
else
{
mark=0;
b<<=8;
temp=(a+b)*0.625;
}
}
voidmain()
{
unsignedcharm;
start();
wcom(0x80);
for(m=0;m<16;m++)
{
wdat(dat1[m]);
delay_1ms(155);
}
display();
while(1)
{
get_temp();
if(ds18b20()) //若18b20初始化不成功或不存在即显示ERROR
{
unsignedcharj;
wcom(0xc2);
for(j=0;j<6;j++)
{
wdat(ERROR[j]);
}
}
else
{
wcom(0xc2);
if(mark)
wdat(0xb0);
else
wdat(0xa0);
wdat(tab[temp/1000]);
wdat(tab[(temp%1000)/100]);
wdat(tab[((temp%1000)%100)/10]);
wdat(0x2e);
wdat(tab[((temp%1000)%100)%10]);
}
}
}
‘捌’ 基于单片机的数字温度计设计难不难学
基于单片手仿机基薯戚的数字温度计设计难学。搏陵根据查询相关公开资料,学习单片机的数字温度计设计需要有一定的电子专业知识和嵌入式开发经验,此外,还需要掌握相关的软件设计技巧,才能更好地掌握这个设计课程。
‘玖’ 求求基于51单片机的数字温度计设计 单片机AT89C51 测温传感器使DS18B20 图在下面!只要c语言程序
#include <reg51.H>
#define uint unsigned int
#define uchar unsigned char
#define Alarm_Value 30 //温度报警值
sbit rs = P2^0;
sbit lcdcs = P2^2;
sbit buzzer = P3^4; //蜂鸣器报警
sbit OUT = P3^5; //光的检测
sbit DQ = P3^7; //温度传送数据IO口
uchar TempBuffer[8];
uint temp_value; //温度值
light_flag=1; //标志位
uchar value1[]={"TempShow:"};
uchar value2[]={"LightY/N:"};
uchar value3[]={"YES"};
uchar value4[]={"NO "};
/*******************************ds18b20子程序*******/
/***********ds18b20延迟子函数(晶振12MHz )*******/
void delay_18B20(unsigned int i)
{
while(i--);
}
/**********ds18b20初始化函数***********************/
void Init_DS18B20(void)
{
unsigned char x=0;
DQ = 1;
delay_18B20(8);
DQ = 0;
delay_18B20(80);
DQ = 1;
delay_18B20(14);
x=DQ;
delay_18B20(20);
}
/***********ds18b20读一个字节**********************/
unsigned char ReadOneChar(void)
{
uchar i=0;
uchar dat = 0;
for (i=8;i>0;i--)
{
DQ = 0; // 给脉冲信号
dat>>=1;
DQ = 1; // 给脉冲信号
if(DQ)
dat|=0x80; //先读入低字节
delay_18B20(4);
}
return(dat);
}
/*************ds18b20写一个字节********************/
void WriteOneChar(uchar dat)
{
unsigned char i=0;
for (i=8; i>0; i--)
{
DQ = 0;
DQ = dat&0x01;
delay_18B20(5);
DQ = 1;
dat>>=1;
}
}
/**************读取ds18b20当前温度****************/
void ReadTemp(void)
{
unsigned char a=0;
unsigned char b=0;
unsigned char t=0;
float tt;
Init_DS18B20();
WriteOneChar(0xCC); //Skip ROM command
WriteOneChar(0x44); //启动DS18B20进行温度转换
delay_18B20(100);
Init_DS18B20();
WriteOneChar(0xCC); //Skip ROM command
WriteOneChar(0xBE); // 读暂存器9个字节内容
delay_18B20(100);
a=ReadOneChar(); //读温度值低位
b=ReadOneChar(); //读温度值高位
temp_value=b;
temp_value<<=8;
temp_value=temp_value|a;
tt=temp_value*0.0625;
temp_value=tt*100+0.5; /*经典:处理保留几位小数(此列为2位);*/
}
/*******************温度值转换为字符串**************/
void temp_to_str()
{
TempBuffer[0]=temp_value/1000+'0'; //十位
TempBuffer[1]=temp_value%1000/100+'0'; //个位
TempBuffer[2]='.'; //小数点
TempBuffer[3]=temp_value%1000%100/10+'0'; //小数点后一位
TempBuffer[4]=temp_value%1000%100%10+'0'; //小数点后二位
TempBuffer[5]=0xdf; //温度符号
TempBuffer[6]='C';
TempBuffer[7]='\0';
}
void delay(uint ms)
{
uint i,j;
for (j=0;j<ms;j++)
for (i=0;i<120;i++);
}
Check_light()
{
if(out==0)
{
light_flag=1;
}
else
{
light_flag=0;
}
}
/**********1602显示开始 ***************************/
void write_command(uchar command)
{
rs=0;
P0=command;
lcdcs=1;
lcdcs=0;
}
void write_data(uchar data0)
{
rs=1;
P0=data0;
lcdcs=1;
lcdcs=0;
}
void init_1602()
{
delay(15);
write_command(0x38);
delay(5);
write_command(0x0c);
delay(5);
write_command(0x06);
delay(5);
}
/*****************1602显示结束 *********************
void show()
{
uchar i;
init_1602(); //初始化lcd
write_command(0x80); //液晶显示位置第一行第一个
Init_DS18B20();
ReadTemp();
temp_to_str();
for (i=0;i<sizeof(value1)-1;i++)
{
write_data(value1[i]);
delay(5);
}
for (i=0;i<sizeof(TempBuffer)-1;i++)
{
write_data(TempBuffer[i]);
delay(5);
}
write_command(0x80+0x40); //液晶显示位置 第二行第一个
delay(100);
for (i=0;i<sizeof(value2)-1;i++)
{
write_data(value2[i]);
delay(5);
}
if(light_flag== 1 )
{
for(i=0;i<sizeof(value3)-1;i++)
{
write_data(value3[i]);
delay(5);
}
}
else
{
for(i=0;i<sizeof(value4)-1;i++)
{
write_data(value4[i]);
delay(5);
}
}
}
void Temperature_Alarm() //温度报警
{
if(temp_value/100>=Alarm_Value) //取temp_value前两位
{
buzzer = 0; //不要用端口赋值
}
else
{
buzzer = 1;
}
}
/*****************主函数******************/
void main()
{
while(1)
{
show();
Temperature_Alarm();
Check_light();
}
}
我做的液晶是1602的