导航:首页 > 操作系统 > 单片机数码管静态显示

单片机数码管静态显示

发布时间:2022-02-11 07:02:02

❶ 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造化了。

阅读全文

与单片机数码管静态显示相关的资料

热点内容
ie文件夹禁止访问 浏览:543
百川互联网程序员 浏览:783
linuxpython解释器 浏览:665
兴安得力软件加密狗 浏览:490
智能网络摄像头加密 浏览:574
软件毕业程序员培训 浏览:652
安卓陀螺仪低怎么办 浏览:247
一级建造师复习题集pdf 浏览:903
法理学pdf海默 浏览:390
服务器内存储器是用什么的 浏览:819
微帮同城分类信息源码 浏览:808
安卓系统ad是什么 浏览:471
python输出中不加占位符 浏览:596
linux文件夹权限控制 浏览:730
雅虎邮箱怎么加密码 浏览:819
为什么安卓手机登录不了苹果账号 浏览:537
如何复制usb加密狗 浏览:801
哪个app看你微笑时很美 浏览:908
mac启动命令 浏览:604
ngc服务器是什么的简称 浏览:75