您的位置 首页 电子

CEPARK AVR单片机 之HC595驱动数码管显现

这里我用的CEPARK的M64AVR开发板,这一课的重点是学会如何使用74HC595来驱动数码管。74HC595是具有8位移位寄存器和一个存储器,三态输

这儿我用的CEPARK 的M64 AVR开发板,这一课的重点是学会怎么运用74HC595来驱动数码管。

74HC595是具有8位移位寄存器和一个存储器,三态输出功用。移位寄存器和存储器是别离的时钟。数据在SHcp的上升沿输入,在STcp的上升沿进入的存储寄存器中去。假如两个时钟连在一起,则移位寄存器总是比存储寄存器早一个脉冲。移位寄存器有一个串行移位输入(Ds),和一个串行输出(Q7’),和一个异步的低电平复位,存储寄存器有一个并行8位的,具有三态的总线输出,当使能 OE时(为低电平),存储寄存器的数据输出到总线。

引脚阐明:
QA–QH: 八位并行输出端,能够直接操控数码管的8个段。

QH: 级联输出端。我将它接下一个595的SI端。

SER(DS): 串行数据输入端。

74595的操控端阐明:

/SCLR(MR)(10脚): 低点平常将移位寄存器的数据清零。一般我将它接Vcc。

SCK(SHCP)(11脚):上升沿时数据寄存器的数据移位。QA–>QB–>QC–>…–>QH;下降沿移位寄存器数据不变。(脉冲宽度:5V时,大于几十纳秒就行了。我一般都选微秒级)

RCK(STCP)(12脚):上升沿时移位寄存器的数据进入数据存储寄存器,下降沿时存储寄存器数据不变。一般我将RCK置为低电平,当移位完毕后,在RCK端发生一个正脉冲(5V时,大于几十纳秒就行了。我一般都选微秒级),更新显现数据。

/G(OE)(13脚): 高电平常制止输出(高阻态)。假如单片机的引脚不严重,用一个引脚操控它,能够方便地发生闪耀和平息作用。比经过数据端移位操控要省时省力。

注:74164和74595功用相仿,都是8位串行输入转并行输出移位寄存器。74164的驱动电流(25mA)比74595(35mA)的要小,14脚封装,体积也小一些。

74595的首要长处是具有数据存储寄存器,在移位的过程中,输出端的数据能够坚持不变。这在串行速度慢的场合很有用途,数码管没有闪耀感。

与164只需数据清零端比较,595还多有输出端时能/制止操控端,能够使输出为高阻态。
注明:74HC595引脚命名我现在看到两种,如串行数据输入端(14脚)有的Datasheet上叫SER,还有一种叫DS。不过这都没有关系,仅仅姓名不一样,咱们看这些文档时,留意点就行。

咱们这儿只需留意11,12,14这三个引脚由单片机的哪几个口操控就好。

SHCP(11)———–PG0

STCP(12)———–PG1

DS(14)————-PG2

下面是源程序:
作用:第一位和第二位数码管显现5;

#include <avr/io.h>

#include

#define SER_PORT PORTG //PG口

#define SER_DATA PG2 //DS,串行数据进口

#define SER_RCK PG1 //STCP,来一个上升沿时数据进入并行输出

#define SER_SCK PG0 //SHCP,来一个上升沿时数据移位

unsigned char Led_Disbuf[10]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90}; //共阳极

void Send_Byte_HC595(unsigned char byte) //并行数据移位输出函数

{ //byte是表明咱们想哪一位数码管亮,如为0x01,表明第一个数码管亮

unsigned char i; //循环变量

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

{

if(byte & 0x80)

{

SER_PORT |= _BV(SER_DATA); //PG2输出1

}

else

{

SER_PORT &= ~_BV(SER_DATA);//PG2输出0

}

SER_PORT |= _BV(SER_SCK); //上升沿触发,SER_DATA数据进入移位寄存器

_delay_us(5);

SER_PORT &= ~_BV(SER_SCK);

byte <<= 1; //经过左移,逐一点亮个个数码管

}

SER_PORT |= _BV(SER_RCK); //上升沿触发,移位寄存器中的数据并行输出

_delay_us(5);

SER_PORT &= ~_BV(SER_RCK);

}

int main(void)

{

PORTB = 0xff; //PB口赋初值为ff

DDRB = 0xff; //PB口为输出态

PORTG = 0x00; //PG口赋初值为0

DDRG |= _BV(SER_DATA)|_BV(SER_RCK)|_BV(SER_SCK); //PG0,PG1,PG2为输出态

PORTB = Led_Disbuf[5]; //数码管上显现5

Send_Byte_HC595(0x03); //第一位,第二位数码管点亮

while(1)

{};

}

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/qiche/dianzi/262345.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部