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次,则超过三十次认为有报警,否则不报警