- 浏览: 324476 次
- 性别:
- 来自: 南京
文章分类
最新评论
-
huangyunbin:
swc.advance(); 这个什么时候被调用是最核心的 ...
滑动窗口计数java实现 -
80后的童年2:
深入浅出MongoDB应用实战开发网盘地址:https://p ...
MongoDB 从入门到精通专题教程 -
rryymmoK:
深入浅出MongoDB应用实战开发下载地址:http://pa ...
MongoDB 从入门到精通专题教程 -
u012352249:
怎么支持多个窗口啊?
滑动窗口计数java实现 -
rryymmoK:
深入浅出MongoDB应用实战开发百度网盘下载:链接:http ...
MongoDB 从入门到精通专题教程
这是我做的最后一个单片机的实验了,不过没有把程序调通,先作个记号,以后如有时间再来慢慢调
头文件
主程序
头文件
#define uint unsigned int #define uchar unsigned char sbit lcdrs = P1^0; sbit lcdrw = P1^1; sbit lcden = P1^2; sbit key0 = P2^0;//功能键,选择时分秒 sbit key1 = P2^1;//加1键 sbit key2 = P2^2;//减1键 sbit key4 = P2^4; sbit clk_1302 = P1^5; //1302芯片位定义 sbit io_1302 = P1^6; sbit rst_1302 = P1^7; uchar bdata dat; sbit dat0 = dat^0; sbit dat7 = dat^7; uchar key0_count;//按键0被按的次数(0~3) uchar flag; char hour,minute,second; uchar table_date[] = "2009-4-12 Mon"; uchar table_time[] = "00:00:00"; /****** 函数申明 ********/ void write_cmd_1602(uchar cmd); void write_data_1602(uchar dat); void write_add(uchar add,uchar dat); void init1602(); void delay(uint z); uchar reverse(uchar c); void keyscan(); void init(); void RTC_initial (); void wr_1302(uchar wr_data); uchar rd_1302(void); uchar uc_R1302(uchar ucAddr); void v_W1302(uchar ucAddr, uchar ucDa);
主程序
#include <reg52.h> #include <intrins.h> #include "header.h" /****** 主函数 ********/ void main() { RTC_initial(); init(); //init1602(); //while(1); while(1) { if(flag) { second = uc_R1302(0x81); minute = uc_R1302(0x83); hour = uc_R1302(0x85); write_add(0x40+10,second); write_add(0x40+7,minute); write_add(0x40+4,hour); } keyscan(); delay(1); } } void RTC_initial () { v_W1302(0x8e,0x00); //使能 v_W1302(0x80,0x80); //停止晶振 v_W1302(0x90,0x00); //关闭充电 v_W1302(0x8c,0x07); //设置年 v_W1302(0x8a,0x06); //设置周 v_W1302(0x88,0x01); //设置月 v_W1302(0x86,0x13); //设置日 v_W1302(0x84,0x18); //设置小时 v_W1302(0x82,0x05); //设置分 v_W1302(0x80,0x00); //启动晶振,设置秒 v_W1302(0x8e,0x80); //使能 } /***************************** * 功 能: 往DS1302写入1Byte数据 * 输 入: wr_data写入的数据 * 返回值: 无 *******************************/ void wr_1302(uchar wr_data) { uchar i = 0; dat = wr_data; rst_1302 = 1; clk_1302 = 0; delay(5); for(i=0;i<8;i++) { io_1302 = dat0; clk_1302 = 0; _nop_(); clk_1302 = 1; _nop_(); dat >>= 1; } //rst_1302 = 0; } /***************************** * 功 能: 从DS1302读出1Byte数据 * 返回值: dat *******************************/ uchar rd_1302(void) { uchar i; rst_1302 = 1; clk_1302 = 1; delay(5); for(i=0;i<8;i++) { dat >>= 1; dat7 = io_1302; clk_1302 = 1; _nop_(); _nop_(); clk_1302 = 0; _nop_(); } rst_1302 = 0; return dat; } /******************************************************************** * 名 称: uc_R1302 * 说 明: 先写地址,后读命令/数据 * 功 能: 读取DS1302某地址的数据 * 调 用: v_RTInputByte() , uc_RTOutputByte() * 输 入: ucAddr: DS1302地址 * 返回值: ucDa :读取的数据 ***********************************************************************/ uchar uc_R1302(uchar add) { uchar temp= 0xff; wr_1302(add); temp = rd_1302(); return temp; } /******************************************************************** * 名 称: v_W1302 * 说 明: 先写地址,后写命令/数据 * 功 能: 往DS1302写入数据 * 调 用: v_RTInputByte() * 输 入: ucAddr: DS1302地址, ucDa: 要写的数据 * 返回值: 无 **********************************************************************/ void v_W1302(uchar ucAddr, uchar ucDa) { wr_1302(ucAddr); wr_1302(ucDa); rst_1302 = 0; clk_1302 = 0; } //1602液晶初始化 void init1602() { lcdrw = 0; //本程序只读不写,故将其置低 lcden = 0; //关闭1602 delay(5); write_cmd_1602(0x01); //清屏 write_cmd_1602(0x38); //显示模式 write_cmd_1602(0x0c); //开显示,不显示光标,不闪烁 write_cmd_1602(0x06); //地址指针自动加1 write_cmd_1602(0x80+1);//将光标指向第一行第二个位置 delay(5); } void delay(uint z) { uint x,y; for(x=z;x>0;x--) for(y=110;y>0;y--); } /** 将发送的数据进行翻转,高位到低位,低位转到高位 **/ uchar reverse(uchar c) { uchar chbuff=0; if (c&0x01) chbuff=chbuff|0x80; if (c&0x02) chbuff=chbuff|0x40; if (c&0x04) chbuff=chbuff|0x20; if (c&0x08) chbuff=chbuff|0x10; if (c&0x10) chbuff=chbuff|0x08; if (c&0x20) chbuff=chbuff|0x04; if (c&0x40) chbuff=chbuff|0x02; if (c&0x80) chbuff=chbuff|0x01; return chbuff; } //向液晶写命令 void write_cmd_1602(uchar cmd) { lcdrs = 0; //低表示写命令,高表示写数据 delay(5); P0 = reverse(cmd); delay(5); lcden = 1; //给一个高脉冲 delay(5); lcden = 0; delay(5); } //向液晶写数据 void write_data_1602(uchar dat) { lcdrs = 1; //低表示写命令,高表示写数据 delay(5); P0 = reverse(dat); delay(5); lcden = 1; //给一个高脉冲 delay(5); lcden = 0; delay(5); } //根据地址向液晶写数据 void write_add(uchar add,uchar dat) { uchar shi,ge; shi = dat/10; ge = dat%10; delay(5); write_cmd_1602(0x80+add); write_data_1602(shi+0x30); delay(5); write_data_1602(ge+0x30); } //键盘扫描函数 void keyscan() { key4 = 0; if(0==key0) //第一个键被按下 { delay(5); //消抖 if(0==key0) { key0_count ++; if(4==key0_count) { key0_count = 0; flag = 1; } while(!key0); //松手检测 flag = 0; if(0==key0_count) { flag = 0; write_cmd_1602(0x0c); //禁止显示光标并不让其闪烁 } if(1==key0_count) { flag = 0; write_cmd_1602(0x80+0x40+11);//将地址指针指向秒的位置 write_cmd_1602(0x0f); //显示光标并闪烁 delay(5); } if(2==key0_count) { flag = 0; write_cmd_1602(0x80+0x40+8);//将地址指针指向分的位置 write_cmd_1602(0x0f); //显示光标并闪烁 delay(5); } if(3==key0_count) { flag = 0; write_cmd_1602(0x80+0x40+5);//将地址指针指向小时的位置 write_cmd_1602(0x0f); //显示光标并闪烁 delay(5); } } } if(0==key1) //第二个键被按下 { delay(5); //消抖 if(0==key1) { while(!key1); //松手检测 flag = 0; if(key0_count==1) { second ++; if(60==second) second = 0; write_add(0x40+10,second); v_W1302(0x80,second); } if(key0_count==2) { minute ++; if(60==minute) minute = 0; write_add(0x40+7,minute); v_W1302(0x82,minute); } if(key0_count==3) { hour ++; if(24==hour) hour = 0; write_add(0x40+4,hour); v_W1302(0x84,hour); } } } if(0==key2) //第三个键被按下 { delay(5); //消抖 if(0==key2) { while(!key2); //松手检测 flag = 0; if(key0_count==1) { second --; if(-1==second) second = 59; write_add(0x40+10,second); v_W1302(0x80,second); } if(key0_count==2) { minute --; if(-1==minute) minute = 59; write_add(0x40+7,minute); v_W1302(0x82,minute); } if(key0_count==3) { hour --; if(-1==hour) hour = 23; write_add(0x40+4,hour); v_W1302(0x84,hour); } } } } //程序初始化函数 void init() { uchar i; flag = 1; hour = 0; minute = 0; second = 0; init1602(); delay(20); //延长时间,确保液晶处于非忙状态 for(i=0;i<14;i++) { write_data_1602(table_date[i]); delay(5); } write_cmd_1602(0x80+0x40+4); //调整地址指针 for (i=0;i<8;i++) { write_data_1602(table_time[i]); delay(5); } delay(50); v_W1302(0x81,25); v_W1302(0x83,48); v_W1302(0x85,10); }
发表评论
-
51单片机操作DS1302时钟芯片
2009-04-18 22:13 1832这是我做的最后一个单 ... -
51单片机实现数字时钟
2009-04-12 17:56 3517用单片机实现数字时钟,关于时间显示,是用的1602液 ... -
51单片机之I^2C总线
2009-04-11 19:06 1801I^2C总线的SDA与CLK ... -
MCS-51单片机之液晶显示
2009-04-11 11:55 2182用MCS-51单片机来驱 ... -
51系列单片机之串口通信
2009-04-05 11:08 1644单片机的串口通信 ... -
单片机A/D,D/A
2009-04-02 20:59 1459整了几天也没整明白单片机的A/D,D/A,以后用的着,再来 ... -
单片机 键盘编程
2009-03-31 22:26 1635花了几天时间整了下单片机的键盘.我用的单片机板子是用的P ... -
单片机数码管显示数字递增
2009-03-29 13:13 2906让单片机的数码管显示的数从0开始递增一直到255,然后重新 ... -
单片机显示三位整数
2009-03-29 13:03 1838利用数码管显示三位数是利用了单片机数码管的动态扫描,但此 ... -
单片机的数码管动态显示
2009-03-29 12:56 2276要达到单片机数码管轮流显示的效果,不但要控制哪一个数 ... -
单片机定时器
2009-03-28 13:48 2221单片机的定时器的工作原理是利用了寄存器的溢出来触发中断的 ... -
STC89C52中断系统
2009-03-27 17:06 570480C51的中断系统有5个中断源(80C52有6个),2 ... -
74HC164控制数码管显示
2009-03-25 22:45 4670刚开始的时候把74HC164当成了74HC573使 ... -
单片机的数码管的倥制
2009-03-25 13:27 1699今天总算是看到了一点单片机实在的东西了,经过今天的学习, ... -
使单片机的发光二极管闪烁
2009-03-25 13:16 1605学习单机一星期,收益颇多! 下面是我做的第一个 ...
相关推荐
本文将深入探讨如何使用51单片机驱动DS1302时钟芯片,以及相关的keil工程文件和C源代码。DS1302是一款低功耗、高性能的实时时钟(RTC)芯片,它能够精确地跟踪时间,并提供日期和时间的存储功能。 首先,DS1302芯片...
本文将深入探讨如何使用51单片机、DS1302时钟芯片以及12864液晶显示器来构建一个功能完善的万年历系统。 51单片机是Intel公司开发的8051系列单片机的一种,以其易用性和广泛的硬件支持而著名。它内部集成了CPU、RAM...
电子万年历毕业设计(基于AT89C51单片机和DS1302时钟芯片) 根据给定的文件信息,本文将从给定的文件的标题、描述、标签和部分内容中生成相关知识点。下面是生成的知识点: 电子万年历毕业设计概述 电子万年历...
本文将详细讲解如何利用51单片机控制DS1302时钟芯片,并在LCD1602液晶显示屏上实现实时时钟的显示。 首先,DS1302是一款低功耗、高性能的实时时钟(RTC)芯片,它能够提供精确的时间信息,包括年、月、日、星期、...
通过本实例的分析,我们可以了解到如何利用51单片机配合DS1302时钟芯片和共阴数码管制作一个简易的数字时钟。从电路设计、程序编写到最终的调试验证,每一个环节都是开发过程中不可或缺的部分。通过这个实例,初学者...
51单片机 时钟芯片 ds1302 控制 有一定的程序描述,可以学习使用DS1302
电子万年历毕业设计(基于AT89C51单片机和DS1302时钟芯片) 本文档是关于电子万年历毕业设计的论文,基于AT89C51单片机和DS1302时钟芯片。该设计主要使用STC89C52RC单片机作为主控核心,并使用DS1302时钟芯片提供...
基于51系列单片机与DS1302时钟芯片的电子时钟C语言Proteus仿真报告 本报告从基于51系列单片机与DS1302时钟芯片的电子时钟的设计与实现出发,详细介绍了电子时钟的设计思想、硬件选择、电路设计、软件设计、仿真与...
电子万年历设计基于AT89C51单片机和DS1302时钟芯片 本文介绍了基于AT89C51单片机设计的电子万年历。以AT89C51单片机作为主控核心,与时钟芯片DS1302、按键、LED显示等模块组成硬件系统。在硬件系统中设有独立按键和...
在这个项目中,51单片机被用于控制DS1302实时时钟芯片,实现时间和日期的显示与管理功能。 DS1302是一款低功耗、高性能的串行实时时钟,能够提供精确的时间信息,包括小时、分钟、秒、年、月、日等。它通过三线接口...
【51单片机 DS1302时钟】是一种基于51系列单片机的实时时钟系统,其中DS1302是一款常见的串行实时时钟芯片。本文将详细探讨51单片机与DS1302的集成应用,以及相关的设计原理和编程方法。 DS1302是一款低功耗、高...
总结来说,基于51单片机的DS1302时钟仿真设计涵盖了51单片机的硬件接口设计、DS1302时钟芯片的使用、单片机编程以及仿真验证等多个方面。通过这个项目,学习者可以深入理解微控制器的I/O操作、实时时钟芯片的应用...
本程序还有三个子程序,分别为Key.c,LCD1602.c和DS1302.c,分别代表按键控制、LCD1602液晶屏和DS1302时钟芯片。直接运行main.c即可。 如果无法运行,请验证二个事项: 1.是否已安装LCD1602 2.是否已连接DS1302(我...
基于51单片机与DS1302时钟芯片和LCD1602液晶显示的数字时钟.doc
关键词:proteus仿真、51单片机、DS1302时钟芯片、DB18B20温度芯片、AT24C02_51MCU_stc89C52_ProjectDB18B20温度芯片、AT24C02_51MCU_stc89C52_Project.zip
【电子万年历设计基于AT89C51单片机和DS1302时钟芯片】 电子万年历是一种现代计时装置,代表了钟表行业的第三次革命,其精度远超传统的机械钟表和石英钟。电子万年历通过单片机数码计时技术,提供精确到1/600万秒的...