这是我做的最后一个单片机的实验了,不过没有把程序调通,先作个记号,以后如有时间再来慢慢调
主程序:
#include
#include
#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>= 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>= 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;
/****** 函数申明 ********/
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);
分享到:
相关推荐
本文将深入探讨如何使用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万秒的...