找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1688|回复: 0
收起左侧

51单片机按键显示数字键键值程序+Proteus仿真图

[复制链接]
ID:992634 发表于 2021-12-15 11:06 | 显示全部楼层 |阅读模式
要求:假设键盘上的8个按键,分别代表数字键“0”  "1" “2” “3” "4" “5” “6” “7”则要求在连续按下不同数字按键时,从左往右以此显示按下的数字键键值。附件里包含了Proteus仿真,keil源程序以及流程图。
按下按键:
fdee2d69c7f003a59aecab2c672df3fe.png 51hei.gif

单片机源程序如下:
  1. #include <reg52.h>
  2. #include "key.h"
  3. unsigned char code smgd[]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8};//段选
  4. unsigned char code smgw[]={0x80,0x40,0x20,0x10,0x08,0x04,0x02,0x01};//位选
  5. unsigned char smgdbuff[]={0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff};//段选暂存
  6. unsigned char jh[]={0xff,0xff,0xff};//交换
  7. unsigned  char b=0;
  8. unsigned  char a=0;
  9. unsigned  char t=0;
  10. unsigned  char f=0;//记录0的位置
  11. void dir();
  12. void Delay100us()                //@12.000MHz
  13. {
  14.         unsigned char i, j;

  15.         i = 2;
  16.         j = 39;
  17.         do
  18.         {
  19.                 while (--j);
  20.         } while (--i);
  21. }
  22. void display(unsigned char key)
  23. {        
  24.         t=k;
  25.         switch(key)//根据返回的键值给段选数组赋值
  26.         {
  27.                 case 1:smgdbuff[k-1]=smgd[0];break;
  28.                 case 2:smgdbuff[k-1]=smgd[1];break;
  29.                 case 3:smgdbuff[k-1]=smgd[2];break;
  30.                 case 4:smgdbuff[k-1]=smgd[3];break;
  31.                 case 5:smgdbuff[k-1]=smgd[4];break;
  32.                 case 6:smgdbuff[k-1]=smgd[5];break;
  33.                 case 7:smgdbuff[k-1]=smgd[6];break;
  34.                 case 8:smgdbuff[k-1]=smgd[7];break;
  35.                 default:break;
  36.         }
  37.         if(k==1)
  38.         {
  39.                 jh[0]=smgdbuff[0];//存放第一个按键按下的数字
  40.         }
  41.         jh[2]=smgdbuff[k-1];//把最高位的数字暂存
  42.         if(z==1)
  43.         {
  44.                 for(a=0;a<k;a++)
  45.                 {
  46.                         if(smgdbuff[a]==jh[0])//存放第一个按下的数字的位置
  47.                                 f=a;
  48.                 }
  49.                 for(a=0;a<k;a++)//交换程序,把次高位及之后的位依次前移,这里t是最高位的位置,f是次高位的位置
  50.                 {
  51.                         t--;
  52.                         smgdbuff[t]=smgdbuff[f];
  53.                         f--;
  54.                 }
  55.                 smgdbuff[0]=jh[2];//把最高位的数字送到最低位
  56.                 z=0;
  57.         }
  58.         if(k==8)
  59.         {
  60.                 while(1)
  61.                 {
  62.                         dir();
  63.                 }
  64.         }
  65.         dir();
  66. }
  67. /*显示*/
  68. void dir()
  69. {
  70.         for(b=0;b<k;b++)
  71.         {
  72.                 P1=smgdbuff[b];
  73.                 P3=smgw[b];
  74.                 Delay100us();
  75.                 P3=0x00;               
  76.                 P1=0xff;                //消影
  77.                 Delay100us();
  78.                 Delay100us();
  79.         }
  80. }
复制代码
51hei.png
所有资料51hei附件下载:
Proteus8.8与代码.7z (2.99 MB, 下载次数: 22)

评分

参与人数 1黑币 +30 收起 理由
admin + 30 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表