|
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
51单片机学习:使用DS1302芯片制作电子钟 J6 ]) ^9 f8 n! L" d# X" M( X
2 p+ x3 B8 h9 y% h, ?' M
! u- N! [7 L" K0 X$ t) u
DS1302 是美国DALLAS公司推出的一种高性能、低功耗、带RAM的实时时钟电路,它可以对年、月、日、周日、时、分、秒进行计时,具有闰年补偿功能,工作电压为2.5V~5.5V。采用三线接口与CPU进行同步通信,并可采用突发方式一次传送多个字节的时钟信号或RAM数据。DS1302内部有一个31×8的用于临时性存放数据的RAM寄存器。DS1302是DS1202的升级产品,与DS1202兼容,但增加了主电源/后备电源双电源引脚,同时提供了对后备电源进行涓细电流充电的能力。 3 \( O( X& i e8 {$ J
DS1302的引脚排列,其中Vcc1为后备电源,VCC2为主电源。在主电源关闭的情况下,也能保持时钟的连续运行。DS1302由Vcc1或Vcc2两者中的较大者供电。当Vcc2大于Vcc1+0.2V时,Vcc2给DS1302供电。当Vcc2小于Vcc1时,DS1302由Vcc1供电。X1和X2是振荡源,外接32.768kHz晶振。RST是复位/片选线,通过把RST输入驱动置高电平来启动所有的数据传送。RST输入有两种功能:首先,RST接通控制逻辑,允许地址/命令序列送入移位寄存器;其次,RST提供终止单字节或多字节数据传送的方法。当RST为高电平时,所有的数据传送被初始化,允许对DS1302进行操作。如果在传送过程中RST置为低电平,则会终止此次数据传送,I/O引脚变为高阻态。上电运行时,在Vcc>2.0V之前,RST必须保持低电平。只有在SCLK为低电平时,才能将RST置为高电平。I/O为串行数据输入输出端(双向),后面有详细说明。SCLK为时钟输入端。 下图为DS1302的引脚功能图 4 ^: W& X, f# }
..................................................................................... ; P) y+ r7 g3 B. Z/ v0 d; Z
! l3 e% g* ~6 L P: K
* {5 L- V- S( p" {& h; p6 {4 B ; ]) y4 j! w2 E3 Q/ W e
我在淘宝上花了几块钱买了个山寨的1302模块,凑合着可以用,; d- u7 A' D5 q: |
但是模块上的sclk,io,RST这3个脚没有上拉电阻,自己加上去了,汗!
# z* T, r8 c! A不加上拉电阻,显示的时钟很容易发生错误# J8 B6 m# _( f. F
好了不多说,贴代码, m! `/ X4 h5 h6 P* A
本程序只显示时间,没有年份和月份...) t" p7 ?# F# x, f' Q
! X/ C% B& ^* a1 w7 |$ ?/ q0 o6 J
( v& j9 s+ i% y3 a" }
6 V; z& o" n. z# T: o! s
2 I4 e4 k# ? m
. _2 x8 x$ c; o0 k+ v! T |
|