NO12 蓝桥杯单片机实践之DS1302

1 回顾

DS1302使用电子时钟模式时,使用方法为:

(1)将读写寄存器的地址写成数组

(2)时间参数写成数组

(3)调用函数来进行读取实时时间(底层代码.c文件)

2 实践

2.1 任务

2.2 思路

首先读任务分为两部分,一是使用DS1302电子时钟功能,二是将电子时钟的时分秒显示在数码管上。(DS1302电子时钟功能就按照使用步骤来写,第二部分任务就用到数码管的动态显示,之前多次练习就不再赘述。)

其次由于要用到底层代码ds1302.c,官方没有给对应.h文件,因此要自己写。

2.3 完整代码

2.3.1 .h 文件编写

首先是底层文件.h的编写,按照之前讲的.h文件编写有对应的结构,其应包括对函数的声明,有需要的话还要有相关引脚的定义(定义引脚时有时会用到一些函数库)。

(1)结构先写好:

(2)翻看.c 文件:

有三个函数,因此复制到.h文件中。

.h文件变为:

(3)编译一下,发现缺少引脚定义

则回去看硬件原理图:

根据对应引脚进行定义(可放.c文件也可放.h文件),定义引脚时还要使用对应的库:

最后.h文件就写完啦!!!!!!

2.3.2 任务完整代码

完整代码如下,这里要注意的是main函数中,ds1302读写函数都要涉及,写函数放在while循环外(写一次即可),读函数就要循环读,可理解为电子时钟每时每刻的时间都在更新,因此需要循环读。

其次,还有读写函数的编写时,写函数是直接调用底层代码的写入函数,对相应地址进行相应的写入即可,而读函数在调用了底层代码的读取函数后,还要赋给一个数组Timer_dat,这是因为数码管显示时,内容用的是Timer_dat里的元素来计算的,如果不把每时每刻读到的时间重新赋值给Timer_dat,那么Timer_dat就恒定为最初设计的初始时间,变成了个常数而不会改变了。

完整代码如下:

#include  "stc15f2k60s2.h"
#include  "ds1302.h"

void selectHC138(unsigned int n)
{
  switch(n)
  {
    case 0:
      P2 = (P2 & 0x1f) | 0x00;  break;
    case 1:
      P2 = (P2 & 0x1f) | 0x20;  break;
    case 2:
      P2 = (P2 & 0x1f) | 0x40;  break;
    case 3:
      P2 = (P2 & 0x1f) | 0x60;  break;
    case 4:
      P2 = (P2 & 0x1f) | 0x80;  break;
    case 5:
      P2 = (P2 & 0x1f) | 0xa0;  break;
    case 6:
      P2 = (P2 & 0x1f) | 0xc0;  break;
    case 7:
      P2 = (P2 & 0x1f) | 0xe0;  break;
  }
}

//==============================================================================
unsigned char code Read_add_ds1302[7] = {0x81,0x83,0x85,0x87,0x89,0x8b,0x8d};
unsigned char code Write_add_ds1302[7] = {0x80,0x82,0x84,0x86,0x88,0x8a,0x8c};

//18nian.2.17  23h,50min,46s  Sat.
unsigned char Time_dat[7]={0x46,0x59,0x23,0x17,0x02,0x06,0x18};


unsigned int i;
void  Write_DS1302()
{
  Write_Ds1302_Byte(0x8e,0x00);
  for(i=0;i<7;i++)
  {
    Write_Ds1302_Byte(Write_add_ds1302[i],Time_dat[i]);
  }
  Write_Ds1302_Byte(0x8E,0x80);
}

void  Read_DS1302()
{
  Read_Ds1302_Byte(0x8f);
  for(i=0;i<7;i++)
  {
    Time_dat[i] = Read_Ds1302_Byte(Read_add_ds1302[i]);
  }
}
//====================================================================================

//========================
void Delay(unsigned char t)
{
  while(t--);
}

code unsigned char SMG_Table[] = 
{
0xc0, //0
0xf9, //1
0xa4, //2
0xb0, //3
0x99, //4
0x92, //5
0x82, //6
0xf8, //7
0x80, //8
0x90, //9
0x88, //A
0x83, //b
0xc6, //C
0xa1, //d
0x86, //E
0x8e,  //F
0xbf  //-
};

void SMG(unsigned int position, unsigned char content)
{
  selectHC138(6);
  P0 = 0x01 << position;
  selectHC138(7);
  P0 = content;
}



void SMG_CLOSEALL(unsigned char dat)
{
 	selectHC138(6);
	P0 = 0xff;
	selectHC138(7);
	P0 = dat;
}

void SMG_Display()
{
    
  SMG_CLOSEALL(0xff);
	Delay(100);
  
  SMG(0,SMG_Table[ Time_dat[2] /16]);
  Delay(100);
  SMG(1,SMG_Table[ Time_dat[2] %16]);
  Delay(100);
  SMG(2,SMG_Table[16]);
  Delay(100);
  SMG(3,SMG_Table[ Time_dat[1] /16]);
  Delay(100);
  SMG(4,SMG_Table[Time_dat[1] %16]);
  Delay(100);
  SMG(5,SMG_Table[16]);
  Delay(100);
  SMG(6,SMG_Table[ Time_dat[0] /16] );
  Delay(100);
  SMG(7,SMG_Table[ Time_dat[0] %16] );
  Delay(100);
  
  SMG_CLOSEALL(0xff);
	Delay(100);
}


void close()
{
  selectHC138(5);
  P0 = 0x00;
  selectHC138(4);
  P0 = 0xff;
}




void main()
{
  Write_DS1302();
  close();
  while(1)
  {
    Read_DS1302();
    SMG_Display();
  }
}

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值