共阳数码管段码表_数码管的显示原理

我们最常用的是七段式和八段式LED数码管,八段比七段多了一个小数点,其他的基本相同。所谓的八段就是指数码管里有八个小LED发光二极管,通过控制不同的LED的亮灭来显示出不同的字形。数码管又分为共阴极和共阳极两种类型,其实共阴极就是将八个LED的阴极连在一起,让其接地,这样给任何一个LED的另一端高电平,它便能点亮。而共阳极就是将八个LED的阳极连在一起。其原理图如下。

a22b18164a19f1c448293f49deb9f0d9.png

其中引脚图的两个COM端连在一起,是公共端,共阴数码管要将其接地,共阳数码管将其接正5伏电源。一个八段数码管称为一位,多个数码管并列在一起可构成多位数码管,它们的段选线(即a.b.c.d.e.fg.dp)连在一起,而各自的公共端称为位选线。显示时,都从段选线送入字符编码,而选中哪个位选线,那个数码管便会被点亮。数码管的8段,对应一个字节的8位, a对应最低位, dp对应最高位。所以如果想让数码管显示数字0,那么共阴数码管的字符编码为00111111 , 即Ox3f;共阳数码管的字符编码为11000000,即Oxco。可以看出两个编码的各位正好相反。如下图。

a6ef9b6fb0fca7b2fe42d203396c0b92.png

由上面的图可以得到共阳极和共阴极的数码管的编码

共阳极:位选为高电平(即1)选中数码管,各段选为低电平(即0接地时)选中各数码段,由0到f的编码为:

uchar code table[]={

0xc0,0xf9,0xa4,0xb0,

0x99,0x92,0x82,0xf8,

0x80,0x90,0x88,0x83,

0xc6,0xa1,0x86,0x8e};

共阴极:

位选为低电平(即0)选中数码管,各段选为高电平(即1接+5V时)选中各数码段,

uchar code table[]={

0x3f,0x06,0x5b,0x4f,

0x66,0x6d,0x7d,0x07,

0x7f,0x6f,0x77,0x7c,

0x39,0x5e,0x79,0x71};

数码管静态显示

当多位数码管应用于某一系统时,它们的“位选”是可独立控制的,而“段选”是连接在一起的,我们可以通过位选信号控制哪几个数码管亮,而在同一时刻,位选选通的所有数码管上显示的数字始终都是一样的,因为它们的段选是连接在一起的,所以送入所有数码管的段选信号都是相同的,那么它们显示的数字必定一样,数码管的这种显示方法叫做静态显示。

让一个数码管循环显示0-9

63195215cedda69ed1f66bb129fb8c66.gif

下面是程序,从DSY_CODE数组中依次的将编码数据送到P0口就可以了,是不是很简单。

#include #define uchar unsigned char#define uint unsigned intuchar code DSY_CODE[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};void DelayMS(uint x){ uchar t;while(x--)for(t=120;t>0;t--);}void main(){ uchar i=0;P0=0x00;while(1){ P0=DSY_CODE[i++];if(i==10)i=0;DelayMS(200);}}

今天的分享就到这里了,欢迎大家评论转发,有问题欢迎关注私信我哦。

  • 6
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是51单片机的程序示例,用于将数字2313在四共阳数码管显示: ``` #include <reg51.h> // 数码管选控制端口定义 sbit SEG_A = P2^2; sbit SEG_B = P2^3; sbit SEG_C = P2^4; sbit SEG_D = P2^5; // 数码管位选控制端口定义 sbit DIGIT_1 = P2^6; sbit DIGIT_2 = P2^7; // 数码管码表 unsigned char SEG_TABLE[] = { 0x3F, // 0 0x06, // 1 0x5B, // 2 0x4F, // 3 0x66, // 4 0x6D, // 5 0x7D, // 6 0x07, // 7 0x7F, // 8 0x6F // 9 }; void delay(unsigned int x) { unsigned int i, j; for (i = x; i > 0; i--) for (j = 110; j > 0; j--); } void main() { unsigned int num = 2313; unsigned int digit_1, digit_2, digit_3, digit_4; while (1) { digit_1 = num / 1000; // 千位 digit_2 = num % 1000 / 100; // 百位 digit_3 = num % 100 / 10; // 十位 digit_4 = num % 10; // 个位 // 显示千位 SEG_A = SEG_TABLE[digit_1]; SEG_B = SEG_C = SEG_D = 1; DIGIT_1 = 0; delay(1); DIGIT_1 = 1; SEG_A = SEG_B = SEG_C = SEG_D = 1; // 显示百位 SEG_B = SEG_TABLE[digit_2]; SEG_A = SEG_C = SEG_D = 1; DIGIT_2 = 0; delay(1); DIGIT_2 = 1; SEG_A = SEG_B = SEG_C = SEG_D = 1; // 显示十位 SEG_C = SEG_TABLE[digit_3]; SEG_A = SEG_B = SEG_D = 1; DIGIT_1 = 0; delay(1); DIGIT_1 = 1; SEG_A = SEG_B = SEG_C = SEG_D = 1; // 显示个位 SEG_D = SEG_TABLE[digit_4]; SEG_A = SEG_B = SEG_C = 1; DIGIT_2 = 0; delay(1); DIGIT_2 = 1; SEG_A = SEG_B = SEG_C = SEG_D = 1; } } ``` 上述程序中使用了一个数码管码表,将数字0~9对应的选控制码存储在数组SEG_TABLE中,方便程序中的显示操作。程序中通过除法和模运算操作,将数字2313拆分为千位、百位、十位和个位四个数字,分别在四个循环中显示数码管上。其中,使用了延时函数delay()来控制数码管的刷新速度。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值