数码管使用

数码管(Segment Displays)由多个发光二极管封装在一起组成“8”字型的器件,引线已在内部连接完成,只需引出它们的各个笔划,公共电极。数码管实际上是由七个发光管组成8字形构成的,加上小数点就是8个。这些段分别由字母a,b,c,d,e,f,g,dp来表示。

数码管原理图:

数码管共阴极接法:

数码管共阳极接法:

数码管中有位选和段选,位选就是选择哪个数码管,段选就是被选择的数码管要显示什么数字!

根据数码管的段选,可以总结出数码管的显示数据表:

 

符号不显示0123456789ABCDEF.
编码0x000x3F0x060x5B0x4F0x660x6D0x7D0x070x7F0x6F0x770x7C0x390x5E0x790x710x80

 





    #include "reg52.h"           //此文件中定义了单片机的一些特殊功能寄存器  
      
    typedef unsigned int u16;     //对数据类型进行声明定义  
    typedef unsigned char u8;  
      
    sbit LSA=P2^2;  
    sbit LSB=P2^3;  
    sbit LSC=P2^4;  
      
    u8 code smgduan[17]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,  
                        0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};//显示0~F的值  
      
    /*******************************************************************************  
    * 函 数 名         : delay  
    * 函数功能         : 延时函数,i=1时,大约延时10us  
    *******************************************************************************/  
    void delay(u16 i)  
    {  
        while(i--);   
    }  
      
    /*******************************************************************************  
    * 函 数 名         : DigDisplay  
    * 函数功能         : 数码管动态扫描函数,循环扫描8个数码管显示  
    *******************************************************************************/  
    void DigDisplay()  
    {  
        u8 i;  
        for(i=0;i<8;i++)  
        {  
            switch(i)    //位选,选择点亮的数码管,  
            {  
                case(0):  
                    LSA=0;LSB=0;LSC=0; break;//显示第0位  
                case(1):  
                    LSA=1;LSB=0;LSC=0; break;//显示第1位  
                case(2):  
                    LSA=0;LSB=1;LSC=0; break;//显示第2位  
                case(3):  
                    LSA=1;LSB=1;LSC=0; break;//显示第3位  
                case(4):  
                    LSA=0;LSB=0;LSC=1; break;//显示第4位  
                case(5):  
                    LSA=1;LSB=0;LSC=1; break;//显示第5位  
                case(6):  
                    LSA=0;LSB=1;LSC=1; break;//显示第6位  
                case(7):  
                    LSA=1;LSB=1;LSC=1; break;//显示第7位      
            }  
            P0=smgduan[i];//发送段码  
            delay(100); //间隔一段时间扫描    
            P0=0x00;//消隐  
        }  
    }  
      
    /*******************************************************************************  
    * 函 数 名       : main  
    * 函数功能       : 主函数  
    * 输    入       : 无  
    * 输    出         : 无  
    *******************************************************************************/  
    void main()  
    {     
        while(1)  
        {     
            DigDisplay();  //数码管显示函数      
        }         
    }  

LED数码管是单片机外围接口设备中常用的显示设备,有七段管和米字管两种,实验室中常用的是七段管。其工作方式有两种:共阴极和共阳极。所谓共阴极是把LED的com端都接地,而共阳极就是把com端都接高电平。其驱动显示方式也有两种:静态显示和动态显示。

静态显示中每个数码管占用单片机的一个八位口I/O口,工作时点亮的段常亮。于该种方式而言,硬件电路简单,编程简单,但是浪费单片机的I/O口。下面简单演示一下该种驱动方式。

P2口接一个数码管,数码管显示的数字每秒钟自动加一,加到9后清0,一直循环,本实验中数码管采用共阴极接法。

实验原理图如下:


实验程序如下:

    #include<reg52.h>  
    #define uchar unsigned char;  
    #define uint unsigned int;  
    uchar code table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};//共阴极数码管数据表  
    uchar a,i,j,z;  
      
    void delay(z)   //延时子函数  
    {  
       for(j=z;j>0;j--)  
          for(i=110;i>0;i--);  
    }  
      
    void main()   //主函数  
    {  
      while(1)  
        {  
    for(a=0;a<10;a++)//从0到9,共10次循环     
         {  
         P2=table[a];   //P2口从数据表中取数据  
         delay(1000); //延时大约1s   
          }        
        }  
    }  


试验结果如下:


  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
针对你提到的hc32l13x芯片及ch455h 4x5矩阵键盘和数码管驱动,我可以给你提供一些基本的实现示例,但需要注意的是,由于具体的硬件连接和功能实现可能会因为不同的应用场景而有所不同,因此以下仅供参考。 首先,我们来看一下hc32l13x芯片的GPIO和I2C的使用方法。 GPIO的使用方法: 1.引脚配置 hc32l13x芯片的GPIO可以通过库函数来进行配置,例如下面的代码可以将PC5配置为输出模式(推挽输出): ``` GPIO_SetFunc(GPIOC, GPIO_PIN_5, GPIO_FUNC_0_GPIO); GPIO_SetDir(GPIOC, GPIO_PIN_5, GPIO_DIR_OUT); GPIO_SetOutputVal(GPIOC, GPIO_PIN_5, 1); ``` 2.读写GPIO 读写GPIO的方法也很简单,可以通过库函数来实现,例如下面的代码可以读取PA3引脚的电平值: ``` uint8_t u8PinVal = GPIO_ReadInputPortBit(GPIOA, GPIO_PIN_3); ``` I2C的使用方法: 1.I2C初始化 hc32l13x芯片的I2C可以通过库函数来进行初始化配置,例如下面的代码可以将I2C1配置为400KHz的速率: ``` stc_i2c_init_t stcI2cInit; stcI2cInit.u32Baudrate = 400000UL; stcI2cInit.bMaster = TRUE; stcI2cInit.u8SlaveAddr = 0x00; stcI2cInit.bWaitSelection = FALSE; stcI2cInit.u8I2cClkDiv = I2C_CLK_DIV4; stcI2cInit.u8I2cSclTime = I2C_SCL_TIME; I2C_Init(I2C1, &stcI2cInit); ``` 2.I2C发送数据 I2C发送数据的方法也很简单,可以通过库函数来实现,例如下面的代码可以向设备地址为0x50的设备发送一个字节的数据0x01: ``` uint8_t u8DataBuf[] = {0x01}; I2C_SendData(I2C1, 0x50, u8DataBuf, 1); ``` 3.I2C接收数据 I2C接收数据的方法也很简单,可以通过库函数来实现,例如下面的代码可以从设备地址为0x50的设备接收一个字节的数据到u8DataBuf中: ``` uint8_t u8DataBuf[1]; I2C_ReceiveData(I2C1, 0x50, u8DataBuf, 1); ``` 接下来,我们来看一下如何使用hc32l13x芯片和ch455h 4x5矩阵键盘和数码管驱动。 1.矩阵键盘的实现 首先,让我们来看一下ch455h 4x5矩阵键盘的引脚定义: ``` KEY_ROW0 - PC0 KEY_ROW1 - PC1 KEY_ROW2 - PC2 KEY_ROW3 - PC3 KEY_COL0 - PC4 KEY_COL1 - PC5 KEY_COL2 - PC6 KEY_COL3 - PC7 KEY_COL4 - PA2 ``` 可以看到,矩阵键盘的行和列的引脚都是通过GPIO进行控制的,因此我们可以通过配置GPIO的方式来实现矩阵键盘的扫描。 以4x5矩阵键盘为例,我们可以通过依次将每一列的引脚输出为低电平,然后读取每一行的引脚的电平值来判断是否有按键按下。 具体实现代码如下: ``` #define KEY_ROW0 GPIO_PIN_0 #define KEY_ROW1 GPIO_PIN_1 #define KEY_ROW2 GPIO_PIN_2 #define KEY_ROW3 GPIO_PIN_3 #define KEY_COL0 GPIO_PIN_4 #define KEY_COL1 GPIO_PIN_5 #define KEY_COL2 GPIO_PIN_6 #define KEY_COL3 GPIO_PIN_7 #define KEY_COL4 GPIO_PIN_2 #define KEY_ROW_PORT GPIOC #define KEY_COL_PORT GPIOC #define KEY_SCAN_INTERVAL 10 //扫描间隔时间(ms) static uint8_t s_u8KeyState[4][5] = {0}; //按键状态数组 void Key_Scan(void) { static uint8_t s_u8KeyScanCol = 0; //当前扫描的列号 static uint32_t s_u32KeyScanTick = 0; //扫描定时器 //每隔一定时间扫描一次按键 if((SysTick_GetTick() - s_u32KeyScanTick) < KEY_SCAN_INTERVAL) { return; } s_u32KeyScanTick = SysTick_GetTick(); //输出当前列为低电平,并读取行的状态 GPIO_SetOutputVal(KEY_COL_PORT, KEY_COL0 << s_u8KeyScanCol, 0); s_u8KeyState[0][s_u8KeyScanCol] = GPIO_ReadInputPortBit(KEY_ROW_PORT, KEY_ROW0); s_u8KeyState[1][s_u8KeyScanCol] = GPIO_ReadInputPortBit(KEY_ROW_PORT, KEY_ROW1); s_u8KeyState[2][s_u8KeyScanCol] = GPIO_ReadInputPortBit(KEY_ROW_PORT, KEY_ROW2); s_u8KeyState[3][s_u8KeyScanCol] = GPIO_ReadInputPortBit(KEY_ROW_PORT, KEY_ROW3); //将当前列恢复为高电平 GPIO_SetOutputVal(KEY_COL_PORT, KEY_COL0 << s_u8KeyScanCol, 1); //判断是否扫描完了一行,如果是,则更新扫描列号 s_u8KeyScanCol++; if(s_u8KeyScanCol >= 5) { s_u8KeyScanCol = 0; } } ``` 2.数码管驱动的实现 接下来,让我们来看一下如何实现使用hc32l13x芯片和I2C驱动ch455h数码管。 首先,让我们来看一下ch455h数码管的引脚定义: ``` DIN - PC1 CLK - PC0 CS - PC2 ``` 可以看到,ch455h数码管的引脚是通过I2C进行控制的,因此我们可以通过配置I2C的方式来实现数码管的驱动。 具体实现代码如下: ``` #define SEG_ADDR 0xC0 //数码管地址 static uint8_t s_u8SegBuf[4] = {0}; //数码管缓存数据 void Seg_Init(void) { //向数码管发送初始化命令 uint8_t u8InitCmd[] = {0x21, 0x81, 0xA0, 0xCF}; I2C_SendData(I2C1, SEG_ADDR, u8InitCmd, sizeof(u8InitCmd)); } void Seg_SetData(uint8_t u8Data[4]) { memcpy(s_u8SegBuf, u8Data, sizeof(s_u8SegBuf)); } void Seg_Update(void) { //向数码管发送更新数据命令 uint8_t u8UpdateCmd[] = {0x01, 0x02, 0x03, 0x04}; I2C_SendData(I2C1, SEG_ADDR, u8UpdateCmd, sizeof(u8UpdateCmd)); //向数码管发送数码数据 I2C_SendData(I2C1, SEG_ADDR, s_u8SegBuf, sizeof(s_u8SegBuf)); } ``` 以上就是使用hc32l13x芯片和ch455h 4x5矩阵键盘和数码管驱动的基本实现示例,希望能够对你有所帮助。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值