❶ 51单片机共阴数码管利用静态显示,让六个数码管显示1~6,程序怎么写
代码如下:
#include <reg52.h>
#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 = 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++)
{
= 1; //段选开
data = leddata[i]; //送入段选数据
= 0; //段选关
delay(500); //延时
}
}
}
(1)单片机数码管静态显示扩展阅读
对于74HC573,形象一点,我们只需要将其理解为一扇大门,只不过这扇大门是单向的,其中11引脚(LE)控制着门的开、关状态,高电平为大门打开,低电平为大门关闭。
D0-D7为输入,Q0-Q7为输出,在LE = 1,即输入高电平时,输入端=输出端,输入是什么,输出也就原封不动的输出;在LE = 0 ,即输入高电平时,大门关闭,实现锁存,不再输出。了解之后,我们按照电路图,来进行编程,代码实现。
在实现数码管的静态显示中,用到了两个锁存器,两个I/O口,P1.6和P1.7,分别是位选和段选。
首先定义了个数码管位选数组,也就是十六进制代码,这便是后来数码管显示数字的核心,接着,用 sbit 定义了位选和段选端口,分别是 P1.6 和 P1.7 ,定义了一个延时函数,其实这一串代码很有意思,开关开关思想,贯穿始终。
首先把位选打开,送入位选数据后,关闭锁存器,实现锁存,进入循环,随之打开段选锁存器,送入段选数据后,再次关闭段选。
接下来,这个延时操作对于实际看到数码管的显示效果特别重要,因为程序在段选后之后,会马上消隐,显示的时间之后几个微秒,这显然不太合理,需要在关闭段选后加上延时,这样一来,才会让每位数码管亮度保持均匀。
❷ c51单片机数码管静态显示程序
1.先把显示函数,按照下列,改一改。
void
display(uchar
shi,uchar
ge)
{
shi
=
num
/
10;
ge
=
num
%
10;
la
=
1;
p0
=
table[shi];
la
=
0;
wela
=
1;
p0
=
0xfe;
wela
=
0;
delay(5);
la
=
1;
p0
=
table[ge];
la
=
0;
wela
=
1;
p0
=
0xfd;
wela
=
0;
delay(5);
}
2.用显示函数代替延时函数。
把你的程序中,凡是:delay(10);,都改成:display(shi,
ge);。
3.把几处等待按键释放,都加上显示函数。
如:
while(!key1);
改为:while(!key1)
display(shi,
ge);
试试看吧。
❸ 51单片机数码管静态显示的问题
应该是动态显示吧!
❹ 单片机汇编程序:LED数码管静态显示问题
显示8,是因为你程序跑飞了,加上延时,自然是延时后跑飞,所以显示8。静态显示不需特殊的延时。想要一直显示就写个死循环就程序停住就可以了,RET是子程序调用的返回,你这里不用加。
❺ 51单片机led数码管显示0-99静态程序
假设P0 P2口接数码管 程序如下
include<reg52.h>
#define uchar unsigned char
#define uint unsigned int
uchar num=0;
//共阴数码管七段码
uchar code table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d, 0x07,0x7f,0x6f,0x77};
void Delay1ms(uint i) //1ms延时程序
{
uint j;
for(;i>0;i--)
{
for(j=0;j<164;j++)
{;}
}
}
void main(void )//主程序
{
while(1)
{
delay_ms(1000);
num++;
if(num==100)num=0;
P0=table[num/10];
P2=table[num%10];
❻ 单片机数码管静态显示学号1830508,用keil 最好有过程,在图上的过程上修改
// 单片机数码管动态显示学号1830508(注多位数码管用静态显示电路会很复杂,所以一般多用动态显示),方法有多种,下面是一个仿真例程可以参考。
#include<reg51.h>
#define uchar unsigned char
// 此表为 LED 的字模 0 1 2 3 4 5 6 7 8 9 a b c d e f
unsigned char code LED7Code[] = {0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F,0x77,0x7C,0x39,0x5E,0x79,0x71};
void delay(uchar z)
{
uchar i,j;
for(i=0;i<120;i++)
for(j=0;j<z;j++);
}
void main()
{
while(1)
{
P0=0xff;
P2=LED7Code[0];
P0=0xfe;
delay(5);
P0=0xff;
P2=LED7Code[1];
P0=0xfd;
delay(5);
P0=0xff;
P2=LED7Code[8];
P0=0xfb;
delay(5);
P0=0xff;
P2=LED7Code[3];
P0=0xf7;
delay(5);
P0=0xff;
P2=LED7Code[0];
P0=0xef;
delay(5);
P0=0xff;
P2=LED7Code[5];
P0=0xdf;
delay(5);
P0=0xff;
P2=LED7Code[0];
P0=0xbf;
delay(5);
P0=0xff;
P2=LED7Code[8];
P0=0x7f;
delay(5);
}
}
❼ 51单片机数码管静态显示问题
点亮数码管是最基本的了。首先要学会看原理图。通过P22,P23,P24来控制38译码器先选通一个数码管,然后把段码加到P0上,就能显示了。要想显示多个数码管,就是上述方法加上延时。先显示一个数码管,再选通另一个数码管,再送段码,就能静态显示多个数码管了。
❽ 用51单片机汇编语言,数码管静态轮流显示1~F
编写相应程序,对应数码管顺序,点亮时间等效果要求,最后执行程序段循环命令即可
❾ 怎么用单片机汇编语言数码管静态显示1234
数码管连接电路如图1所示,p0口输出码型,p2口输出位选。锁存器74hc573起驱动作用,提供驱动电流供数码管发光。译码器74hc138将位选地址转换成位选信号,例如当前是第5个数码管显示,那么p2口输出位选地址05h,译码器输入cba=110,输出位选信号y7-y0=11101111,其中y5=0,第5个数码管选通并显示,其它数码管不显示。实验时将j6的左边两个引脚针(1和2)用跳冒连接,锁存器11脚接vcc,关闭锁存功能。
数码管显示方式为动态扫描方式,当p0口送第一个数0的码型到锁存器时,p2送位选地址01h,即y0=0,只有第一个数码管亮,显示0,其他数码管不显示。当p0口送第二个数1的码型到锁存器时,p2送位选地址02h,即y1=0,只有第二个数码管亮,显示1,其他数码管不显示。即每次只有一个数码管点亮,8个数码管是轮流被点亮的,轮流点亮的间隔时间很短(一般用延时程序延时几个毫秒),由于视觉的暂留现象,看到的却好象全都点亮着,这就是动态扫描。
数码管显示数字的码型由数码管的数据脚a~dp决定,图2为数码管的笔段分布图,由于是共阴极的,所以当a~dp为高电平时相应的笔段会亮,电路中p1.0~p1.7分别接数码管的a.b.c.d.e.f.g.dp,得到0~9这10个数字的码型如表1所示。
图2 数码管的笔段分布图
引脚
p0.7
p0.6
p0.5
p0.4
p0.3
p0.2
p0.1p0.0数字 码型
笔段
dp
g
f
e
d
c
b a
0
0
1
1
1
1
1 1
0 3fh
0
0
0
0
0
1
1 0
1 06h
0
1
0
1
1
0
1 1
2 5bh
0
1
0
0
1
1
1 1
3 4fh
0
1
1
0
0
1
1 0
4 66h
0
1
1
0
1
1
0 1
5 6dh
0
1
1
1
1
1
0 1
6 7dh
0
0
0
0
0
1
1 1
7 07h
0
1
1
1
1
1
1 1
8 7fh
0
1
1
0
1
1
1 1
9 6fh
1
0
0
0
0
0
0 0
小数点80h
只要把上面的相关数,改成学好就可以了。
❿ 单片机上8个数码管这样是让他循环显示,怎样让它静态显示呢
/**52单片机,12MHz晶振,8位共阴数码管,P0口段选,P2口低电平位选,P20最高位,P27最低位**/
#include <reg52.h>
#define uchar unsigned char
#define uint unsigned int
#define TRUE 1
#define FALSE 0
#define th0 0xfe
#define tl0 0x0c //500us at 12MHz(定时器工作模式1 状态)
#define DisTimeAt500usCount 5 //单'位'数码管显示时间,数码管刷新频率f=1/(4t),其中 t 为单'位'数码管显示时间,单位 s,频率f 单位 Hz
#define SEG_Num 8 //数码管位数
uchar code LoveYouList[SEG_Num]={0x38,0x3f,0x3e,0x79,0x40,0x6e,0x3f,0x3e};//LOVE-YOU
#define SEG_Data P0 //数码管段驱动接口
#define SEG_En P2 //数码管位驱动接口
#define SEG_AllOff SEG_En=0xff //关闭所有数码管(位驱动)
bit DisplayFlag; //显示标志位
void Timer0() interrupt 1 //定时器0中断函数
{
static uchar t500us; //定义静态变量 t500us 定时计数寄存空间
TL0=tl0;
TH0=th0; //重赋 1ms 定时初值
t500us=++t500us%DisTimeAt500usCount; //先计数值加1,后对计数范围进行限制0~(DisTimeAt500usCount-1)
if(!t500us) DisplayFlag=TRUE; //若定时计数值归0,则表示计数值曾到达 单'位'显示时间(DisTimeAt500usCount),显示标志 置位
}
void SystemInit() //系统初始化函数
{
TMOD=0x01; //关闭定时器1,开启定时器0,且工作在模式1(16位定时器)
TH0=th0;
TL0=tl0; //装定时初值(1ms at 12MHz)
TR0=1; //启动计时
ET0=1; //允许定时器0中断
EA=1; //开启系统中断功能
}
void Display() //显示函数
{
static dis_loca; //定义静态变量 显示位置
dis_loca=++dis_loca%SEG_Num; //先对 显示位置 加1,后对变量范围进行限制 0~(SEG_Num-1)
SEG_AllOff; //关闭所有数码管显示(位驱动)
SEG_Data=LoveYouList[dis_loca]; //将本次显示位上的内容转成代码,并送到数据端口
SEG_En&=~(1<<dis_loca); //开启本次需要显示的位驱动
}
void main() //主函数
{
SystemInit(); //调用 系统初始化函数
while(1) //循环系统
{
if(DisplayFlag) //若显示标志位为真(单'位'显示时间结束),则执行以下任务
{
DisplayFlag=FALSE; //清显示标志位
Display(); //调用 显示函数
}
}
}
很多设定好的参数可以在 宏定义的时候修改,包括数码管位数、数码管刷新率等,如果LZ的晶振不是12MHz,那么只需要将宏定义中 TH0,TL0的初值修改正常即可,如24MHz,就改成FC18,总体效果我没实物测试,看LZ造化了。