@Mahdi
2017-07-21T18:19:45.000000Z
字数 2811
阅读 1091
未分类
集成电路
- 共16引脚,
- 8GND,16VCC
- 1~6输入引脚.
- 1,2,3 逻辑输入控制引脚
- 4,5,6使能引脚.4,5低电平。6高电平。
- 15~7输出引脚,对应YO~Y7
- 74HC245 稳定工作在 70mA 电流是没有问题的,仅仅是电流驱动缓冲
- 八路双向收发器
- 封装形式:SDP20,SOP20-2,TSSOP20,DIP20
- 共20引脚
- 10GND,20VCC
- 1脚 DIR 方向引脚
- 2~9脚"A"信号输入输出端
- 11~18脚"B"信号输入输出端
- 19脚OE(低电平有效) 输出使能端,
置1
A/B端的信号不导通,清0
A/B端才被启用,该脚也就是起到开关的作用
dir = 1
B = A
dir = 0
A = B
/*************STC98C52中138的定义************************/
#include <reg52.h>
sbit A1 = P2^2;
sbit A2 = P2^3;
sbit A3 = P2^4;
void main()
{
// unsigned char code LedChar[] = {0xC0, 0xF9, 0xA4, 0xB0,
// 0x99, 0x92, 0x82, 0xF8,
// 0x80, 0x90, 0x88, 0x83,
// 0xC6, 0xA1, 0x86, 0x8E};
A3 = 0;
A2 = 1;
A1 = 0;
P0 = ~0xF8; // 1111 1001 点亮数码管段 b 和 c 共阴极的真值表是共阳极的取反值
}
}
- 八路输出的透明锁存器(当输入的数据消失时,在芯片的输出端,数据仍然保持输出),输出为三态门
- 这种电路可以驱动大电容或低阻抗负载,可以直接与系统总线接口并驱动总线,而不需要外接口。特别适用于缓冲寄存器,I/O 通道,双向总线驱动器和工作寄存器。
- 共20引脚
- 10GND,20VCC
- 1脚 OE(Output Enable)输出使能端
- 2~9脚 D0~D7(Data Input)数据输入
- 11 LE(Latch Enable Input)锁存使能输入
- 12~19脚 Q0~Q7(3 State Latch Output)3态锁存输出
1脚 OE是一个低电平有效的引脚(通常在开发板上,直接采取接地的措施,因为既然用到573,那么一般都是想让它处于工作状态的)
当OE = 1;
无论Input(输入端D0~D7)输入何种电平状态,Output(输出端Q0~Q7)都为Z,此时芯片处于不可控状态。
当OE = 0;
LE = 1 => Q(输出) = D(输入) (Q端的电平状态紧随着D端变化)
LE = 0;
无论D为何种电平状态,Q都会保持上一次的电平(Q端电平状态将保持住,LE端变化为低电平之前Q端的电平状态).
- 最重要的功能就是:串行输入,并行输出,3态高速位移寄存器.595里面有2个8位寄存器:移位寄存器、存储寄存器.并各具有相互独立的时钟
- 共16引脚,
- 8GND,16VCC
- 15,1~7脚QA~QH(3 State Output)3态输出(8位并行数据输出)
- 9脚QH' 串行数据输出口(用于多个595串联)
- 10脚MR 主复位 又称SCLR(Shift Clear)移位寄存器清零端(低电平有效)
- 11脚SCK(Shift Register Clock Input)移位寄存器时钟输入口
- 12脚RCK(Storage Register Clock Input)存储寄存器时钟输入口
- 13脚OE 输出使能(低电平有效)
- 14脚DS,又叫SER (Serial Data Input)串行数据输入口
所谓存储寄存器,就是数据可以存在这个寄存器中,并不会随着一次输出就消失,只要595不断电,也没有新的数据从移位寄存器中过来,数据就一直不变且有效。新的数据过来后,存储寄存器中的数据就会被覆盖更新。
数据从位移寄存器 转移到 存储寄存器,也是需要时钟脉冲驱动的,这就是12脚的作用
9脚,没用起作用,如果要让2个595串联起来的话,就需要它了。
138译码器通过3个输入口控制8个输出口,而且还只能是特定的8个输出值,
想一下,我们将移位寄存器的8个位填满后,再往移位寄存器中塞一个会怎么样?也许你想到了。
对!移位寄存器的最后一个位数据会被挤出去,从哪里出去?就是从9脚输出的。如果我们把第一个595的9脚连接到第二个的串行数据输入脚SER,那么,就形成了595的级联。这样,如果我们用2个595组合成了一个新的超级595,这个草鸡595的移位寄存器和存储寄存器的容量都翻倍了,1口控制16口,有木有!你还可以继续级联下去!而595只用了一个输入口就可以输任意的8位数据。
QA--QH: 八位并行输出端,可以直接控制数码管的8个段
SCLR(10脚): 低电平时将移位寄存器的数据清零。通常将它接VCC让其保持高电平。
所谓存储寄存器,就是数据可以存在这个寄存器中,并不会随着一次输出就消失,只要595不断电,也没有新的数据从移位寄存器中过来,数据就一直不变且有效。新的数据过来后,存储寄存器中的数据就会被覆盖更新。
51单片机的工作离不开晶振,它使CPU的工作步调稳定有序,就像跑步时喊1,2,1的那个人。那么这里的位移寄存器时钟也是同样的道理,当一个新的位数据要进来时,已经进入的位数据就在移位寄存器时钟脉冲的控制下,整体后移,让出位置。
上升沿:电平从低到高的那个过程。移位寄存器时钟在上升沿这个过程中才起作用。
QA QB QC QD QE QF QG QH 分别接 8个LED正极
14脚SER 接 单片机P3.4
11脚SCK 接 单片机P3.6
12脚RCK接 单片机P3.5
13脚OE接GND
10脚SCLR接VCC
9脚闲置不接
/****************/
#include<reg51.h>
#include<intrins.h>
typedef unsigned char uchar;
typedef unsigned int uint;
sbit SER = P3^4; //p3.4脚控制串行数据输入
sbit SCK = P3^6; //串行输入时钟
sbit RCK = P3^5; //存储寄存器时钟
/****定义HC595发送函数***/
void SendTo595(uchar byteData)
{
char i=0;
for(;i<8;i++)
{
SER = byteData >> 7; //大家自己考量这2句
byteData= byteData << 1;
SCK = 1; //上升沿,让串行输入时钟变为高电平,并延时2个时钟周期
_nop_();
_nop_();
SCK = 0; //变为低电平,为下次准备
}
/*位移寄存器数据准备完毕,转移到存储寄存器*/
RCK = 1; //上升沿,让存储寄存器时钟变为高电平,并延时2个时钟周期
_nop_();
_nop_();
RCK = 0;
}
void main()
{
SendTo595(85); //85的二进制:0101 0101
while(1);
}
//功能:发送一个字节的数据给595,再并行输出