历史上的今天
今天是:2025年08月15日(星期五)
2019年08月15日 | 共阴极数码管的显示刷新
2019-08-15 来源:eefocus
共阳极数码管是指八段数码管的八段发光二极管的阳极(正极)都连在一起,而阴极对应的各段可分别控制,如图(B)所示:
共阴极数码管是指八段数码管的八段发光二极管的阴极(负极)都连在一起,而阳极对应的各段分别控制,如图(C)所示:

共阴级输入高电平有效,共阳级输入低电平有效。
驱动程序如下:
/*seg.c*/
#include "./delay/delay.h"
#define SEGPORT P0
sbit bit_select = P2^0; //定义位码位为P2^0口
sbit seg_select = P2^1; //定义断码位为P2^1口
/*共阴极数码管的0~F的显示*/
unsigned char seg_data[16] = {0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
unsigned char bit_data[8] = {0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};
void main()
{
unsigned char i;
SEGPORT = 0;
/*消除数码管刷新时的重影*/
while(1)
{
for(i = 0; i < 8; i++)
{
SEGPORT = 0x0;
seg_select = 1;
seg_select = 0;
SEGPORT = 0xff;
bit_select = 1;
bit_select = 0;
SEGPORT = seg_data[i];
seg_select = 1;
seg_select = 0;
SEGPORT = bit_data[i];
bit_select = 1;
bit_select = 0;
delay_ms(2);
}
}/*延时函数*/
/*delay.c*/
void delay_us(unsigned char t){
while(--t);
}
void delay_ms(unsigned char t)
{
while(t--)
{
delay_us(245);
delay_us(245);
}
}
void delay_s(unsigned char t)
{
while(t--)
{
delay_ms(200);
delay_ms(200);
delay_ms(200);
delay_ms(200);
delay_ms(200);
}
}
/*delay.h*/
#ifndef _DELAY_H_
#define _DELAY_H_
extern void delay_us(unsigned char t);
extern void delay_ms(unsigned char t);
extern void delay_s(unsigned char t);
#endif
下一篇:利用中断实现的4*4矩阵键盘扫描
史海拾趣
|
随着信息时代的到来,信息技术尤其是计算机多媒体技术与网络技术飞速发展,语音教室在各种学 校都已有了广泛的应用。现存的语音教学系统一般都是采用模拟电路,可靠性低,抗干扰性弱,易发生 串音,从而在传输过程中会失真、衰减,且易受干扰, ...… 查看全部问答> |
|
特点: * Serial Peripheral Interface (SPI) compatible -- Mode 0 and Mode 3 * 33,554,432 x 1 bit structure * 64 Equal Sectors with 64K byte each - Any sector can be erased * Single Power Supply Operation - 2.7 t ...… 查看全部问答> |
|
基于VxWorks的军用仿真系统 软件使用VxWorks平台 硬件使用研华CPCI平台 功能概述: ●实时模拟火箭发射与操作 ●控制站采用VxWorks系统,操作站采用Windows ●使用1553B通讯 ●AI/AO/DI/DO与通讯接口 解决方案:&nbs ...… 查看全部问答> |
|
在RAM里运行速度明显的快于flash运行速度。想把如何把F2812片内FLASH的程序搬移到RAM里,谁有相关的流程和例程?万分感谢!… 查看全部问答> |
|
板子是自己做的 仿真器没问题 好着呢 硬件设计也没问题 因为前几块板子都没问题 新做的一个板子 连接没问题 但烧写LOAD .OUT 文件是提示 DAta Verification failed at address 0x6460 Please verufy ttarget memory and memory map ...… 查看全部问答> |
|
请问,对于不同的IO,比如GPIOA1,A2,A3 ,B1,B2,B3,C1,C2 可不可以用结构体对这非连续的八个IO口写到一组里面,然后向对这一组IO口的值同时赋值?或者对这一组IO口的值同时读取值?多谢!… 查看全部问答> |
|
做了好久的交流采样,总是在定时器A与AD12的地方出问题,请大侠看看下面的定时器与AD12的初始设置到底哪儿有问题,我实在太菜了。 要求是,AD12的时钟由TimerA产生,采样频率为50HZ的交流信号,信号周期为20ms,采样间隔为1ms,单通 ...… 查看全部问答> |




