基于51单片机的排队叫号系统设计(已通过proteus仿真)

基于51单片机的排队叫号系统设计(已通过proteus仿真)

系统概述

	笔者认为,该项目设计特点为:工作模式贴近生活实际,设计思路较为小众,芯片利用率高,代码易懂。
	该系统在实际应用中可减缓流水号排序速度,增加用户及时按下按键的时间,使之更为实用。

应用软件及版本

	本系统设计主要使用了keil5和proteus8.6。读者应注意在直接通过下方链接下载原工程文件后,
	自己电脑上的软件版本是否与笔者的相匹配。一般情况下都是高版本软件能打开低版本文件,
	否则会出现问题。

系统功能描述

	本系统基于STC15F2K60S2芯片,通过proteus仿真软件,模拟排队叫号系统。
	因proteus8.6版本中不含有该芯片,故采用AT89C51作为替代。
	该系统共有八个窗口,显示屏显示叫号格式为“窗口号--流水号”。
	八个按键控制八个窗口的占用状态,按下为占用,重复按下为办理业务结束,解除占用。

代码及仿真展示

//**********************************************************************************************************
//****项目名称:基于单片机的排队叫号系统设计
//****创建人:Kingzd
//****创建日期:2020年4月19日
//****项目效果:模拟叫号系统,显示屏显示“窗口号--流水号”,共有八个窗口,模拟出八个按键,若有按键按下,则视为
//******窗口被占用,屏幕显示流水将略过该窗口,依次往下排流水号,若再次按下,则解除占用状态,参与下一轮流水排号
//****版本控制:1.0版本
//**********************************************************************************************************
#include <STC15F2K60S2.H>
#include <intrins.h>

typedef unsigned char uchar;
typedef unsigned int uint;

sbit shcp_dr = P2^0;
sbit ds_dr = P2^1;
sbit stcp_dr = P2^2;
sbit mr_dr = P2^3;
sbit oe_dr = P2^4;
sbit Beep = P2^6;
sbit Win1 = P1^0;
sbit Win2 = P1^1;
sbit Win3 = P1^2;
sbit Win4 = P1^3;
sbit Win5 = P1^4;
sbit Win6 = P1^5;
sbit Win7 = P1^6;
sbit Win8 = P1^7;

uint code DigSegBuff[]=
{
	0x00c0,0x00f9,0x00a4,0x00b0,0x0099,0x0092,0x0082,0x00f8,          //0 - 7
	0x0080,0x0090,0x0088,0x0083,0x00c6,0x00a1,0x0086,0x008e,          //8 - 15
	0x00bf,0x00c1,0x0091                                              // - u y
};

static uchar flag[]={1,1,1,1,1,1,1,1};

void IniSystem();
void IniPeripherals();
void DelayXms(uint uiXms);
void BeepVoice(uchar ucNum);
void SendWords(uint uiDig);
void Display();

void main()
{
	IniSystem();
	_nop_();
	IniPeripherals();
	_nop_();
	while(1)
	{
		Display();
	}
}

void IniSystem()
{
	shcp_dr = 0;
	stcp_dr = 1;
	mr_dr = 0;
	oe_dr = 1;
	Beep = 0;
	EX0 = 0;    
	IE0 = 0;
}

void IniPeripherals()
{
	shcp_dr = 0;
	stcp_dr = 0;
	mr_dr = 1;
	oe_dr =1;
	Beep = 1;
	P1 = 0xff;
	EA = 1;           //打开总中断,成功前的最后一关
	EX0 = 1;
	IE0 = 1;
	IT0 = 1;
}

void DelayXms(uint uiXms)
{
	uint i,j;
	for(i = uiXms;i > 0;i--)
	{
		for(j = 110;j > 0;j--);
	}
}

void BeepVoice(uchar ucNum)
{
	uchar k;
	for(k = 0;k < ucNum;k++)
	{
		Beep = 0;
		DelayXms(120);
		Beep = 1;
		DelayXms(120);
	}
	Beep = 1;
}

void SendWords(uint uiDig)
{
	uint uiTemp = ~uiDig;
	uchar k;
	for(k = 0;k < 16;k++)
	{
		if((uiTemp & 0x8000) != 0x8000)
		{
			ds_dr = 1;
		}
		else
		{
			ds_dr = 0;
		}
		shcp_dr = 0;
		_nop_();
		shcp_dr = 1;
		_nop_();
		shcp_dr = 1;
		uiTemp = uiTemp << 1;
	}
	stcp_dr = 0;
	_nop_();
	stcp_dr = 1;
	_nop_();
	stcp_dr = 0;
	oe_dr = 0;
}

void Display()
{
	uchar k,m;
	uint uiTemp,uiBit = 0x0001;        
	static uchar NumQ = 0,NumB = 0,NumS = 0,NumG = 1;      //计数变量

	for(m = 0;m < 8;m++)
	{
		if(flag[m] == 1)
		{		
		BeepVoice(3);
		for(k = 0; k < 20;k++)   //八位数码管显示
		{
		uiTemp = (uiBit << 8) | ((DigSegBuff[0]) & 0x00ff);
	  SendWords(uiTemp);
	  uiBit = uiBit << 1;
		DelayXms(6);
		uiTemp = (uiBit << 8) | ((DigSegBuff[m+1]) & 0x00ff);
	  SendWords(uiTemp);
	  uiBit = uiBit << 1;
		DelayXms(6);
		uiTemp = (uiBit << 8) | ((DigSegBuff[16]) & 0x00ff);
	  SendWords(uiTemp);
	  uiBit = uiBit << 1;
		DelayXms(6);
		uiTemp = (uiBit << 8) | ((DigSegBuff[16]) & 0x00ff);
	  SendWords(uiTemp);
  	uiBit = uiBit << 1;
		DelayXms(6);
		uiTemp = (uiBit << 8) | ((DigSegBuff[NumQ]) & 0x00ff);
	  SendWords(uiTemp);
	  uiBit = uiBit << 1;
		DelayXms(6);
		uiTemp = (uiBit << 8) | ((DigSegBuff[NumB]) & 0x00ff);
	  SendWords(uiTemp);
  	uiBit = uiBit << 1;
		DelayXms(6);
		uiTemp = (uiBit << 8) | ((DigSegBuff[NumS]) & 0x00ff);
  	SendWords(uiTemp);
	  uiBit = uiBit << 1;
		DelayXms(6);
	  uiTemp = (uiBit << 8) | ((DigSegBuff[NumG]) & 0x00ff);
	  SendWords(uiTemp);
	  uiBit = uiBit << 1;
		DelayXms(6);
		uiBit = uiBit << 1;
    uiBit = 0x0001;
	  }       //八位数码管显示

	NumG ++;            //序列号按位计数
	if(NumG > 9)
	{
		NumG = 0;
		NumS ++;
		if(NumS > 9)
		{
			NumS = 0;
			NumB ++;
			if(NumB > 9)
			{
				NumB = 0;
				NumQ ++;
				if((NumQ == 9)&(NumB == 9)&(NumS == 9)&(NumG > 9))
				{
					NumQ = 0;
					NumB = 0;
					NumS = 0;
					NumG = 1;
				}
			}
		 }
	 }   //序列号计数
	
 }   //if
}
}

void int0Win() interrupt 0
{
	EX0 = 0;
	if(Win1 == 0)
	{
		flag[0] = ~flag[0];
	}
	if(Win2 == 0)
	{
		flag[1] = ~flag[1];
	}
	if(Win3 == 0)
	{
		flag[2] = ~flag[2];
	}
	if(Win4 == 0)
	{
		flag[3] = ~flag[3];
	}
	if(Win5 == 0)
	{
		flag[4] = ~flag[4];
	}
	if(Win6 == 0)
	{
		flag[5] = ~flag[5];
	}
	if(Win7 == 0)
	{
		flag[6] = ~flag[6];
	}
	if(Win8 == 0)
	{
		flag[7] = ~flag[7];
	}
	EX0 = 1;         //尝试注释,发现影响功能,故保留            
}

//****By Kingzd****

在这里插入图片描述

工程文件链接

上述工程文件链接(含代码文件和仿真文件)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值