找回密码
 立即注册

QQ登录

只需一步,快速开始

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

51单片机数码管和点阵分时显示源程序

[复制链接]
跳转到指定楼层
楼主
这几天做了个学长交代的任务,让数码管显示20190520,点阵显示“电”字,
并且要用按键控制点阵的移动,想了几天,终于想出来了,和大家分享一下,
希望对大家有帮助,话不多说,上图,


新建文件夹 (3).rar (1.24 MB, 下载次数: 25) 代码如下
我用的板子的原理图在附件中

单片机源程序如下:
  1. #include <reg52.h>
  2. #include <intrins.h>
  3. sbit k1=P3^4;
  4. sbit k2=P3^5;
  5. sbit k3=P3^6;
  6. sbit k4=P3^7;
  7. sbit duan=P1^7;
  8. sbit wei=P1^6;
  9. sbit SER=P1^0;  //数据输入端
  10. sbit SH=P1^2;  //收到上升沿锁存数据
  11. sbit ST=P1^1; //收到上升沿,输出数据
  12. int z1[]={0xef,0x83,0xab,0x83,0xab,0x83,0x6f,0x0f};//点阵横向接收的数据
  13. int x[]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80}; //点阵纵向接收的数据</div><div>  int j=0;
  14.   void delayms(int i)  //延时函数
  15. {
  16. int j,k;
  17. for(j=0;j<i;j++)
  18. for(k=0;k<40;k++);
  19. }</div><div> void shu(void)  //数码管显示20190520
  20. {
  21. int i=0;
  22. char d[]={0x3f,0x5b,0x6d,0x3f,0x6f,0x06,0x3f,0x5b};
  23. char w[]={0x7f,0xbf,0xdf,0xef,0xf7,0xfb,0xfd,0xfe};
  24. while(1)
  25. {
  26.   for(i=0;i<8;i++)
  27.   {
  28.    duan=1;   //   *****
  29.    P0=0x00;   //  消
  30.   // delayms(1);//  ****
  31.    duan=0;  //    影
  32.    P0=0xff; //消影            
  33.    wei=1;
  34.    P0=w[i];
  35.    wei=0;
  36.    P0=0x00;    //消影
  37.   // delayms(1);
  38.    duan=1;
  39.    P0=d[i];
  40.    duan=0;
  41.    delayms(1);
  42.    P0=0x00;
  43.       //消影
  44.    
  45.   }
  46.   wei=1;   //***********
  47.   P0=0xff;  //*****
  48.   wei=0;    //解决点阵数码管同时显示有一个数更亮
  49.   duan=1;    //
  50.   P0=0x00;   //
  51.   duan=0;    //
  52.   break;
  53. }
  54. }
  55. void qidongdianzhen(int i)
  56. {
  57.   int Bit;
  58. SH=1;
  59. for(Bit=0;Bit<8;Bit++)
  60. {
  61.   
  62.   if(i&0x80)
  63.    SER=1;
  64.   else
  65.    SER=0;
  66.   i=i<<1;
  67.   SH=0;
  68.   _nop_();_nop_();
  69.   SH=1;

  70. }
  71.   ST=0;
  72.   _nop_();
  73.   _nop_();
  74.   ST=1;</div><div> }
  75. void shangyi()
  76. {
  77.    int temp,i;
  78.   temp=z1[0];
  79.   for(i=0;i<7;i++)
  80.   {
  81.    z1[i]=z1[i+1] ;    //调换数组内元素的顺序来改变点阵显示
  82.   }
  83.   z1[7]=temp;
  84. }
  85. void xiayi()
  86. {
  87.   int temp,i;
  88.   temp=z1[7];
  89. for(i=0;i<7;i++)
  90. {
  91.    z1[7-i]=z1[6-i];    //调换数组内元素的顺序来改变点阵显示
  92. }
  93. z1[0]=temp;</div><div>
  94. }
  95. void zuoyi()
  96. {
  97.   int i;
  98. for(i=0;i<8;i++)
  99. {
  100.   z1[i]=_cror_(z1[i],1); //将数组内每一个数的值按位右移
  101. } }
  102. void youyi()
  103. {
  104.   int i;
  105. for(i=0;i<8;i++)
  106. {
  107.   z1[i]=_crol_(z1[i],1); //将数组内每一个数的值按位左移
  108. }
  109. }
  110. void dian()
  111. {
  112.   int i;
  113.   for(i=0;i<8;i++)
  114. {
  115.   P0=z1[i];
  116.   qidongdianzhen(x[i]);
  117.   delayms(1);    //改变亮和灭的比列来提高亮度
  118.   qidongdianzhen(0x00); //点阵消影
  119.   
  120. }
  121. }


  122. void main()
  123. {
  124.      int i; //先关闭数码管
  125.      duan=1;
  126.     P0=0x00;
  127.     duan=0;
  128.     wei=1;
  129.     P0=0xff;
  130.     wei=0;
  131.     while(1)
  132.     {
  133.       shu();
  134.     if (k3==0)
  135.     {
  136.       j=0;
  137.      shangyi();
  138.      while(j<10)   //主要起延时作用
  139.      {
  140.       for(i=0;i<8;i++)
  141.        {
  142.         P0=z1[i];
  143.         qidongdianzhen(x[i]);
  144.         delayms(1); //改变亮和灭的比列来提高亮度
  145.         qidongdianzhen(0x00);
  146.       
  147.       
  148.        }
  149.        shu();
  150.        j++;
  151.      }
  152.    
  153.     }
  154.     if (k4==0)
  155.     {
  156.       j=0;
  157.      xiayi();
  158.      while(j<10)  //主要起延时作用
  159.      {
  160.       for(i=0;i<8;i++)
  161.        {
  162.         P0=z1[i];
  163.         qidongdianzhen(x[i]);
  164.          delayms(1); //改变亮和灭的比列来提高亮度
  165.         qidongdianzhen(0x00);
  166.       
  167.       
  168.        }
  169.        shu();
  170.        j++;
  171.      }
  172.    
  173.     }
  174.      if (k1==0)
  175.     {
  176.       j=0;
  177.      zuoyi();
  178.      while(j<10)   //主要起延时作用
  179.      {
  180.       for(i=0;i<8;i++)
  181.        {
  182.         P0=z1[i];
  183.         qidongdianzhen(x[i]);
  184.          delayms(1); //改变亮和灭的比列来提高亮度
  185.         qidongdianzhen(0x00);
  186.       
  187.       
  188.        }
  189.        shu();
  190.        j++;
  191.      }
  192.    
  193.     }
  194.      if (k2==0)
  195.     {
  196.       j=0;
  197.      youyi();
  198.      while(j<10)   //主要起延时作用
  199.      {
  200.       for(i=0;i<8;i++)
  201.        {
  202.         P0=z1[i];
  203.         qidongdianzhen(x[i]);
  204.          delayms(1); //改变亮和灭的比列来提高亮度
  205.         qidongdianzhen(0x00);
  206.       
  207.       
  208.        }
  209.        shu();
  210.        j++;
  211.      }
  212.    
  213.     }    dian();  }

  214. }

复制代码

评分

参与人数 2黑币 +105 收起 理由
Jeff_BlindCat + 5 赞一个!+5分再接再厉。
admin + 100 共享资料的黑币奖励!

查看全部评分

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

使用道具 举报

沙发
ID:588173 发表于 2019-7-26 20:21 | 只看该作者
可能我的注释格式有点不对,导致显示不对,所以可以把注释删了用
回复

使用道具 举报

板凳
ID:588173 发表于 2019-7-27 16:09 | 只看该作者
改了几次终于没有乱码了,开心
回复

使用道具 举报

地板
ID:328014 发表于 2019-7-28 00:49 | 只看该作者
很不错的思路
回复

使用道具 举报

5#
ID:805457 发表于 2020-7-19 15:39 | 只看该作者
为什么我的代码写出来没有效果
回复

使用道具 举报

6#
ID:495287 发表于 2020-7-19 20:43 | 只看该作者
硬件互联是基础,
思路创新无界属,
范例引得共鸣意,
你追我赶新征途。
回复

使用道具 举报

7#
ID:856401 发表于 2021-3-27 07:58 来自手机 | 只看该作者
一路下来全是delay,没有工程实用价值
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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