找回密码
 立即注册

QQ登录

只需一步,快速开始

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

单片机数码管递减计数及流水灯程序

[复制链接]
跳转到指定楼层
楼主
ID:964116 发表于 2021-9-8 15:55 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
包含Proteus仿真图和源代码
单片机源程序如下:
  1. #include<reg52.h>
  2. #include<intrins.h>
  3. #define uint unsigned int
  4. #define uchar unsigned char

  5. uint count0, count1, count2, flag, flag1;         //三个定时时间 递减计时 流水灯计时 暂停计时   
  6. uint  inx1, inx2, inx3, inx4, inx5, inx6, temp;       //六根数码管的显示
  7. uchar flowlight;

  8. void delay(uint num);       //延时函数
  9. void display(uchar inx1, uchar inx2, uchar inx3, uchar inx4, uchar inx5, uchar inx6);       //数码管显示函数

  10. sbit Wela = P2^7;          //位选端口
  11. sbit Dula = P2^6;          //段选端口
  12. sbit beep = P2^3;          //蜂鸣器端口

  13. uchar code Table[] =                //段码数组
  14. {
  15.     0x3F,0x06,0x5B,0x4F,0x66,0x6D,  //共阴极段码 0 1 2 3 4 5
  16.     0x7D,0x07,0x7F,0x6F,0x77,0x7C,  //共阴极段码 6 7 8 9 A b
  17.     0x39,0x5E,0x79,0x71,0x73,0x3E,  //共阴极段码 C d E F P U
  18.     0x31,0x6E,0x76,0x38,0x00        //共阴极段码 T y H L 灭灯
  19. };  

  20. /************延时函数***************/
  21. void delay(uint num)        //延时 num ms
  22. {
  23.     uint x, y;
  24.     for(x=num; x>0; x--)
  25.     {
  26.         for(y=110; y>0; y--);
  27.     }
  28. }

  29. void main()
  30. {
  31.     temp = 765432 - 765000;
  32.     count0 = 0;
  33.     count1 = 0;
  34.     count2 = 0;
  35.     flag = 0;
  36.     flag1 = 0;

  37.     EA = 1;
  38.     EX0 = 1;
  39.     TMOD = 0x11;    //设置定时器T0,T1 为工作方式1
  40.     TH0 = (65536 - 50000) / 256;
  41.     TL0 = (65536 - 50000) % 256;
  42.     TH1 = (65536 - 50000) / 256;
  43.     TL1 = (65536 - 50000) % 256;
  44.     ET0 = 1;        //开定时器T0中断
  45.     ET1 = 1;        //开定时器T1中断
  46.     TR0 = 1;        //打开定时器T0
  47.     TR1 = 1;        //打开定时器T1
  48.    
  49.     P1 = 0xfe;      
  50.     flowlight = P1;
  51.     while(1)
  52.     {
  53.         beep = 0;
  54.         if(flag1 != 1)
  55.         {
  56.             display(7, 6, 5, inx4, inx5, inx6);
  57.             if(temp == 398)
  58.             {
  59.                 TR0 = 0;
  60.                 TR1 = 0;
  61.                 flag = 1;
  62.                 P1 = 0xff;
  63.                 TH0 = (65536 - 50000) / 256;
  64.                 TL0 = (65536 - 50000) % 256;
  65.                 TR0 = 1;
  66.                 count0 = 0;
  67.                 temp--;
  68.             }
  69.         }
  70.         else
  71.         {
  72.             display(20, 14, 21, 21, 0, 22);
  73.             TR0 = 0;
  74.         }   
  75.     }
  76. }

  77. /***********数码管显示函数************/
  78. void display(uchar inx1, uchar inx2, uchar inx3, uchar inx4, uchar inx5, uchar inx6)
  79. {
  80.     Wela = 1;
  81.     P0 = 0xfe;
  82.     Wela = 0;
  83.     Dula = 1;
  84.     P0 = Table[inx1];
  85.     Dula = 0;
  86.     delay(5);
  87.    
  88.     Wela = 1;
  89.     P0 = 0xfd;
  90.     Wela = 0;
  91.     Dula = 1;
  92.     P0 = Table[inx2];
  93.     Dula = 0;
  94.     delay(5);

  95.     Wela = 1;
  96.     P0 = 0xfb;
  97.     Wela = 0;
  98.     Dula = 1;
  99.     P0 = Table[inx3];
  100.     Dula = 0;
  101.     delay(5);

  102.     Wela = 1;
  103.     P0 = 0xf7;
  104.     Wela = 0;
  105.     Dula = 1;
  106.     P0 = Table[inx4];
  107.     Dula = 0;
  108.     delay(5);

  109.     Wela = 1;
  110.     P0 = 0xef;
  111.     Wela = 0;
  112.     Dula = 1;
  113.     P0 = Table[inx5];
  114.     Dula = 0;
  115.     delay(5);

  116.     Wela = 1;
  117.     P0 = 0xdf;
  118.     Wela = 0;
  119.     Dula = 1;
  120.     P0 = Table[inx6];
  121.     Dula = 0;
  122.     delay(5);

  123. }

  124. /*********定时器T0定时**********/
  125. void timer0() interrupt 1       //定时器T0定时50ms
  126. {
  127.     TH0 = (65536 - 50000) / 256;
  128.     TL0 = (65536 - 50000) % 256;
  129.     count0++;

  130.     if(flag != 1)
  131.     {
  132.         if(count0 == 10)        //流水灯延时 500ms 流动
  133.         {   
  134.             beep = 1;
  135.             flowlight = _crol_(flowlight, 1);
  136.             P1 = flowlight;
  137.             count0 = 0;
  138.         }
  139.     }
  140.     else
  141.     {
  142.         if(count0 % 4 == 0)
  143.         {
  144.             P1 = ~P1;
  145.             if(count0 == 60)
  146.             {
  147.                 flag1 = 1;
  148.             }
  149.         }
  150.     }
  151. }

  152. /*********定时器T1中断函数50ms*******/
  153. void timer1() interrupt 3       //定时器T1定时50ms
  154. {   
  155.     TH1 = (65536 - 50000) / 256;
  156.     TL1 = (65536 - 50000) % 256;
  157.     count1++;

  158.     if(count1 == 2)     //数码管以100ms递减
  159.     {
  160.         temp--;
  161.         inx4 = temp / 100;
  162.         inx5 = temp % 100 / 10;
  163.         inx6 = temp % 10;
  164.         count1 = 0;
  165.     }
  166. }
复制代码
新手程序,望大佬放过
所有资料51hei附件下载:
Works.rar (95.66 KB, 下载次数: 9)

评分

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

查看全部评分

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

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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