基于单片机的占座占位管理(16)系统设计(#0546)

2024-01-10 11:39:18

功能描述

本设计应用:座位管理、车位管理、存柜管理、图书管理等。

1、采用51单片机作为主控;
2、采用1602显示已占数量,总数16;
3、采用红外对管检测遮挡,判断位置是否被占用;
4、当对管有遮挡时,点亮LED,计数器+1;
5、当对管无遮挡时,计时5s后再次检测,仍无遮挡,熄灭LED,计数器-1;

电路设计

采用Altium?Designer作为电路设计工具。Altium?Designer通过把原理图设计、PCB绘制编辑、拓扑逻辑自动布线、信号完整性分析和设计输出等技术的完美融合,为设计者提供了全新的设计解决方案,使设计者可以轻松进行设计,熟练使用这一软件必将使电路设计的质量和效率大大提高。

单片机管脚说明:

P0端口(P0.0-P0.7):P0口为一个8位漏极开路双向I/O口,每个引脚可吸收8TTL门电流。当P1口的管脚第一次写1时,被定义为高阻输入。P0能够用于外部程序数据存储器,它可以被定义为数据/地址的第八位。在FIASH编程时,P0 口作为原码输入口,当FIASH进行校验时,P0输出原码,此时P0外部必须被拉高。

P1端口(P1.0-P1.7):P1口是一个内部提供上拉电阻的8位双向I/O口,P1口缓冲器能接收输出4TTL门电流。P1口管脚写入1后,被内部上拉为高电平,可用作输入,P1口被外部下拉为低电平时,将输出电流,这是由于内部上拉的缘故。在FLASH编程和校验时,P1口作为第八位地址接收。

P2端口(P2.0-P2.7):P2口为一个内部上拉电阻的8位双向I/O口,P2口缓冲器可接收,输出4个TTL门电流,当P2口被写“1”时,其管脚被内部上拉电阻拉高,且作为输入。并因此作为输入时,P2口的管脚被外部拉低,将输出电流。这是由于内部上拉的缘故。P2口,用于外部程序存储器或16位地址外部数据存储器进行存取时,P2口输出地址的高八位。在给出地址“1”时,它利用内部上拉优势,当对外部八位地址数据存储器进行读写时,P2口输出其特殊功能寄存器的内容。P2口在FLASH编程和校验时接收高八位地址信号和控制信号。

P3端口(P3.0-P3.7):P3口管脚是一个带有内部上拉电阻的8位的双向I/O端口,可接收输出4个TTL门电流。当P3口写入“1”后,它们被内部上拉为高电平,并用作输入。作为输入端时,由于外部下拉为低电平,P3口将输出电流(ILL)。P3口同时为闪烁编程和编程校验接收一些控制信号。

仿真设计

采用Proteus作为仿真设计工具。Proteus是一款著名的EDA工具(仿真软件),从原理图布图、代码调试到单片机与外围电路协同仿真,一键切换到PCB设计,真正实现了从概念到产品的完整设计。

主程序设计

void main()
{
	init_1602();
	write_string(1,0,"ALL Number:");
	TMOD|=0X01;
	TH0=0X3C;
	TL0=0XB0;	
	ET0=1;//打开定时器0中断允许
	EA=1;//打开总中断
	TR0=1;//打开定时器
	while(1)
	{
		 
	}
}
//定时器中断
void Timer0() interrupt 1
{
	uchar i=0;
	if(time<10)//0.5s
		time++;
	else
	{
		time=0;
		for(i=0;i<16;i++)
		{
			if(read1(i)>0)//座位有人
			{
				 set(i);
			}
			else
			{
				if(read2(i)>0)//座位无人
				{
					if(miao[i]<10)//倒计时
						miao[i]++;
					else
					{
						miao[i]=0;
						clr(i);	  //熄灭led
					}
				}
			}
		}
		all();//统计亮灯数量
		disp[0]=num/10+0x30;//显示
		disp[1]=num%10+0x30;
		write_string(2,6,disp);
	}
	TH0=0X3C;
	TL0=0XB0;
}

源文件获取

关注公众号-电子开发圈,首页发送?“公共设备” 获取;

文章来源:https://blog.csdn.net/weixin_42625444/article/details/135439229
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。