【51单片机学习笔记&心得记录】-数码管篇

  • 数码管段选函数


//数码管段码表--段选
unsigned char NixieTable[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};

/*
  0x3F  0011 1111-> 对应数字‘0’  
  0x06  0000 0110-> 对应数字‘1’
  0x5B  0101 1011-> 对应数字‘2’
  0x4F  0100 1111-> 对应数字‘3’
  0x66  0110 0110-> 对应数字‘4’
  0x6D  0110 1101-> 对应数字‘5’
  0x7D  0111 1101-> 对应数字‘6’
  0x07  0000 0111-> 对应数字‘7’
  0x7F  0111 1111-> 对应数字‘8’
  0x6F  0110 1111-> 对应数字‘9’
  0x77  0111 0111-> 对应数字‘A’
  0x7C  0111 1100-> 对应数字‘B’
  0x39  0011 1001-> 对应数字‘C’
  0x5E  0101 1110-> 对应数字‘D’
  0x79  0111 1001-> 对应数字‘E’
  0x71  0111 0001-> 对应数字‘F’
*/
  • 数码管位选函数


//数码管显示子函数--位选
void Nixie(unsigned char Location,Number)
{
    switch(Location)        //位码输出
    {
        case 1:P2_4=1;P2_3=1;P2_2=1;break; //第八位 7 - 0 111
        case 2:P2_4=1;P2_3=1;P2_2=0;break; //第七位 6 - 0 110
        case 3:P2_4=1;P2_3=0;P2_2=1;break; //第六位 5 - 0 101
        case 4:P2_4=1;P2_3=0;P2_2=0;break; //第五位 4 - 0 100
        case 5:P2_4=0;P2_3=1;P2_2=1;break; //第四位 3 - 0 011
        case 6:P2_4=0;P2_3=1;P2_2=0;break; //第三位 2 - 0 010
        case 7:P2_4=0;P2_3=0;P2_2=1;break; //第二位 1 - 0 001
        case 8:P2_4=0;P2_3=0;P2_2=0;break; //第一位 0 - 0 000
    }
    P0=NixieTable[Number];            //段码输出
    Delay(1);                        //显示一段时间
    P0=0x00;                         //段码清0,消影
}
  • 延时子函数


//延时子函数
void Delay(unsigned int xms)
{
    unsigned char i, j;
    while(xms--)
    {
        i = 2;
        j = 239;
        do
        {
            while (--j);
        } while (--i);
    }
}
  • 在数码管上显示数字


#include <REGX52.H>
unsigned char NixieTable[]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F};
void Delay(unsigned int xms)
{
    unsigned char i, j;
    while(xms--)
    {
        i = 2;
        j = 239;
        do
        {
            while (--j);
        } while (--i);
    }
}
void Nixie(unsigned char Location,Number)
{
    switch(Location)        //位码输出
    {
        case 1:P2_4=1;P2_3=1;P2_2=1;break; //第八位 7 - 0 111
        case 2:P2_4=1;P2_3=1;P2_2=0;break; //第七位 6 - 0 110
        case 3:P2_4=1;P2_3=0;P2_2=1;break; //第六位 5 - 0 101
        case 4:P2_4=1;P2_3=0;P2_2=0;break; //第五位 4 - 0 100
        case 5:P2_4=0;P2_3=1;P2_2=1;break; //第四位 3 - 0 011
        case 6:P2_4=0;P2_3=1;P2_2=0;break; //第三位 2 - 0 010
        case 7:P2_4=0;P2_3=0;P2_2=1;break; //第二位 1 - 0 001
        case 8:P2_4=0;P2_3=0;P2_2=0;break; //第一位 0 - 0 000
    }
    P0=NixieTable[Number];            //段码输出
    Delay(1);                        //显示一段时间
    P0=0x00;                         //段码清0,消影
}
void main()
{
    while(1)
    {
        Nixie(1,1);    //在数码管的第1位置显示1
        Nixie(2,2);    //在数码管的第2位置显示2
        Nixie(3,3);    //在数码管的第3位置显示3
        Nixie(4,4);    //在数码管的第4位置显示4
        Nixie(5,5);    //在数码管的第5位置显示5
        Nixie(6,6);    //在数码管的第6位置显示6
    }
}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

庆庆知识库

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值