#include "msp430G2553.h"
int tab[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
int temp;
//毫秒延迟函数
void delay(int ms)
{
int i;
while(ms--)
for(i=0;i<120;i++);
}
//纳米延迟函数
void delayns(int ns)
{
while(ns--);
}
void display(temp)//现实位置P2.0=SH;P2.1=ST;P2,2=DS
{
int k,temp1,temp2;
for(k=7;k>=0;k--)
{
temp1=1< temp2=temp & temp1;
if(temp2==temp1)
{
P2OUT |=BIT2;
}
else
{
P2OUT &=~BIT2;
}
P2OUT &=~BIT0;
delayns(10);
P2OUT |=BIT0;
}
P2OUT &=~BIT1;
delayns(10);
P2OUT |=BIT1;
}
int main( void )
{
// Stop watchdog timer to prevent time out reset
WDTCTL = WDTPW + WDTHOLD;
P2DIR |=0x07;
int m,time,temp;
while(1)
{
m=P1IN;
//显示
temp=tab[(2*m)%10];//个位
display(temp);
temp=tab[(2*m)/10];//十位
display(temp);
//脉宽
if(m<=9) time +=10;
if(m>15) time -=30;
P2OUT |=BIT3;
delay(time);
P2OUT &=~BIT3;
delay(20);
}
}
int tab[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
int temp;
//毫秒延迟函数
void delay(int ms)
{
int i;
while(ms--)
for(i=0;i<120;i++);
}
//纳米延迟函数
void delayns(int ns)
{
while(ns--);
}
void display(temp)//现实位置P2.0=SH;P2.1=ST;P2,2=DS
{
int k,temp1,temp2;
for(k=7;k>=0;k--)
{
temp1=1<
if(temp2==temp1)
{
P2OUT |=BIT2;
}
else
{
P2OUT &=~BIT2;
}
P2OUT &=~BIT0;
delayns(10);
P2OUT |=BIT0;
}
P2OUT &=~BIT1;
delayns(10);
P2OUT |=BIT1;
}
int main( void )
{
// Stop watchdog timer to prevent time out reset
WDTCTL = WDTPW + WDTHOLD;
P2DIR |=0x07;
int m,time,temp;
while(1)
{
m=P1IN;
//显示
temp=tab[(2*m)%10];//个位
display(temp);
temp=tab[(2*m)/10];//十位
display(temp);
//脉宽
if(m<=9) time +=10;
if(m>15) time -=30;
P2OUT |=BIT3;
delay(time);
P2OUT &=~BIT3;
delay(20);
}
}
#include"reg51.h"
sbit DS_595= P1^0;
sbit CT_595= P1^1;
sbit CH_595= P1^2;
int tab[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
int temp;
void delay(int ms)
{
int i;
while(ms--)
for(i=0;i<120;i++);
}
void delayns(int ns)
{
while(ns--);
}
void WR_595(void)
{
int k,temp1,temp2;
for(k=7;k>=0;k--)
{
temp1=1<
temp2=temp & temp1;
if(temp2==temp1)
{
DS_595=1;
}
else
{
DS_595=0;
}
CH_595=0;
delayns(10);
CH_595=1;
}
}
void main()
{
int m;
for(m=0;m<10000;m++)
{
temp=tab[m/1000];
WR_595();
CT_595=0;
delayns(10);
CT_595=1;
temp=tab[(m%1000)/100];
WR_595();
CT_595=0;
delayns(10);
CT_595=1;
temp=tab[((m%1000)%100)/10];
WR_595();
CT_595=0;
delayns(10);
CT_595=1;
temp=tab[((m%1000)%100)%10];
WR_595();
CT_595=0;
delayns(10);
CT_595=1;
delay(200);
}
} [page]
串行通信时钟程序
#include"reg51.h"
sbit DS_595= P1^0;
sbit CT_595= P1^1;
sbit CH_595= P1^2;
sbit POT =P1^3;
int tab[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
int temp;
void delay(int ms)
{
int i;
while(ms--)
for(i=0;i<120;i++);
}
void delayns(int ns)
{
while(ns--);
}
void WR_595(void)
{
int k,temp1,temp2;
for(k=7;k>=0;k--)
{
temp1=1<
temp2=temp & temp1;
if(temp2==temp1)
{
DS_595=1;
}
else
{
DS_595=0;
}
CH_595=0;
delayns(10);
CH_595=1;
}
}
void main()
{
int hour,min,sec;
while(1)
{
sec++;
if(sec==60)
{
sec=0;
min++;
if(min==60)
{
min=0;hour++;
if(hour==24)hour=0;
}
}
temp=tab[hour/10];
WR_595();
CT_595=0;
delayns(2);
CT_595=1;
temp=tab[hour%10];//245959
WR_595();
CT_595=0;
delayns(2);
CT_595=1;
temp=tab[min/10];//5900
WR_595();
CT_595=0;
delayns(2);
CT_595=1;
temp=tab[min%10];
WR_595();
CT_595=0;
delayns(2);
CT_595=1;
temp=tab[sec/10];
WR_595();
CT_595=0;
delayns(2);
CT_595=1;
temp=tab[sec%10];
WR_595();
CT_595=0;
delayns(2);
CT_595=1;
delay(300);
POT=~POT;
delay(300);
POT=~POT;
}[page]
74HC595芯片是一种串入并出的芯片,在电子显示屏制作当中有广泛的应用。
74HC595是8位串行输入/输出或者并行输出移位寄存器,具有高阻、关、断状态。
三态。特点 8位串行输入 8位串行或并行输出 存储状态寄存器,三种状态 输出寄存器可以直接清除 100MHz的移位频率 输出能力 并行输出,总线驱动 串行输出;
标准 中等规模集成电路应用 串行到并行的数据转换 Remote control holding register. 描述 595是告诉的硅结构的CMOS器件, 兼容低电压TTL电路,遵守JEDEC标准。
595是具有8位移位寄存器和一个存储器,三态输出功能。 移位寄存器和存储器是分别的时钟。数据在SCHcp的上升沿输入,在STcp的上升沿进入的存储寄存器中去。如果两个时钟连在一起,则移位寄存器总是比存储寄存器早一个脉冲。 移位寄存器有一个串行移位输入(Ds),和一个串行输出(Q7’),和一个异步的低电平复位,存储寄存器有一个并行8位的,具备三态的总线输出,当使能OE时(为低电平),存储寄存器的数据输出到总线。
CPD决定动态的能耗, PD=CPD×VCC×f1+∑(CL×VCC2×f0) F1=输入频率,CL=输出电容 f0=输出频率(MHz) Vcc=电源电压 引脚说明符号引脚描述
内部结构
结合引脚说明就能很快理解 595的工作情况
74HC595引脚图,管脚图
______________________
QB--|1 16|--Vcc
QC--|2 15|--QA
QD--|3 14|--SI(DS)
QE--|4 13|--/G(/OE)
QF--|5 12|--RCK(ST_CP)
QG--|6 11|--SRCK(SH_CP)
QH--|7 10|--/SRCLR(/MR)
GND- |8 9|--QH\'
________________________
74595的数据端:
QA--QH: 八位并行输出端,可以直接控制数码管的8个段。
QH\': 级联输出端。我将它接下一个595的SI端。
SI: 串行数据输入端。
74595的控制端说明:
/SRCLR(10脚): 低点平时将移位寄存器的数据清零。通常我将它接Vcc。
SRCK(11脚):上升沿时数据寄存器的数据移位。QA-->QB-->QC-->...-->QH;下降沿移位寄存器数据不变。(脉冲宽度:5V时,大于几十纳秒就行了。我通常都选微秒级)
RCK(12脚):上升沿时移位寄存器的数据进入数据存储寄存器,下降沿时存储寄存器数据不变。(通常我将RCK置为低电平,) 当移位结束后,在RCK端产生一个正脉冲(5V时,大于几十纳秒就行了。我通常都选微秒级),更新显示数据。
/G(13脚): 高电平时禁止输出(高阻态)。如果单片机的引脚不紧张,用一个引脚控制它,可以方便地产生闪烁和熄灭效果。比通过数据端移位控制要省时省力。
注:
1)74164和74595功能相仿,都是8位串行输入转并行输出移位寄存器。74164的驱动电流(25mA)比74595(35mA)的要小,14脚封装,体积也小一些。
2)74595的主要优点是具有数据存储寄存器,在移位的过程中,输出端的数据可以保持不变。这在串行速度慢的场合很有用处,数码管没有闪烁感。
与164只有数据清零端相比,595还多有输出端时能/禁止控制端,可以使输出为高阻态。
3)595是串入并出带有锁存功能移位寄存器,它的使用方法很简单,在正常使用时SCLR为高电平, G为低电平。从SER每输入一位数据,串行输595是串入并出带有锁存功能移位寄存器,它的使用方法很简单,如下面的真值表,在正常使用时SCLR为高电平, G为低电平。从SER每输入一位数据,串行输入时钟SCK上升沿有效一次,直到八位数据输入完毕,输出时钟上升沿有效一次,此时,输入的数据就被送到了输出端。入时钟SCK上升沿有效一次,直到八位数据输入完毕,输出时钟上升沿有效一次,此时,输入的数据就被送到了输出端。
其实,看了这么多595的资料,觉得没什么难的,关键是看懂其时序图,说到底,就是下面三步(引用):
第一步:目的:将要准备输入的位数据移入74HC595数据输入端上。
方法:送位数据到 P1.0。
第二步:目的:将位数据逐位移入74HC595,即数据串入
方法:P1.2产生一上升沿,将P1.0上的数据移入74HC595中.从低到高。
第三步:目的:并行输出数据。即数据并出
方法:P1.1产生一上升沿,将由P1.0上已移入数据寄存器中的数据
送入到输出锁存器。
说明: 从上可分析:从P1.2产生一上升沿(移入数据)和P1.1产生一上升沿
(输出数据)是二个独立过程,实际应用时互不干扰。即可输出数据的
同时移入数据。
而具体编程方法为
如:R0中存放3FH,LED数码管显示“0”
;*****接口定义:
DS_595 EQU P1.0 ;串行数据输入(595-14)
CH_595 EQU P1.2 ;移位时钟脉冲(595-11)
CT_595 EQU P1.1 ;输出锁存器控制脉冲(595-12)
;*****将移位寄存器内的数据锁存到输出寄存器并显示
OUT_595:
CALL WR_595 ;调用移位寄存器接收一个字节数据子程序
CLR CT_595 ;拉低锁存器控制脉冲
NOP
NOP
SETB CT_595 ;上升沿将数据送到输出锁存器,LED数码管显示“0”
NOP
NOP
CLR CT_595
RET
;*****移位寄存器接收一个字节(如3FH)数据子程序
WR_595:
MOV R4,#08H ;一个字节数据(8位)
MOV A,R0 ;R0中存放要送入的数据3FH
LOOP:
;第一步:准备移入74HC595数据
RLC A ;数据移位
MOV DS_595,C ;送数据到串行数据输入端上(P1.0)
;第二步:产生一上升沿将数据移入74HC595
CLR CH_595 ;拉低移位时钟
NOP
NOP
setb CH_595 ;上升沿发生移位(移入一数据)
DJNZ R4,LOOP ;一个字节数据没移完继续
RET
而其级联的应用
74HC595主要应用于点阵屏,以16*16点阵为例:传送一行共二个字节(16位)
如:发送的是06H和3FH。其方法是:
1.先送数据3FH,后送06H。
2.通过级联串行输入后,3FH在IC2内,06H在IC1内。应用如图二
3.接着送锁存时钟,数据被锁存并出现在IC1和IC2的并行输出口上显示。
编程方法:
数据在30H和31H中
;MOV 30H,#3FH
;MOV 31H,#06H
;*****接口定义:
DS_595 EQU P1.0 ;串行数据输入(595-14)
CH_595 EQU P1.2 ;移位时钟脉冲(595-11)
CT_595 EQU P1.1 ;输出锁存器控制脉冲(595-12)
;*****串行输入16位数据
MOV R0,30H
CALL WR_595 ;串行输入3FH
nop
NOP
MOV R0,31H
CALL WR_595 ;串行输入06H
NOP
NOP
SETB CT_595 ;上升沿将数据送到输出锁存器,显示
NOP
NOP
CLR CT_595
RET
MC74HC595A包括一个8位移位寄存器和一个8位D型锁存器和三态并行输出。移位寄存器接受串行数据并提供串行输出。移位寄存器也提供并行数据输出和8位锁存器。移位寄存器和锁存器都有独立的时钟输入。这个IC还具有异步复位的功能。
HC595A可以直接和CMOS MPU的和MCU的SPI接口进行连接。
数据在30H和31H中
;MOV 30H,#3FH
;MOV 31H,#06H
;*****接口定义:
DS_595 EQU P1.0 ;串行数据输入(595-14)
CH_595 EQU P1.2 ;移位时钟脉冲(595-11)
CT_595 EQU P1.1 ;输出锁存器控制脉冲(595-12)
;*****串行输入16位数据
MOV R0,30H
CALL WR_595 ;串行输入3FH
nop
NOP
MOV R0,31H
CALL WR_595 ;串行输入06H
NOP
NOP
SETB CT_595 ;上升沿将数据送到输出锁存器,显示
NOP
NOP
CLR CT_595
RET
MC74HC595A包括一个8位移位寄存器和一个8位D型锁存器和三态并行输出。移位寄存器接受串行数据并提供串行输出。移位寄存器也提供并行数据输出和8位锁存器。移位寄存器和锁存器都有独立的时钟输入。这个IC还具有异步复位的功能。
HC595A可以直接和CMOS MPU的和MCU的SPI接口进行连接。
#include"reg51.h"
sbit DS_595= P1^0;
sbit CT_595= P1^1;
sbit CH_595= P1^2;
int tab[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
int temp;
void delay(int ms)
{
int i;
while(ms--)
for(i=0;i<120;i++);
}
void WR_595(void)
{
int k,temp1,temp2;
for(k=7;k>=0;k--)
{
temp1=1<
if(temp2==temp1)
{
DS_595=1;
}
else
{
DS_595=0;
}
CH_595=0;
delay(2);
CH_595=1;
}
}[page]
void main()
{
int m;
for(m=0;m<16;m++)
{
temp=tab[m];
WR_595();
CT_595=0;
delay(2);
CT_595=1;
delay(2);
CT_595=0;
delay(500);
}
}
#include"reg51.h"
sbit DS_595= P1^0;
sbit CT_595= P1^1;
sbit CH_595= P1^2;
sbit AA=P1^3;
sbit BB=P1^4;
int yu[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
int temp,court,gg,ss,m,n,j;
void delay(int ms)
{
int i;
while(ms--)
for(i=0;i<120;i++);
}
void WR_595(void)
{
int k,temp1,temp2;
for(k=7;k>=0;k--)
{
temp1=1<
if(temp2==temp1)
{
DS_595=1;
}
else
{
DS_595=0;
}
CH_595=0;
delay(2);
CH_595=1;
}
}
void display(m)
{
temp=yu[m];
WR_595();
CT_595=0;
delay(1);
CT_595=1;
delay(1);
}
void main()
{
for(m=0;m<1000;m++)
{
n=m/1000;
BB=1;AA=1;
P2=0x80;
display(n);
n=(m%1000)/100;
BB=1;AA=0; P2=0x40;
display(n);
n=((m%1000)%100)/10;
BB=0;AA=1; P2=0x20;
display(n);
n=m%10;
AA=0;BB=0; P2=0x01;
display(n);
delay(600);
}
}
上一篇:MSP430F5299时钟设置(24M)和计数器A使用
下一篇:MSP430单片机串口通信详解
推荐阅读最新更新时间:2024-03-16 13:49
MSP430单片机WDT看门狗定时
看门狗定时器用来防止程序因供电电源、空间电磁干扰或其它原因引起的强烈干扰噪声而跑飞的事故。程序中设置看TL=WDTPW+WDTCNTCL,当程序跑飞不能及时清零看门狗,导致看门狗溢出复位,这样程序可以恢复正常运行状态。 1.记数单元WDTCNT:WDTCNT是16位增记数器,由MSP430选定的时钟电路产生的固定周期脉冲信号对记数器进行加法记数。 2.控制寄存器WDTCTL:WDTCTL由两部分组成,高8位用作口令,即5AH(头文件中定义为WDTPW),低8位是对WDT操作的控制命令时先写入口令WDTPW,口令写错将导致系统复位。读WDTCTL时不需口令,低字节WDTCTL的值,高字节读出始终为69H。 3.通过
[单片机]
STM32 LCD12864 串行通信模式
lcd12864简介 带中文字库的128X64是一种具有4位/8位并行、2线或3线串行多种接口方式,内部含有国标一级、二级简体中文字库的点阵图形液晶显示模块;其显示分辨率为128×64,内置8192个16*16点汉字,和128个16*8点ASCII字符集。利用该模块灵活的接口方式和简单、方便的操作指令,可构成全中文人机交互图形界面。可以显示8×4行16×16点阵的汉字。也可完成图形显示。低电压低功耗是其又一显著特点。由该模块构成的液晶显示方案与同类型的图形点阵液晶显示模块相比,不论硬件电路结构或显示程序都要简洁得多,且该模块的价格也略低于相同点阵的图形液晶模块。 注: 我们所用的LCD屏的命名,基本都是按照其分辨率来进行命名的
[单片机]
DSP与MSP430的电力系统故障录波器设计
引言 目前,电力系统录波器已成为电力系统自动化及系统管理的重要组成部分。简单地说,电力系统录波器就是一种数据采集记录装置,它可以记录系统非正常和正常状况下系统电压、电流、频率的变化。在电力系统正常运行情况下记录的数据,对于分析电力系统正常运行下电能的应用情况起着重要的作用;而故障阶段记录的数据,对于分析电力系统故障发生的原因,以及帮助寻找故障发生点,从而迅速处理相关故障事故起着关键的作用。 参考文献设计的电力系统故障录波器,其数据传输采用计算机与局域网相结合的方法,必须以局域网方式连接才能传输数据,使得其应用有一定的局限性。参考文献设计方案是基于DSP的电力系统故障录波器,通过以太网方式来控制。这两种设计方案必须架设局域网络才能实
[单片机]
基于Modbus协议的三相电力智能配电系统设计
随着电力自动化技术的发展和电力智能配电系统建设的需要,具有数字化、智能化、网络化、多功能的配电系统日渐成为中低压配电的最基本要求,采用专用的三相电参量采集芯片和高性价比的16位MSP430处理器构建的智能配电系统,并通过RS 485总线实现电力系统通用的Modbus协议,具有适时遥测数据精度高、遥控可靠、遥信号时、低功耗、扩展性好等优点。 1 三相电力配电系统的硬件设计 1.1 TI MSP430F149处理器 TI MSP430F149是一款超低功耗的高性价比精简指令集16位单片机,最小指令周期125 ns,32 kB的FLASH和2 kB RAM,具有丰富的片上外设资源和5个双向8位IO口,并具有JTAG调试接口,非常
[测试测量]
MSP430单片机的DCO初始化
1.平台说明MSP430F5438。 2.ACLK选择XT1,频率为32.768K,MCLK和SMCLK选择DCOCLKDIV,频率为8000K。 //辅助时钟ACLK32.768K //系统时钟子系统时钟8000K #include“inc/hw_memmap.h” #include“ucs.h” #include“wdt_a.h” #include“gpio.h” #include“sfr.h” voidmain(void) { //停止看门狗 WDT_A_hold(WDT_A_BASE); //P4.0保持输出状态 GPIO_setAsOutputPin(GPIO_PORT_P4,GPIO_PIN0); //初始化P7.
[单片机]
MSP430G2553 WDT的NMI中断例子
将 RST/NMI 引脚设为 NMI 模式,主程序中点亮 P1.0 口 LED,在 NMI 中断中关掉 LED。现象为当按下 RST 按键时,LED 熄灭,并且再也不亮(除非重新上电)。 #include MSP430G2553.h void main( void ) { WDTCTL = WDTPW + WDTHOLD +WDTNMI; //NMI模式(非Reset模式) IE1=NMIIE; //开NMI中断,无需开总中断 P1DIR |=BIT0; //P1.0设为输出口 P1OUT |=BIT0; //亮灯 LPM
[单片机]
单片机MSP430入门-理论⑤--定时器模块-WDT看门狗
上期大概给大家汇总介绍了,在MSP430环境下的时钟寄存器BCSCTL2,他每个位的意义以及他们的设置方法 本期将重点介绍下,定时器模块,这次先讲下看门狗定时器和他的寄存器,设置等 1.0 定义 1.1 定时器: MSP430的定时器大概有4种,看门狗定时器,基本定时器,定时器A,定时器B, 1.2 基本定时器功能: 基本定时,支持软件和各种外围模块工作在低频率,低功耗条件下 1.3 定时器A功能: 基本定时,支持同时进行的多种时序控制,多个捕获,比较功能和多种输出波形(PWM),可以以硬件方式支持串行通信 1.4 定时器B功能: 基本定时,功能基本跟定时器A差不多,但比较定时器A更灵活,功能更强大 1.5 看门口定时器功
[单片机]
基于MSP430的十二导联同步心电图机的设计
MSP430系列单片机在医疗设备行业应用很广泛,以其低功耗,外围设计简单的优点得到了设计者的喜欢。而心电图或CT的复杂的医疗设备应用的很多。心电图机是诊断心脏病的重要仪器之一,能够为医生提供最直观的心电波形。欧美国家已经普遍使用十二导心电图机。十二导联心电图同步记录能客观表达各波、段和间期,可以对早博、心动过速、预激综合征、束支阻滞及分支阻滞等进行定位诊断与鉴别诊断;将心电数据存入数据库,可以进行各种电参数的统计学处理,为临床医疗和科研工作带来了极大便利。根据目前的微电子、单片机和计算机技术成功研制出一种便携式心电图机,它可通过液晶显示器显示心电图,同时将数据在计算机上显示并通过网络实现信息远传,是一种新颖的临床和家庭兼用的心
[医疗电子]
小广播
热门活动
换一批
更多
设计资源 培训 开发板 精华推荐
最新单片机文章
更多精选电路图
更多热门文章
更多每日新闻
更多往期活动
- 是德科技有奖直播:如何让你的Wi-Fi测试“兔”飞猛进?
- 2020年ST MEMS传感器创意设计大赛
- 免费申请英飞凌FMCW雷达解决方案Position2Go,角度,距离,速度,运动方向检测一板搞定!
- 有奖直播|如何借助Mentor Xpedition AMS对汽车CAN总线进行仿真优化分析?
- 下载Vishay最新通信解决方案 赢取超赞移动电源
- 中秋“国宴“ :拍摄板卡上的国产元器件,抽开心小礼品
- 联想栗子工业智能开发板抢先首发!免费申请进行时~另有12 月 22 日深圳技术沙龙邀您莅临!
- 有奖直播:TI 的故事—— IC 创世纪
- Nexperia有奖直播|电动汽车中车规功率MOSFET和氮化镓器件的介绍及应用
- 【颁奖礼】摸黑抢楼赢大礼!
11月13日历史上的今天
厂商技术中心