單片機課程設計報告數字溫度計
⑴ 單片機課程設計 數字溫度計
我可以來為你提供所有你源所需要的,用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;
}
}