找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4079|回复: 1
收起左侧

单片机驱动8位动态数码管仿真与源程序

[复制链接]
ID:399107 发表于 2018-9-26 10:22 | 显示全部楼层 |阅读模式
8位动态数码管仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
0.png 0.png

单片机源程序如下:
  1. #include<reg51.h>
  2. #include<intrins.h>
  3. #include<ctype.h>
  4. #include<string.h>
  5. #include<math.h>
  6. #include<stdio.h>
  7. #define uchar unsigned char
  8. #define uint unsigned int
  9. sbit dula=P2^0;
  10. sbit wela=P2^1;
  11. uint time=0;
  12. uint hh=23;
  13. uint mm=59;
  14. uint ss=49;
  15. uchar code table[]={
  16. 0x3f,0x06,0x5b,0x4f,
  17. 0x66,0x6d,0x7d,0x07,
  18. 0x7f,0x6f,0x77,0x7c,
  19. 0x39,0x5e,0x79,0x71
  20. };
  21. void delayms(uint t)
  22. {
  23.         uint i,j;
  24.         for(i=t;i>0;i--)
  25.                 for(j=110;j>0;j--)
  26.                         ;
  27. }
  28. void print_string_LED(char* str)
  29. {
  30.         uint len=strlen(str);
  31.         uint index=strpos(str,'.');
  32.         uchar t=0x7f;
  33.         uint i=0;
  34.         for(i=0;i<len;i++)
  35.         {
  36.                 if(isdigit(str[len-i-1])==1)
  37.                 {
  38.                         P0=0xff;
  39.                         wela=1;
  40.                         P0=t;
  41.                         wela=0;

  42.                         P0=0x00;
  43.                         dula=1;
  44.                         if(i==len-index)
  45.                                 P0=table[str[len-i-1]-'0']|0x80;
  46.                         else
  47.                                 P0=table[str[len-i-1]-'0'];
  48.                         dula=0;
  49.                 }
  50.                 else if(isalpha(str[len-i-1])==1)
  51.                 {
  52.                         P0=0xff;
  53.                         wela=1;
  54.                         P0=t;
  55.                         wela=0;

  56.                         P0=0x00;
  57.                         dula=1;
  58.                         str[len-i-1]=tolower(str[len-i-1]);
  59.                         if(i==len-index)
  60.                                 P0=table[str[len-i-1]-'a'+10]|0x80;
  61.                         else
  62.                                 P0=table[str[len-i-1]-'a'+10];
  63.                         dula=0;
  64.                 }
  65.                 else if(str[len-i-1]=='-')
  66.                 {
  67.                         P0=0xff;
  68.                         wela=1;
  69.                         P0=t;
  70.                         wela=0;

  71.                         P0=0x00;
  72.                         dula=1;
  73.                         P0=0x40;
  74.                         dula=0;
  75.                 }
  76.                 else
  77.                         continue;
  78.                 t=_cror_(t,1);
  79.                 delayms(2);        
  80.         }
  81. }
  82. void main()
  83. {
  84.         char str[9];
  85.         char str_h[3];
  86.         char str_m[3];
  87.         char str_s[3];
  88.         uchar i,j,k;
  89.         TMOD=0x01;//计时器0以工作方式1计时
  90.         EA=1;//打开全局中断允许
  91.         ET0=1;//打开定时器0中断允许位
  92.         TR0=1;//启动定时器0
  93.         TH0=55535/256;
  94.         TL0=55535%256;
  95.         while(1)
  96.         {
  97.                 if(ss==60)
  98.                 {
  99.                         ss=0;
  100.                         mm++;
  101.                 }
  102.                 if(mm==60)
  103.                 {
  104.                         mm=0;
  105.                         hh=(++hh)%24;
  106.                 }
  107.                 sprintf(str_h,"%u",hh);
  108.                 sprintf(str_m,"%u",mm);
  109.                 sprintf(str_s,"%u",ss);
  110.                 i=0;
  111.                
  112.                 //if(hh!=0)
  113.                 {
  114.                         for(i=0;str_h[i]!='\0';i++)
  115.                                 str[i]=str_h[i];
  116.                         str[i++]='-';
  117.                 }
  118.                 //if(mm!=0)
  119.                 {
  120.                         for(j=0;str_m[j]!='\0';j++)
  121.                                 str[i++]=str_m[j];
  122.                         str[i++]='-';
  123.                 }
  124.                 for(k=0;str_s[k]!='\0';k++)
  125.                         str[i++]=str_s[k];
  126.                 str[i]='\0';  
  127.                 print_string_LED(str);
  128.         }
  129. }
  130. void ET_T0() interrupt 1
  131. {
  132.         TH0=55535/256;
  133.         TL0=55535%256;
  134.         time++;
  135.         if(time==100)
  136.         {
  137.                 ss++;
  138.                 time=0;
  139.         }
  140. }
复制代码

所有资料51hei提供下载:
八位数码管.zip (21.89 KB, 下载次数: 78)

评分

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

查看全部评分

回复

使用道具 举报

ID:755823 发表于 2020-5-19 16:43 | 显示全部楼层
为下载了不能用?
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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