用到的有:51单片机、共阳数码管(图中GND改COM)
七段数码管 + dp > 八段(一个字节八位,其中dp为最高位,a为最低位)
共阳数码管码
0XC0 | 0XF9 | 0XA4 | 0XB0 | 0X99 | 0X92 |
0 | 1 | 2 | 3 | 4 | 5 |
0X82 | 0XF8 | 0X80 | 0X90 | 0X88 | 0X83 |
6 | 7 | 8 | 9 | A | B |
0XC6 | 0XA1 | 0X86 | 0X8E | 0XFF | |
C | D | E | F | 无显示 |
共阴数码管码
0X3F | 0X06 | 0X5B | 0x4F | 0x66 | 0x6D |
0 | 1 | 2 | 3 | 4 | 5 |
0X7D | 0X07 | 0X7F | 0X6F | 0X77 | 0X7C |
6 | 7 | 8 | 9 | A | B |
0X39 | 0X5E | 0X79 | 0X71 | 0X00 | |
C | D | E | F | 无显示 |
|
共阴共阳码表取反过程 :以显示数字‘0’为例
>在共阳数码管中给a、b、c、d、e、f 管脚接低电平(0) g、dp管脚接高电平(1)
> 假设是单片机P0口输出(P0^7为最高位P0^0为最低位)
>P0输出 1100 0000(二进制)
>即0XC0(十六进制)
>显示数字‘0’
>在共阴数码管中给a、b、c、d、e、f 管脚接高电平(1) g、dp管脚接低电平(0)
> 假设是单片机P0口输出(P0^7为最高位P0^0为最低位)
>P0输出 0011 1111(二进制)
>即0X3F(十六进制)
>显示数字‘0’
共阳、共阴码表转换就是各位对应取反的过程
(共阴共阳码表对应相加等于0XFF)例如共阳显示‘A'是0X88,共阴显示’A‘是0X77,相加为0XFF
本次实验采用P0口接共阳数码管
管脚对应接线如图:(JP3接JP10)
P0^0 | a |
P0^1 | b |
P0^2 | c |
P0^3 | d |
P0^4 | e |
P0^5 | f |
P0^6 | g |
P0^7 | dp |
#include <reg51.h>
#include <intrins.h>
typedef unsigned int u16;
void delay1s(void) //误差 0us
{
unsigned char a,b,c;
for(c=167;c>0;c--)
for(b=171;b>0;b--)
for(a=16;a>0;a--);
_nop_(); //if Keil,require use intrins.h
}
code int StaticDisply[17]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90,0x88,0x83,0xC6,0xA1,0x86,0x8E,0xFF};
void main()
{
u16 i;
while(1)
{
for(i=0;i<17;i++)
{
P0=StaticDisply[i];
delay1s();
}
}
}
延时函数用 单片机小精灵 v1.3 自动生成
数码管静态显示:每个数码管必须接一个8位数据线来保持显示的字符。
优点:占用CPU时间少、便于检测和控制
缺点:硬件电路复杂,成本高(占用单片机的管脚多,一个数码管占用一个端口(51单片机共四个端口))