zoukankan      html  css  js  c++  java
  • 2017.11.25 中断与数码管动态显示

    数组基本概念:

      1、具有相同的数据类型

      2、具有相同的名字

      3、在存储器中的存储是连续的

    注意:区分数组下标和数组元素个数的概念,数组下标可以是常量或变量,数组赋值只能在初始化进行,程序只能进行单个元素赋值。

    switch()

    {

      case 常量表达式1: 语句1;break;

      default 常量表达式2:语句2;break;

    }

    switch 与if 的区别是,switch的每条语句都会执行,而 if 有一条符合,则跳过。

    动态显示:

      多个数码管显示数字的时候,我们实际上是轮流点亮数码管,利用人眼的视觉暂留现象(余晖效应)。

    假如有6个数码管,就有6个切换周期。10ms要重复刷新一个数码管,才能让人眼保持余晖效应。

    在编写程序,可以画个流程图,帮助编程。

    #include<reg52.h>

    sbit ADDR0 = P1^0;
    sbit ADDR1 = P1^1;
    sbit ADDR2 = P1^2;
    sbit ADDR3 = P1^3;
    sbit ENLED = P1^4;

    unsigned char code LedChar[]={
     0xC0, 0xF9, 0xA4, 0xB0, 0x99, 0x92, 0x82, 0xF8,
     0x80, 0x90, 0x88, 0x83, 0xC6, 0xA1, 0x86, 0x8E
     };
    unsigned char LedBuff[6]={
     0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF
     };

    void main()
    {
     unsigned int cnt = 0;
     unsigned long sec = 0;
     unsigned char i = 0;

     ENLED = 0;
     ADDR3 = 1;
     TMOD = 0x01;
     TH0 = 0xFC;
     TL0 = 0x67;
     TR0 = 1;

     while(1)
     {
      if(TF0 ==1)
      {
       TF0 = 0;
       TH0 = 0xFC;
       TL0 = 0x67;
       cnt++;
       if(cnt >= 1000)  
       {
        cnt = 0;
        sec++;
        LedBuff[0] = LedChar[sec%10];
        LedBuff[1] = LedChar[sec/10%10];
        LedBuff[2] = LedChar[sec/100%10];
        LedBuff[3] = LedChar[sec/1000%10];
        LedBuff[4] = LedChar[sec/10000%10];
        LedBuff[5] = LedChar[sec/100000%10];
       }

       if(i == 0)
       {ADDR2=0; ADDR1=0; ADDR0=0; i++; P0=LedBuff[0];}
       else if(i == 1)
       {ADDR2=0; ADDR1=0; ADDR0=1; i++; P0=LedBuff[1];}
       else if(i == 2)
       {ADDR2=0; ADDR1=1; ADDR0=0; i++; P0=LedBuff[2];}
       else if(i == 3)
       {ADDR2=0; ADDR1=1; ADDR0=1; i++; P0=LedBuff[3];}
       else if(i == 4)
       {ADDR2=1; ADDR1=0; ADDR0=0; i++; P0=LedBuff[4];}
       else if(i == 5)
       {ADDR2=1; ADDR1=0; ADDR0=1; i=0; P0=LedBuff[5];}

      }
     }
    }

        }

    }

      

    }

  • 相关阅读:
    C#微信开发
    3-4:字符串方法
    2-4-1 元组
    2-3-3 列表方法
    2-2-3:序列(字符串)乘法(p32)
    3-3字符串格式化(p47)
    2-2:分片
    2-1:Print date(p28)
    old.2.三次登录机会
    old.2.sum(1-2+3-4+...+99)
  • 原文地址:https://www.cnblogs.com/wongsh/p/7896301.html
Copyright © 2011-2022 走看看