当前位置: 首页 > ds >正文

【51单片机】【protues仿真】基于51单片机呼叫系统

 目录

一、主要功能

二、使用步骤

三、硬件资源

四、软件设计

五、实验现象

一、主要功能

1、数码管显示
2、矩阵按键​
3、呼叫后数码管显示号数同时声光警报提示
4、应答按键按下后取消当前呼叫和声光警报

二、使用步骤

基于51单片机的呼叫系统设计(如病床呼叫、排队叫号等)是一种典型的嵌入式应用,采用数码管显示,矩阵按键和蜂鸣器组成。

三、硬件资源

1、51单片机核心模块
2、按键模块
3、蜂鸣器模块,led灯模块
4、数码管显示模块

四、软件设计

#include <reg51.h>
#include"intrins.h"
#define uint unsigned int
#define uchr unsigned char
sbit led0=P2^2;
sbit buzzer=P2^3;
sbit dula=P2^6;                //声明段选线选通端
sbit wela=P2^7;                //声明位选线选通端
sbit clear=P3^4;
uchr key,shi,ge,count;
uchr code tab[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,
0x39,0x5e,0x79,0x71,
0x76,0x79,0x38,0x3f};

/*延时子函数,xms为形参*/
void delay(uint xms)
{
  do
        {
                _nop_();
                _nop_();
                _nop_();
                xms--;
        }
        while(xms);
}

/*矩阵键盘扫描子程序*/
void matrixkeyscan()
{
    uint temp;
    P3=0xf7;                             //给P3口赋值
    temp=P3;
    temp=temp&0xf0;
    if(temp!=0xf0)                       //检测是否有键按下
    {
        delay(6);                       //延时去抖
        temp=P3;
        temp=temp&0xf0;
        if(temp!=0xf0)                   //再次检测是否有键按下
        {
            temp=P3;
            switch(temp)
            {
                case 0x77:
                    key=1;
                    break;
                case 0xb7:
                    key=2;
                    break;
                case 0xd7:
                    key=3;
                    break;
                case 0xe7:
                    key=4;
                    break;              //判断按下的是哪个键
            }
            while(temp!=0xf0)
            {
                temp=P3;
                temp=temp&0xf0;        
            }                           //等待按键释放
        }
    }
    P3=0xfb;
    temp=P3;
    temp=temp&0xf0;
    if(temp!=0xf0)
    {
        delay(6);
        temp=P3;
        temp=temp&0xf0;
        if(temp!=0xf0)
        {
            temp=P3;
            switch(temp)
            {
                                case 0x7b:
                    key=5;
                    break;
                case 0xbb:
                    key=6;
                    break;
                case 0xdb:
                    key=7;
                    break;
                case 0xeb:
                    key=8;
                    break;
            }
            while(temp!=0xf0)
            {
                temp=P3;
                temp=temp&0xf0;
            }
        }
    }
    P3=0xfd;
    temp=P3;
    temp=temp&0xf0;
    if(temp!=0xf0)
    {
        delay(6);
        temp=P3;
        temp=temp&0xf0;
        if(temp!=0xf0)
        {
            temp=P3;
            switch(temp)
            {
                case 0x7d:
                    key=9;
                    break;
                case 0xbd:
                    key=10;
                    break;
               case 0xdd:
                    key=11;
                    break;
                case 0xed:
                    key=12;
                    break;
            }
            while(temp!=0xf0)
            {
                temp=P3;
                temp=temp&0xf0;
            }
        }
    }
    P3=0xfe;
    temp=P3;
    temp=temp&0xf0;
    if(temp!=0xf0)
    {
        delay(6);
        temp=P3;
        temp=temp&0xf0;
        if(temp!=0xf0)
        {
            temp=P3;
            switch(temp)
            {
                case 0x7e:
                    key=13;
                    break;
                case 0xbe:
                    key=14;
                    break;
                case 0xde:
                    key=15;
                    break;
                case 0xee:
                    key=16;
                    break;
            }
            while(temp!=0xf0)
            {
                temp=P3;
                temp=temp&0xf0;
            }
        }
    }
}

五、实验现象

演示视频:

http://www.xdnf.cn/news/19788.html

相关文章:

  • 基于Force-closure评估的抓取计算流程
  • 生成知识图谱与技能树的工具指南:PlantUML、Mermaid 和 D3.js
  • 【AI报表】JimuReport 积木报表 v2.1.3 版本发布,免费可视化报表和大屏
  • 【leetcode】222. 完全二叉树的节点个数
  • Altium Designer中的Net-Tie:解决多网络合并与电气隔离的利器
  • CPTS-Vintage 票据,基于资源的约束委派 (RBCD),DPAPI密钥
  • 自制扫地机器人(二) Arduino 机器人避障设计——东方仙盟
  • Veo Videos Generation API 对接说明
  • 鸿蒙NEXT表单选择组件详解:Radio与Checkbox的使用指南
  • 开源 C++ QT Widget 开发(十)IPC进程间通信--共享内存
  • 零跑汽车8月交付57066台,同比增长超88%
  • amd cpu是x86架构吗
  • 【Audio】静音或振动模式下重复来电响铃
  • stdexcept介绍与使用指南
  • 【LeetCode】3670. 没有公共位的整数最大乘积 (SOSDP)
  • Day19_【机器学习—线性回归 (3)—回归模型评估方法】
  • Docker一键快速部署压测工具,高效测试 API 接口性能
  • ES6手录01-let与const
  • 学习日记-spring-day47-9.1
  • PyCharm 2025版本中新建python工程文件自动创建.venv的意义和作用
  • 教育 AI 的下半场:个性化学习路径生成背后,技术如何平衡效率与教育本质?
  • 第二十八天-DAC数模转换实验
  • “便农惠农”智慧社区系统(代码+数据库+LW)
  • 【深度学习基础】深度学习中的早停法:从理论到实践的全面解析
  • OpenCV C++ 入门实战:从基础操作到类封装全解析
  • UART控制器——ZYNQ学习笔记14
  • QT中的HTTP
  • GSM8K 原理全解析:从数学推理基准到大模型对齐的试金石
  • 五、练习2:Git分支操作
  • 安卓版 Pad 搭载 OCR 证件识别:酒店入住登记的高效解法