当前位置:首页 > 技术学院 > 热搜器件
[导读]8位数码管显示函数(使用74hc573锁存器)。

仿真效果截图:

部分源代码:

/************************************************\

* 8位共阳数码管显示函数(使用74hc573锁存器) *

* 力求程序高效,简洁 *

\************************************************/

/************************************************\

* 分多个函数的原因: *

* 显示要求不同,函数的执行效率不同 *

* 为了实现程序的高效性,显示要求不同调用不同的函数*

\************************************************/

#include

#define DISPLAY_IO P2

#define uchar unsigned char

#define uint unsigned int

#define ulong unsigned long

sbit duan=P3^0; //定义段

sbit wei=P3^1; //定义位

unsigned char code w[]={ //共阴

//0-F无小数点

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

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

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

0x39,0x5e,0x79,0x71,

//0-F带小数点

0xbf,0x86,0xdb,0xcf,

0xe6,0xed,0xfd,0x87,

0xff,0xef,0xf7,0xfc,

0xb9,0xde,0xf9,0xf1,

//小数点 负号

0x80, 0x40};

/************************************************\

* 显示任意内容 *

* n[0-7]数组的值表示数码管位置从左至右的内容 *

\************************************************/

void display_any(uchar n[8])

{

uchar i,delay=0;

for(i=0;i<8;i++)

{

//清除段锁存器内容

DISPLAY_IO=0xff;

duan=1;

duan=0;

//位值送入位锁存器

DISPLAY_IO=0x01<

wei=1;

wei=0;

//段值送入段锁存器

DISPLAY_IO=0xff-n[i];

duan=1;

duan=0;

//延时0-255(越长越亮,但太长会闪)

delay=100;

while(delay--);

}

//清除段锁存器内容 不让第一个数最亮

DISPLAY_IO=0xff;

duan=1;

duan=0;

}

/************************************************\

* 10进制无符号整数显示 *

* 传入n为0到9999 9999 *

* 传入浮点型小数点后忽略,范围不正确显示不正确 *

* 右对齐,左边无多余0 *

\************************************************/

void display_ulong(ulong n)

{

uchar i=8,delay=0;

do

{

//清除段锁存器内容

DISPLAY_IO=0xff;

duan=1;

duan=0;

//位值送入位锁存器

DISPLAY_IO=0x01<<(--i);

wei=1;

wei=0;

//段值送入段锁存器

DISPLAY_IO=0xff-w[n%10];

duan=1;

duan=0;

n/=10;

//延时0-255(越长越亮,但太长会闪)

delay=100;

while(delay--);

}while(n>0);

//清除段锁存器内容 不让第一个数最亮

DISPLAY_IO=0xff;

duan=1;

duan=0;

}

/************************************************\

* 10进制有符号整数显示 *

* 传入n为-999 9999到9999 9999 *

* 传入浮点型小数点后忽略,范围不正确显示不正确 *

* 右对齐,左边无多余0 *

\************************************************/

void display_long(long n)

{

uchar i=8,delay=0;

bit flag=0;

if(n<0)

{

flag=1;

n=-n;

}

do

{

//清除段锁存器内容

DISPLAY_IO=0xff;

duan=1;

duan=0;

//位值送入位锁存器

DISPLAY_IO=0x01<<(--i);

wei=1;

wei=0;

//段值送入段锁存器

DISPLAY_IO=0xff-w[(n==100000000?33:n%10)];

duan=1;

duan=0;

n/=10;

if(n==10000000)

n=-1;

if(n==0&&flag==1)

n=100000000;

//延时0-255(越长越亮,但太长会闪)

delay=100;

while(delay--);

}while(n>0);

//清除段锁存器内容 不让第一个数最亮

DISPLAY_IO=0xff;

duan=1;

duan=0;

}

/************************************************\

* 10进制无符号实型显示 *

* 传入n为0到9999 9800 *

* 传入范围不正确显示不正确 *

* 右对齐,左边无多余0,右边小数点后无多余0 *

\************************************************/

void display_udouble(double n)

{

uchar i=8,delay=0,point_position=0;

ulong n_long=n; //将n赋值给整形变量

while(n_long!=n) //此循环的功能:使n变为8位整数,并记下小数点位置

{

n*=10;

n_long=n;

point_position++;//每乘一次,小数点左移一位

}

do

{

//清除段锁存器内容

DISPLAY_IO=0xff;

duan=1;

duan=0;

//位值送入位锁存器

DISPLAY_IO=0x01<<(--i);

wei=1;

wei=0;

//段值送入段锁存器

DISPLAY_IO=0xff-w[n_long%10+((7-i)==point_position?16:0)];

duan=1;

duan=0;

n_long/=10;

//延时0-255(越长越亮,但太长会闪)

delay=100;

while(delay--);

}while(n_long>0);

//清除段锁存器内容 不让第一个数最亮

DISPLAY_IO=0xff;

duan=1;

duan=0;

}

/************************************************\

* 10进制有符号实型显示 *

* 传入n为-999 999到9999 9800 *

* 传入范围不正确显示不正确 *

* 右对齐,左边无多余0,右边小数点后无多余0 *

\************************************************/

void display_double(double n)

{

uchar i=8,delay=0,point_position=0;

bit flag=0;

long n_long=n; //将n赋值给整形变量

while(n_long!=n) //此循环的功能:使n变为8位整数,并记下小数点位置

{

n*=10;

n_long=n;

point_position++;//每乘一次,小数点左移一位

}

if(n_long<0)

{

flag=1;

n_long=-n_long;

}

do

{

//清除段锁存器内容

DISPLAY_IO=0xff;

duan=1;

duan=0;

//位值送入位锁存器

DISPLAY_IO=0x01<<(--i);

wei=1;

wei=0;

//段值送入段锁存器

DISPLAY_IO=0xff-w[(n_long==100000000?33:(n_long%10+((7-i)==point_position?16:0)))];

duan=1;

duan=0;

n_long/=10;

if(n_long==10000000)

n_long=-1;

if(n_long==0&&flag==1)

n_long=100000000;

//延时0-255(越长越亮,但太长会闪)

delay=100;

while(delay--);

}while(n_long>0);

//清除段锁存器内容 不让第一个数最亮

DISPLAY_IO=0xff;

duan=1;

duan=0;

}

/************************************************\

* 2-16任意进制无符号不去零整数显示 *

* 传入n为0到X,X=((进制)^8)-1 *

* 传入范围不正确显示不正确 *

* 不自动去0 *

\************************************************/

void display_number(ulong n,uchar jin_zhi)

{

uchar i,delay=0;

for(i=0;i<8;i++)

{

//清除段锁存器内容

DISPLAY_IO=0xff;

duan=1;

duan=0;

//位值送入位锁存器

DISPLAY_IO=0x01<<(7-i);

wei=1;

wei=0;

//段值送入段锁存器

DISPLAY_IO=0xff-w[n%jin_zhi];

duan=1;

duan=0;

n/=jin_zhi;

//延时0-255(越长越亮,但太长会闪)

delay=100;

while(delay--);

}

//清除段锁存器内容 不让第一个数最亮

DISPLAY_IO=0xff;

duan=1;

duan=0;

}

/************************\

* 8位数码管测试程序 *

\************************/

void main(void)

{

uint i,t=200;

char n[8]={1,2,4,8,16,32,64,128};

while(1)

{

i=t;

while(i--)

{

display_any(n);

}

i=t;

while(i--)

{

display_ulong(123);

}

i=t;

while(i--)

{

display_long(-123);

}

i=t;

while(i--)

{

display_udouble(123.45);

}

i=t;

while(i--)

{

display_double(-123.45);

}

i=t;

while(i--)

{

display_number(0x123abc,16);

}

}

}

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

为增进大家对工业以太网的认识,本文将对工业以太网的原理、工业以太网的关键技术以及工业以太网要解决的问题予以介绍。

关键字: 以太网 工业以太网 指数

为增进大家对工业以太网的认识,本文将对工业以太网网络优势、工业以太网和IOLINK的区别予以介绍。

关键字: 以太网 工业以太网 指数

为增进大家对工业以太网的认识,本文将对工业以太网的优势、工业以太网缺点、工业以太网的维护予以介绍。

关键字:

Apr. 23, 2024 ---- 随着节能成为AI推理服务器(AI Inference Server)优先考量,北美客户扩大存储产品订单,带动QLC Enterprise SSD需求开始攀升。然而,目前仅Solidi...

关键字: SSD AI 服务器

为增进大家对二极管的认识,本文将对续流二极管、续流二极管的工作原理以及二极管在工业产品中的应用予以介绍。

关键字: 二极管 指数 续流二极管

通过本文,您将了解到二极管反接是否有电压以及二极管在电子电路中的应用。

关键字: 二极管 指数 稳压电路

为增进大家对二极管的了解,本文将对ESD二极管和TVS二极管之间的区别予以介绍。

关键字: ESD TVS 二极管 指数

为增进大家对嵌入式主板的认识,本文将对嵌入式主板以及嵌入式主板常见问题及其解决方法予以介绍。

关键字: 嵌入式 指数 主板

为增进大家对嵌入式系统的认识,本文将对嵌入式系统、嵌入式系统的特点予以介绍。

关键字: 嵌入式 指数 嵌入式系统

为增进大家对嵌入式的认识,本文将对嵌入式、嵌入式工作相关的内容予以介绍。

关键字: 嵌入式 指数 嵌入式技术
关闭
关闭