『壹』 單片機怎麼接模擬溫度感測器,能不能直接連接,為什麼,中間要加什麼電路,誰做過這個的能不能發個電路圖到
這個很簡單,如果你用的單片機內核有AD轉換電路的話,就可以直接接模擬溫度感測器,注意模擬溫度感測器在感知溫度時,會給出不同的模擬電壓,這個模擬電壓還不能超過單片機的埠的最高承受電平
如果單片機沒有AD轉換電路,則需要外接AD轉換電路來實現模擬電壓轉換數字電壓。溫度感測器可以選擇最常用的就夠了,電路很簡單,把輸出端連出來就行了!注意供電和接地
『貳』 多種感測器怎麼和單片機連接
AM2301電容式溫濕度感測器+MQ2氣體感測器+GP2Y1010AU0F灰塵感測器+HC-SR501人體紅外感應模塊+光敏電阻感測器模塊。
其中人體紅外感應模塊(開關量)輸出端可以直接連接到開發板任何IO端。
其他都是模擬量,如果輸出不是數字量,要經過AD轉換,不能直接連到單片機開發板上。
『叄』 我想知道一個單片機怎麼與多個溫度感測器相連,然後怎麼通過無線的方式連到電腦再顯示出來
溫度感測器有多種介面,如果你是想借用現有的開發板的話,可以採用幾種溫度感測器,如和你所說的兩個感測器介面匹配的感測器兩個(不知道是啥介面);I^2C介面的感測器也可以搞幾個(單片機開發板IIC介面一般都有);實在不行可以用熱敏電阻/鉑電阻,這樣就可以借用AD口來檢測溫度了,4、5個可以輕松解決。
至於無線傳送到電腦顯示,方法也很多,最簡單就是採用樓上的說法,用現成模塊,就是那種透傳模塊;開發板出口用串口,然後用透傳模塊傳換成無線(射頻、GPRS、電力載波隨你選)。然後電腦側也需要一個相對應接收模塊用於接收信號;當然,電腦要顯示還需要一個相應的後台軟體。
『肆』 溫度感測器怎麼傳輸信號給單片機,
我對DS18B20還是很熟悉的,前一陣才用過。如果你是應用這個的,那麼你不需要搞清楚它的內部原理,內部主要有ROM.RAM和溫度感測器。DS18B20是使用一根數據線進行通信,首先你要先向它發送一系列脈沖信號。一般我們用的步驟大致為:初始化--跳過ROM操作--啟動溫度轉換--(延時)--初始化--跳過ROM操作--讀溫度寄存器命令然後就可以讀出溫度的數據了。先讀出的是低8位,然後是高位。由於是單線通信,所以對時序的要求相對較高,所以你要根據時序圖和自己的晶振頻率好好計算一下。最後還要注意的是,它的數據線平時是要拉到高電平的。以上都是我自己打出來的,希望對你有幫助!
『伍』 DS18B20與單片機結合來測量溫度。利用數字溫度感測器DS18B20測量溫度信號
#include <reg51.h>
#define uchar unsigned char
sbit keyup=P1^0;
sbit keydn=P1^1;
sbit keymd=P1^2;
sbit out=P3^7; //接控制繼電器
sbit DQ = P3^4; //接溫度感測器18B20
uchar t[2],number=0,*pt; //溫度值
uchar TempBuffer1[4]={0,0,0,0};
uchar Tmax=18,Tmin=8;
uchar distab[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e,0xff,0xfe,0xf7};
uchar dismod=0,xiaodou1=0,xiaodou2=0,currtemp;
bit flag;
void t0isr() interrupt 1
{
TH0=(65536-5000)/256;
TL0=(65536-5000)%256;
switch(number)
{
case 0:
P2=0x08;
P0=distab[TempBuffer1[0]];
break;
case 1:
P2=0x04;
P0=distab[TempBuffer1[1]];
break;
case 2:
P2=0x02;
P0=distab[TempBuffer1[2]]&0x7f;
break;
case 3:
P2=0x01;
P0=distab[TempBuffer1[3]];
break;
default:
break;
}
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=8;i>0;i--)
{
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=8; i>0; i--)
{
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;
//以下程序段消去隨機誤檢查造成的誤判,只有連續12次檢測到溫度超出限制才切換加熱裝置
if(currtemp>Tmin)xiaodou1=0;
if(y<Tmin)
{
xiaodou1++;
currtemp=y;
xiaodou2=0;
}
if(xiaodou1>12)
{
out=0;
flag=1;
xiaodou1=0;
}
if(currtemp<Tmax)xiaodou2=0;
if(y>Tmax)
{
xiaodou2++;
currtemp=y;
xiaodou1=0;
}
if(xiaodou2>12)
{
out=1;
flag=0;
xiaodou2=0;
}
out=flag;
}
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;
}
void keyscan( )
{
uchar keyin;
keyin=P1&0x07;
if(keyin==0x07)return;
else if(keymd==0)
{
dismod++;
dismod%=3;
while(keymd==0);
switch(dismod)
{
case 1:
convert(Tmax);
TempBuffer1[3]=0x11;
break;
case 2:
convert(Tmin);
TempBuffer1[3]=0x12;
break;
default:
break;
}
}
else if((keyup==0)&&(dismod==1))
{
Tmax++;
convert(Tmax);
while(keyup==0);
}
else if((keydn==0)&&(dismod==1))
{
Tmax--;
convert(Tmax);
while(keydn==0);
}
else if((keyup==0)&&(dismod==2))
{
Tmin++;
convert(Tmin);
while(keyup==0);
}
else if((keydn==0)&&(dismod==2))
{
Tmin--;
convert(Tmin);
while(keydn==0);
}
xiaodou1=0;
xiaodou2=0;
}
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();
keyscan();
delay_18B20(30000);
}
}