105 基于51单片机的简易无线门铃控制系统设计【毕设课设】

本设计由STC89C52单片机电路+315M无线遥控器模块+蜂鸣器报警电路+电源电路组成。

1、当遥控器按键按下后,蜂鸣器将会报警,如果不再按下,则5秒后关,如果再次按下,则以当前按下时间为准。

2、遥控器的按键引出。
 

 

 

#include<reg52.h> //包含头文件,一般情况不需要改动,头文件包含特殊功能寄存器的定义
#include<stdio.h>
#include "delay.h"

sbit fmq =P1^0;
sbit key = P2^0;
unsigned int i;

unsigned long time_20ms=255;		   //定时器计数
unsigned int flag=0;			   //按键标志位防止重复检测

void Init_Timer0(void);
void uartSendStr(unsigned char *s,unsigned char length);
void UART_Init(void);
void uartSendByte(unsigned char dat);

void main (void)
{     
	Init_Timer0();         //定时器0初始化
	UART_Init();
	DelayMs(200);          //延时有助于稳定
	uartSendStr("reday ok!!",10);
	while (1)         //主循环
	{
	 	if(key==1)	        	//检测到按键按下
		{
			if(flag==0)		    //防止重复检测
			{
				flag=1;
				time_20ms=0;	//清空计时
			}
		}
		



		if(time_20ms>250)		//定时5s
		{
			fmq=1;				 //蜂鸣器关
		}
		else
		{
			
			for(i=0;i<600;i++)	 //pwm调整咚 的声音
			{
				DelayMs(1);  
				fmq=!fmq;	    //蜂鸣器翻转
			}   
			fmq = 1;		   //清除中间声音
			DelayMs(100);         
	  }
	}
}


void Init_Timer0(void)
{
	TMOD |= 0x01;	  //使用模式1,16位定时器,使用"|"符号可以在使用多个定时器时不受影响		     
	TH0=(65536-20000)/256;		  //重新赋值 20ms
	TL0=(65536-20000)%256;
	EA=1;            //总中断打开
	ET0=1;           //定时器中断打开
	TR0=1;           //定时器开关打开
}

void Timer0_isr(void) interrupt 1 
{
//	TH0=(65536-20000)/256;		  //12M重新赋值 20ms
//	TL0=(65536-20000)%256;
	TL0 = 0x00;		//设置定时初值  	11.0592M重新赋值 20ms
	TH0 = 0xB8;		//设置定时初值	
	time_20ms++;
}


void UART_Init(void)
{
    SCON  = 0x50;		        // SCON: 模式 1, 8-bit UART, 使能接收  
    TMOD |= 0x20;               // TMOD: timer 1, mode 2, 8-bit 重装
    TH1   = 0xFD;               // TH1:  重装值 9600 波特率 晶振 11.0592MHz
	TL1 = TH1;  
    TR1   = 1;                  // TR1:  timer 1 打开                         
    EA    = 1;                  //打开总中断
    ES    = 1;                  //打开串口中断
}

void uartSendByte(unsigned char dat)
{
	unsigned char time_out;
	time_out=0x00;
	SBUF = dat;			  //将数据放入SBUF中
	while((!TI)&&(time_out<100))  //检测是否发送出去
	{time_out++;DelayUs2x(10);}	//未发送出去 进行短暂延时
	TI = 0;						//清除ti标志
}

void uartSendStr(unsigned char *s,unsigned char length)
{
	unsigned char NUM;
	NUM=0x00;
	while(NUM<length)	//发送长度对比
	{
		uartSendByte(*s);  //放松单字节数据
		s++;		  //指针++
		NUM++;		  //下一个++
  	 }
}

void UART_SER (void) interrupt 4 	//串行中断服务程序
{
	if(RI)                        //判断是接收中断产生
	{
		RI=0;                      //标志位清零
	}
	if(TI)  //如果是发送标志位,清零
	TI=0;
} 






 资料下载地址

https://pan.baidu.com/s/1yx8gentKQVvQOUBzsnQu_A?pwd=8888

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值