找回密码
 立即注册

QQ登录

只需一步,快速开始

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

单片机串口发送实时时钟的电路+程序设计

[复制链接]
跳转到指定楼层
楼主

这个程序实现的是 流水灯先流水两次,数码管全亮全灭一次,显示hello,然后显示时钟(我设置初值为23-58-40)开始走,当时间为零点零分,闹钟灯会亮,打开串口发送助手,会发送实时时,串口zip是protues图,发送zip是keil文件

单片机源程序如下:
  1. #include <reg51.h>
  2. #include<intrins.h>
  3. //声明全局函数//
  4. void UsartConfiguration();
  5. unsigned char p;
  6. #define uint unsigned int
  7. #define uchar unsigned char
  8. uchar code duan[]={0x76,0x79,0x38,0x38,0x3f};  //显示hello段选
  9. uchar wei[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};
  10. unsigned char code tab[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};           //数字0-9
  11. int num,second,minute,hour,a;   
  12. int i,j,k,m,n,s,t;
  13. unsigned char PuZh[16];/数组比较大,一个汉字占两个字节
  14. unsigned char src[16] = {0,1,2,3,4,5,6,7,8,9};
  15. sbit stop=P3^5;
  16. sbit clear=P3^6;
  17. sbit start=P3^7;
  18. sbit hourjia=P2^0;
  19. sbit hourjian=P2^1;
  20. sbit minutejia=P2^2;
  21. sbit minutejian=P2^3;
  22. sbit clock=P2^4;    //设置闹钟
  23. sbit ledground=P2^5;
  24. void mDelay(unsigned int mDelay)    //延迟函数
  25. { unsigned int i;
  26. for(;mDelay>0;mDelay--)
  27. { for(i=0;i<124;i++)
  28. {;}
  29. }
  30. }

  31. void liushuideng()     //流水灯
  32. {        
  33.                 int k=2;      //流水灯流水两次
  34.   while(k--)
  35.    {     int i;
  36.             ledground=0;   //设置低电平
  37.       P0=0x01;//第一个灯亮
  38.       mDelay(500);
  39.       for(i=0;i<7;i++)           
  40.         {
  41.                P0=P0<<1;  
  42.          mDelay(100);
  43.                     }
  44.        ledground=1;//设置高电平,关掉流水灯
  45.    }
  46. }

  47. void shumaguan_init()    //数码管初始化
  48. {         
  49.         P0=0xff;//段选码     全亮
  50.         P1=0x00;//位选码
  51.         mDelay(900);
  52.         P0=~0xff;// 取反,全灭
  53.         P1=0x00;
  54.   mDelay(900);
  55. }


  56. void shumaguan()   //数码管初始化
  57. {
  58.     uchar n;
  59.     int z=50;        
  60.     while(z--)
  61.                 {
  62.     for(n=0;n<5;n++)
  63.        {
  64.                         P1=wei[n];
  65.                         P0=duan[n];
  66.       mDelay(1);
  67.        }
  68.                  }
  69. }


  70. void UsartConfiguration()
  71. {
  72.         SCON=0X50;                        //设置为工作方式1
  73.         TMOD=0X21;                        //设置计数器1为方式2 ,定时器0为方式1
  74.         PCON=0X80;                        //波特率加倍 SMOD=1
  75.         TH1=0XF3;                    //定时器初始值设置 TH1=256-2^SMOD*f0sc/(波特率*32*12)
  76.         TL1=0XF3;
  77.         TR1=1;                                            //打开定时器
  78. }


  79. void Interrupt_0()   interrupt 1        
  80. {        TH0=-50000/256;
  81.         TL0=-50000%256;
  82.         num++;
  83.         
  84.         if(num%5==0)
  85.         {        if(minutejia==0)
  86.           {minute++;mDelay(2);if(minute>59) minute=0;}
  87.     if(minutejian==0)
  88.                  { minute--;mDelay(2);if(minute<0) minute=59;}

  89.                 if(hourjia==0)
  90.                 {hour++;mDelay(2);if(hour>23) hour=0;}
  91.                 if(hourjian==0)
  92.           {hour--;mDelay(2);if(hour<0) hour=23;}
  93.         }
  94.         if(num==20)
  95. {        num=0;
  96.     second=second+1;
  97.           if(second>59)
  98.           {second=0;minute=minute+1;}

  99.                 if(minute>59)
  100.                 {minute=0;hour=hour+1;}
  101.                 if(hour>23)
  102.            hour=0;
  103. }               
  104.                  
  105.                
  106. }


  107. void main()
  108. {
  109.          clock=0;
  110.   liushuideng();
  111. shumaguan_init();
  112.          shumaguan();
  113.                 a=-50000;                         //a=(-t*f)/12    设置=50ms   a=[(-50*10^-3)*12*10^6]/12=-50000
  114.         TH0=-50000/256;   //高八位
  115.         TL0=-50000%256;   //低八位
  116.         EA=1;             //总开关
  117.         ET0=1;            //打开定时器0中断
  118.         TR0=1;            //打开定时器0
  119. hour=23;            //设置时钟初值
  120. minute=58;
  121. second=40;   
  122. UsartConfiguration();
  123. while(1)
  124. {
  125.         
  126.                
  127.                 for(p=0; p<16; p++)
  128.                 {
  129.                         SBUF = PuZh[p];   //将要发送的数据放入到发送寄存器
  130.                         while(!TI);                  //等待发送数据完成        查询法
  131.                         TI=0;                          //清除发送标志位
  132.                 }
  133.                 mDelay(3);                  //延时一下再发
  134.         if(stop==0)  {  TR0=0;}    //暂停
  135.                 if(clear==0)             //清零
  136.                 {
  137.                         
  138.                         hour=0;
  139.                         second=0;
  140.                         minute=0;
  141.                         TR0=0;
  142.     }
  143.                 if(start==0)        //启动
  144.                 {TR0=1;}
  145.         

  146.             j=second%10;               
  147.             k=second/10;        
  148.                   m=minute%10;               
  149.             n=minute/10;        
  150.                   s=hour%10;               
  151.             t=hour/10;        
  152. PuZh[0] = src[hour/10]+0x30;
  153. PuZh[1] = src[hour% 10]+0x30;
  154. PuZh[2] = 0x2D;
  155. PuZh[3] = src[minute/ 10]+0x30;
  156. PuZh[4] = src[minute% 10]+0x30;
  157.                         
  158.   if(hour==0&&minute==0)      //定闹钟,当时间为零点零分,闹钟灯亮起
  159.   clock=1;
  160.   else  
  161.   clock=0;
  162.                
  163.                         P1=0x7f;  //0111 1111
  164.                   P0=tab[j];
  165.                   mDelay(1);
  166.       P1=0xbf;  //1011 1111
  167.                         P0=tab[k];
  168.       mDelay(1);
  169.         
  170.                         P1=0xdb;  //1101 1111
  171.                         P0=0x40;
  172.                         mDelay(1);
  173.                         
  174.                     
  175.                                 P1=0xef;  //1110 1111
  176.                                 P0=tab[m];
  177.                                 mDelay(1);
  178.                                 P1=0xf7;   //1111 0111
  179.                                 P0=tab[n];
  180.                                 mDelay(1);
  181.                                                 
  182.          
  183.                                 
  184.                                 P1=0xfd;  //1111 1101
  185.                                 P0=tab[s];
  186.                                 mDelay(1);
  187.                                 P1=0xfe;  //1111 1110
  188.                                 P0=tab[t];
  189.                                 mDelay(1);
  190.                 }
  191. }
复制代码

串口.zip

22.76 KB, 下载次数: 17, 下载积分: 黑币 -5

发送.zip

48.46 KB, 下载次数: 16, 下载积分: 黑币 -5

评分

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

查看全部评分

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

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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