蓝桥杯单片机DS1302时钟芯片模块(时钟的实现)

时钟芯片DS1302原理图:

 比赛中,官方提供的资源包里会有头文件ds1302.h和源代码ds1302.c。同样是把头文件和源代码添加到工程文件夹当中,然后进行修改即可使用。

代码解析:

修改的地方:在ds1302.c源代码里的延时函数后面增加8到12倍的延时,下面是修改完成之后的代码。

DS1302.c

 /*
  程序说明: DS1302驱动程序
  软件环境: Keil uVision 4.10 
  硬件环境: CT107单片机综合实训平台 8051,12MHz
  日    期: 2011-8-9
*/

#include <reg52.h>
#include <intrins.h>

sbit SCK=P1^7;		
sbit SDA=P2^3;		
sbit RST = P1^3;   // DS1302复位												

unsigned char shijian[]={50,59,23,0,0,0,0};
void Write_Ds1302(unsigned  char temp) 
{
	unsigned char i;
	for (i=0;i<8;i++)     	
	{
		SCK=0;
		SDA=temp&0x01;
		temp>>=1; 
		SCK=1;
	}
}

void Write_Ds1302_Byte( unsigned char address,unsigned char dat )     
{
 	RST=0;	_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();
 	SCK=0;	_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();
 	RST=1; 	_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();
 	Write_Ds1302(address);
 	Write_Ds1302(dat);
 	RST=0;
}

unsigned char Read_Ds1302_Byte(unsigned char address)
{
 	unsigned char i,temp=0x00;
 	RST=0;	_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();
 	SCK=0;	_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();
 	RST=1;	_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();
 	Write_Ds1302(address);
 	for (i=0;i<8;i++)
{
		SCK=0;
		temp>>=1;
 		if(SDA)
 		temp|=0x80;
 		SCK=1;
}
 	RST=0;	_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();
 	SCK=0;	_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();
	SCK=1;	_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();
	SDA=0;	_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();
	SDA=1;	_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();
	return (temp);
}

添加的代码:

 

void DS_init(void)       //初始化,要在头文件里面进行定义
{
	unsigned char i,add;
	add=0x80;
	Write_Ds1302_Byte(0x8e,0x00);
	for(i=0;i<7;i++)
	{
		Write_Ds1302_Byte(add,(shijian[i]/10<<4)|(shijian[i]%10));
		add=add+2;
	}
	Write_Ds1302_Byte(0x8e,0x80);
}
void DS_get(void)  //要在头文件里面进行定义
{
	unsigned char i,add,dat;
	add=0x81;
	for(i=0;i<7;i++)
	{
		dat=Read_Ds1302_Byte(add);
		shijian[i]=dat/16*10+dat%16;
		add=add+2;
	}
}

DS1302.h

#ifndef __DS1302_H
#define __DS1302_H

void Write_Ds1302(unsigned char temp);
void Write_Ds1302_Byte( unsigned char address,unsigned char dat );
unsigned char Read_Ds1302_Byte( unsigned char address );
void DS_init(void);        
void DS_get(void);         
#endif

实现的功能程序:

#include <STC15F2K60S2.H>
#include <intrins.h>

#define uchar unsigned char
#define uint unsigned int
	
uchar SMG_duanma[]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90,0xBF,0xFF};
uchar yi,er,san,si,wu,liu,qi,ba;

unsigned char shijian[7];
void Allinit(void);
void Delayms(int ms);
void Display1(uchar yi,uchar er);
void Display2(uchar san,uchar si);
void Display3(uchar wu,uchar liu);
void Display4(uchar qi,uchar ba);
void DS1302_Init(void);
void DS1302_Get(void);

void main(void)
{
	 Allinit();
	DS1302_Init();
//	yi=2;er=0;san=2;si=2;wu=0;liu=3;qi=2;ba=0;
	while(1)
	{
		DS1302_Get();
		yi=shijian[2]/10; er=shijian[2]%10;san=21;
		si=shijian[1]/10;wu=shijian[1]%10;liu=21;
		qi=shijian[0]/10;ba=shijian[0]%10;
		
		Display1(yi,er);
		Display2(san,si);
		Display3(wu,liu);
		Display4(qi,ba);
	}
}
void Display1(uchar yi,uchar er)
{
	P2=0xC0;
	P0=0x01;
	P2=0xE0;
	P0=SMG_duanma[yi];
	Delayms(1);
	
	P2=0xC0;
	P0=0x02;
	P2=0xE0;
	P0=SMG_duanma[er];
	Delayms(1);
}
void Display2(uchar san,uchar si)
{
	P2=0xC0;
	P0=0x04;
	P2=0xE0;
	P0=SMG_duanma[san];
	Delayms(1);
	
	P2=0xC0;
	P0=0x08;
	P2=0xE0;
	P0=SMG_duanma[si];
	Delayms(1);
}
void Display3(uchar wu,uchar liu)
{
	P2=0xC0;
	P0=0x10;
	P2=0xE0;
	P0=SMG_duanma[wu];
	Delayms(1);
	
	P2=0xC0;
	P0=0x20;
	P2=0xE0;
	P0=SMG_duanma[liu];
	Delayms(1);
}
void Display4(uchar qi,uchar ba)
{
	P2=0xC0;
	P0=0x40;
	P2=0xE0;
	P0=SMG_duanma[qi];
	Delayms(1);
	
	P2=0xC0;
	P0=0x80;
	P2=0xE0;
	P0=SMG_duanma[ba];
	Delayms(1);
}
void Allinit(void)
{
	P2=0xA0;
	P0=0x00;
	
	P2=0xC0;
	P0=0xFF;
	P2=0xE0;
	P0=0xFF;
	
	P2=0x80;
	P0=0xFF;
}
void Delayms(int ms)
{
	int i,j;
	for(i=0;i<ms;i++)
		for(j=845;j>0;j--);
}

猜你喜欢

转载自blog.csdn.net/m0_65270952/article/details/124157494