代码如下:
#include
#define uchar unsigned char
#define uint unsigned int
#define data P0 //P0口宏定义
/* ***************************************************** */
// 数码管位选数组定义
/* ***************************************************** */
uchar code leddata[] =
{ 0x3F, //"0"
0x06, //"1"
0x5B, //"2"
0x4F, //"3"
0x66, //"4"
0x6D, //"5"
0x7D, //"6"
0x07, //"7"
0x7F, //"8"
0x6F, //"9"
0x77, //"A"
0x7C, //"B"
0x39, //"C"
0x5E, //"D"
0x79, //"E"
0x71, //"F"
0x76, //"H"
0x38, //"L"
0x37, //"n"
0x3E, //"u"
0x73, //"P"
0x5C, //"o"
0x40, //"-"
0x00, //熄灭
0x00 //自定义};
};
/* ***************************************************** */
// 位定义
/* ***************************************************** */
sbit du = P1^7; //段选定义
sbit we = P1^6; //位选定义
/* ***************************************************** */
// 函数名称:DelayMS()
// 函数功能:毫秒延时
// 入口参数:延时毫秒数(ValMS)
// 出口参数:无
/* ***************************************************** */
void delay(uint z)
{
uint x,y;
for(x = 0; x < z; x++)
for(y = 0; y < 113; y++);
}
/* ***************************************************** */
// 函数名称:main()
// 函数功能:数码管静态显示
// 入口参数:无
// 出口参数:无
/* ***************************************************** */
void main(void)
{
uchar i;
we = 1; //位选开
data = 0x00; //送入位选数据
we = 0; //位选关
while(1)
{
for(i = 0;i < 16 ; i++)
{
du = 1; //段选开
data = leddata[i]; //送入段选数据
du = 0; //段选关
delay(500); //延时
}
}
}
扩展资料
对于74HC573,形象一点,我们只需要将其理解为一扇大门,只不过这扇大门是单向的,其中11引脚(LE)控制着门的开、关状态,高电平为大门打开,低电平为大门关闭。
D0-D7为输入,Q0-Q7为输出,在LE = 1,即输入高电平时,输入端=输出端,输入是什么,输出也就原封不动的输出;在LE = 0 ,即输入高电平时,大门关闭,实现锁存,不再输出。了解之后,我们按照电路图,来进行编程,代码实现。
在实现数码管的静态显示中,用到了两个锁存器,两个I/O口,P1.6和P1.7,分别是位选和段选。
首先定义了个数码管位选数组,也就是十六进制代码,这便是后来数码管显示数字的核心,接着,用 sbit 定义了位选和段选端口,分别是 P1.6 和 P1.7 ,定义了一个延时函数,其实这一串代码很有意思,开关开关思想,贯穿始终。
首先把位选打开,送入位选数据后,关闭锁存器,实现锁存,进入循环,随之打开段选锁存器,送入段选数据后,再次关闭段选。
接下来,这个延时操作对于实际看到数码管的显示效果特别重要,因为程序在段选后之后,会马上消隐,显示的时间之后几个微秒,这显然不太合理,需要在关闭段选后加上延时,这样一来,才会让每位数码管亮度保持均匀。
没有原理图,只好虚拟一个了,假设P0作为段选,P2作为位选,且由373作为锁存器,来控制静态数码管的显示,因为是静态显示,所以不需要扫描和延时。
#include
#define uchar unsigned char;
uchar distab[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x83,0xc6,0xa1,0x86,0x8e,0xff};
main()
{
P2|=0x01;P0=distab[1];P2&=0xfe;
P2|=0x02;P0=distab[2];P2&=0xfd;
P2|=0x04;P0=distab[3];P2&=0xfb;
P2|=0x08;P0=distab[4];P2&=0xf7;
P2|=0x10;P0=distab[5];P2&=0xef;
P2|=0x20;P0=distab[6];P2&=0xdf;
while(1);
}
还是动态扫描吗?
静态能输出这么多码位码。除非用电阻搭出各管的段选。
#include
unsigned char code table[6]={0x06,0x5b,0X4f,0x66,0X6d,0x7d}; //1~6
void delay(unsigned int i)
{
while(i--);
}
void main(void)
{
unsigned char i,k;
while(1)
{
k=1;
for(i=0;i<6;i++)
{
P1 = ~k;
P0 = table[i];
delay(200);
k<<=1;
}
}
}
上面那个程序有错for(i=0;i>5;i++),这是错的