1. 51單片機聲音報警SPEAKER
R3 10K去掉,R2低於1K,硬體就這些問題,
程序上,delay函數太短了,51上,燒進去跑,人根本感覺不出來。裡面加一級循壞,for(j=0;j<256;j++);這樣就沒什麼問題了
2. 單片機報警聲
呵呵,在中斷裡面寫程序就可以了,發出來的聲音就是救護車的聲音,以前直接用三極體做過這個電路。
3. 單片機報警器程序
請問你需要對什麼報警呢?溫度,濕度?
還是只是單純的給個時間讓蜂鳴器響?我有寫好的程序,
4. 單片機報警程序
不就是用個I/O口控制個喇叭這類的,有什麼好寫的,最多也就是用定時器產生不同的頻率而已.
5. 開關控制報警器如何用單片機實現
開關控制報警器如何用單片機實現
單片機C語言程序設計:開關控制報警器
/*名稱:開關控制報警器
說明:用K1開關控制報警器,程序控制P1.0輸出兩種不同頻率的聲音,模擬很逼真的報警效果
*/
#include
#defineucharunsignedchar
#defineuintunsignedint
sbitSPK=P1^0;
sbitK1=P1^7;
//發聲函數
voidAlarm(uchart)
{
uchari,j;
for(i=0;i<200;i++)
{
SPK=~SPK;
for(j=0;j//由參數t行成不同的頻率
}
voidmain()
{
SPK=0;
while(1)
{
if(K1==1)
{
Alarm(90);
Alarm(120);
}
}
}
6. 單片機脈沖報警電路工作原理
此報警器主要功能部分採用成品的模塊,所以比較容易製作。它有遙控設定防盜、遙控關閉防盜自動鎖定引擎和防搶劫等功能。工作原理如下:電源接通後按動遙控器防盜設定鍵(A鍵),HY988A I/O端輸出跳變高電平經D3使T3導通HY-5高響度喇叭發聲作為回應信號。同HY988A A輸出端輸出高電平經R1為T1提供基極電流,這時如果HY966受到輕微震動,其輸出端輸出高電平脈沖使T1導通,T1的導通使C1瞬間充電至+5V左右,此電壓高於比較器參考電壓,比較器反轉輸出高電平經 A1B 緩沖後驅動繼電器吸合、HY-5喇叭報警。此後如 HY966 不在受到震動C1經R4緩慢放電,當C1上的電壓放電至低於比較器參考電壓時,比較器反轉輸出低電平,繼電器釋放、報警停止,繼續警戒狀態。如果在報警過程中按遙控器關閉防盜鍵(B鍵),則HY988A A輸出端變為低電平 T1 失去基極電流,同時經 D2 使C1快速放電,報警立刻停止。以後不論HY966有無受到震動都不會使T1導通而觸發報警,防盜警戒解除,可正常駕駛。另外如車被啟動按遙控器任意按鍵都會使喇叭回應、引擎熄火,此功能可做防搶或尋車使用。 器件選用:震動監測部分用 HY966微震動感測器,它靈敏度高並且可以調整,使用時按芯線顏色連接。遙控功能部分採用,HY988A兩位遙控組件,只用其A和I/O兩個輸出端,遙控器A鍵作為防盜設定、B鍵作為防搶、關閉防盜用。報警部分用高響度喇叭,只用將喇叭引線按正負接入即可,其聲極可達120db;比較和緩沖器用一塊 LM358 雙運放。三端穩壓採用78L06;繼電器用4123型躅點電流大於5A。其它元件參數按圖中標示。
接線方法:將調試好的報警器用合適的外殼裝好,把報警器正極與車用電瓶正極相連,負極搭鐵或接電瓶負極;震動感測器緊貼車體安裝好,將摩托或其它機動車原點火線剪開上端接繼電器 A點,下端接繼電器 B點。接好後按防盜設定鍵,喇叭回應一聲,進入警戒狀態,這時如果車被輕微震動或移動,都將觸發報警,喇叭發出120db強力警號的同時繼電器吸合點火線斷開
7. C51單片機報警程序,怎樣把報警時長定為15s
if(js==30)----你這是30,報警多少秒?
{
js=0;
flag1=0;
...
改大一些,是不是就加長了?
8. 單片機溫度報警系統
不是太難,當然對剛剛接觸單片機的人而言還是有一定難度的,下面是我做的一個溫控系統,供參考。
//溫控系統控製程序
//版本號:V1.0;2015.6.19
//溫度感測器:DS18B20
//顯示方式:LED
#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);
}
}
9. 單片機報警聲設計
//定義管腳
sbitpause=P1^0;
unsignedchart1_cnt;
voidmain(void)
{
TMOD|=0X11;
TH0=(65536-500)/256;//定時500微秒
TL0=(65536-500)%256;
TR0=1;
ET0=1;
TH1=(65536-50000)/256;//定時50000微秒
TL1=(65536-50000)%256;
TR1=1;
ET1=1;
EA=1;
t1_cnt=0;
while(1);
}
voidint_t0(void)interrupt1//定時器0中斷
{
TH0=(65536-500)/256;//定時500微秒
TL0=(65536-500)%256;
pause=~pause;
}
voidint_t1(void)interrupt3//定時器1中斷
{
TH1=(65536-50000)/256;//定時50000微秒
TL1=(65536-50000)%256;
t1_cnt++;
if(t1_cnt>=4)
{
t1_cnt=0;
ET0=~ET0;
}
}
10. 單片機編程如何實現誤報警
多接收幾次,取值,比如在一定時間內接收到50次,則超過三十次認為有報警,否則不報警