找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4594|回复: 2
打印 上一主题 下一主题
收起左侧

4*8矩阵键盘单片机仿真+程序 新手一枚

[复制链接]
跳转到指定楼层
楼主
4*8矩阵键盘显示0-31,使用  一阴一阳数码管,当然有一个疑问本来两位数码管同时可以使用一个位选端口,和同一个P0口的但是发现会出现乱码,而且发现。共阴数码管亮的数据段位,刚好是共阳不亮的段位,怎么用三极管是两者的电压达到平衡呢。不得已把代码改了共阴管使用P0口,共阳管使用P3口,实现功能

仿真原理图如下(proteus仿真工程文件可到本帖附件中下载):


单片机源程序如下:
  1. #include "reg51.h"
  2. #define uchar unsigned char
  3. sbit disn2=P3^5;
  4. sbit disn1=P3^6;

  5. uchar code tab[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};
  6. uchar code dab[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90};
  7. uchar temp,num,n1,n2;

  8. void display();
  9. keyscan();

  10. void delay(uchar z)
  11. {
  12. uchar x,y;
  13. for(x=z;x>0;x--)
  14.   for(y=100;y>0;y--);
  15. }

  16. keyscan()    //矩阵键盘扫描程序
  17. {
  18. P1=0xfe;
  19. if(P2!=0xff)
  20. {
  21.   delay(10);
  22.   if(P2!=0xff)
  23.   {
  24.    temp=P2;
  25.    switch(temp)
  26.    {
  27.     case 0x7f : num=31;break;
  28.     case 0xbf : num=30;break;
  29.     case 0xdf : num=29;break;
  30.     case 0xef : num=28;break;
  31.     case 0xf7 : num=27;break;
  32.     case 0xfb : num=26;break;
  33.         case 0xfd : num=25;break;
  34.         case 0xfe : num=24;break;
  35.    }
  36.    while(temp!=0xff)
  37.    {
  38.       temp=P2;
  39.     display();
  40.    }
  41.   }
  42. }
  43. delay(5);
  44. P1=0xfd;
  45. if(P2!=0xff)
  46. {
  47.   delay(10);
  48.   if(P2!=0xff)
  49.   {
  50.    temp=P2;
  51.    switch(temp)
  52.    {
  53.     case 0x7f : num=23;break;
  54.     case 0xbf : num=22;break;
  55.     case 0xdf : num=21;break;
  56.     case 0xef : num=20;break;
  57.     case 0xf7 : num=19;break;
  58.     case 0xfb : num=18;break;
  59.         case 0xfd : num=17;break;
  60.     case 0xfe : num=16;break;
  61.    }
  62.    while(temp!=0xff)
  63.    {
  64.       temp=P2;
  65.     display();
  66.    }
  67.   }
  68. }
  69. delay(5);
  70. P1=0xfb;
  71. if(P2!=0xff)
  72. {
  73.   delay(10);
  74.   if(P2!=0xff)
  75.   {
  76.    temp=P2;
  77.    switch(temp)
  78.    {
  79.     case 0x7f : num=15;break;
  80.     case 0xbf : num=14;break;
  81.     case 0xdf : num=13;break;
  82.     case 0xef : num=12;break;
  83.     case 0xf7 : num=11;break;
  84.     case 0xfb : num=10;break;
  85.         case 0xfd : num=9;break;
  86.     case 0xfe : num=8;break;  
  87.    }
  88.    while(temp!=0xff)
  89.    {
  90.       temp=P2;
  91.     display();
  92.    }
  93.   }
  94. }
  95. delay(5);
  96. P1=0xf7;
  97. if(P2!=0xff)
  98. {
  99.   delay(10);
  100.   if(P2!=0xff)
  101.   {
  102.    temp=P2;
  103.    switch(temp)
  104.    {
  105.     case 0x7f : num=7;break;
  106.     case 0xbf : num=6;break;
  107.     case 0xdf : num=5;break;
  108.     case 0xef : num=4;break;
  109.     case 0xf7 : num=3;break;
  110.     case 0xfb : num=2;break;
  111.         case 0xfd : num=1;break;
  112.     case 0xfe : num=0;break;
  113.    }
  114.    while(temp!=0xff)
  115.    {
  116.       temp=P2;
  117.     display();
  118.    }
  119.   }
  120. }
  121. delay(5);
  122. /*P0=0xde;
  123. if(P2!=0xff)
  124. {
  125.   delay(10);
  126.   if(P2!=0xff)
  127.   {
  128.    temp=P2;
  129.    switch(temp)
  130.    {
  131.     case 0xdf : num=12;break;
  132.     case 0xef : num=11;break;
  133.     case 0xf7 : num=10;break;
  134.     case 0xfb : num=9;break;
  135.     case 0xfd : num=8;break;
  136.     case 0xfe : num=7;break;
  137.    }
  138.    while(temp!=0xff)
  139.    {
  140.       temp=P2;
  141.     display();
  142.    }
  143.   }
  144. }
  145. delay(5);
  146. P0=0xbe;
  147. if(P2!=0xff)
  148. {
  149.   delay(10);
  150.   if(P2!=0xff)
  151.   {
  152.    temp=P2;
  153.    switch(temp)
  154.    {
  155.     case 0xdf : num=6;break;
  156.     case 0xef : num=5;break;
  157.     case 0xf7 : num=4;break;
  158.     case 0xfb : num=3;break;
  159.     case 0xfd : num=2;break;
  160.     case 0xfe : num=1;break;
  161.    }
  162.    while(temp!=0xff)
  163.    {
  164.       temp=P2;
  165.     display();
  166.    }
  167.   }
  168. }
  169. delay(5);*/

  170. return num;     
  171. }      

  172. void display()
  173. {
  174. //if( disn1==1)
  175. {P0=tab[n1];
  176. //delay(10);
  177. }

  178. ……………………

  179. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
1616.rar (37.11 KB, 下载次数: 42)




评分

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

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:218520 发表于 2017-7-10 15:38 | 只看该作者
学习学习!
回复

使用道具 举报

板凳
ID:19882 发表于 2020-1-13 14:13 来自手机 | 只看该作者
这个仿真软件并不大好
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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