74HC595的工作原理.doc_第1页
74HC595的工作原理.doc_第2页
74HC595的工作原理.doc_第3页
74HC595的工作原理.doc_第4页
74HC595的工作原理.doc_第5页
已阅读5页,还剩4页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

74HC595的工作原理2009-06-09 11:3774HC595的工作原理-编程-显示SCH2007-05-24 23:15 74HC595是具有8位移位寄存器和一个存储器,三态输出功能。 移位寄存器和存储器是分别的时钟。 数据在SHcp的上升沿输入,在STcp的上升沿进入的存储寄存器中去。如果两个时钟连在一起,则移位寄存器总是比存储寄存器早一个脉冲。移位寄存器有一个串行移位输入(Ds),和一个串行输出(Q7),和一个异步的低电平复位,存储寄存器有一个并行8位的,具备三态的总线输出,当使能 OE时(为低电平),存储寄存器的数据输出到总线。 74HC595各个引脚的功能: Q17 是并行数据输出口,即储寄存器的数据输出口 Q7 串行输出口,其应该接SPI总线的MISO接口 STcp 存储寄存器的时钟脉冲输入口 SHcp 移位寄存器的时钟脉冲输入口 OE的非 输出使能端 MR的非 芯片复位端 Ds 串行数据输入端程序说明: 每当SHcp上升沿到来时,DS引脚当前电平值在移位寄存器中左移一位,在下一个上升沿到来时移位寄存器中的所有位都会向左移一位,同时Q7也会串行输出移位寄存器中高位的值,这样连续进行8次,就可以把数组中每一个数(8位的数)送到移位寄存器;然后当STcp上升沿到来时,移位寄存器的值将会被锁存到锁存器里,并从Q17引脚输出。/74HC595串行输出数据void outdisp(unsigned char num) unsigned char i; for (i=0;i8;i+ ) DS=num; SHCP=1; SHCP=0; numQB-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。不过这都没有关系,只是名字不一样,大家看这些文档时,注意点就行。现在大家对595有了一定的了解,现在我们看CEPARK AVR单片机开发板上这一部分的原理图:大家这里只要注意11,12,14这三个引脚由单片机的哪几个口控制就好。SHCP(11)-PG0STCP(12)-PG1DS(14)-PG2下面是源程序:效果:第一位和第二位数码管显示5;#include #include #define SER_PORT PORTG /PG口#define SER_DATA PG2 /DS,串行数据入口#define SER_RCK PG1 /STCP,来一个上升沿时数据进入并行输出#define SER_SCK PG0 /SHCP,来一个上升沿时数据移位unsigned char Led_Disbuf10=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_R

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论