最近想弄一个
单片机数码管时钟,如下图,红 {MOD}显示时间,绿 {MOD}显示年月日
但是,程序写好后,显示确实…………
初始时间是:2014.1.19 19:52:50
红 {MOD}19,95,52
绿 {MOD}:2502,20,01
模拟不好截图 所以就没有截图。
簡單说一哈就是,该显示小时是对的,显示分钟的显示95,显示秒钟的显示出分钟的52;显示年的百位和千位显示了秒钟50;年月日 没有显示。代码如下:
求指明道路。
#include <reg51.h>
#include<intrins.h>
#define uchar unsigned char
#define uint unsigned int
//DS1302引脚定义,可根据实际情况自行修改端口定义
sbit RST=P1^3;
sbit IO=P1^1;
sbit SCK=P1^2;
sbit AB=P2^0; //数码管赋值
sbit CLK=P2^1;
sbit X1=P2^2;
sbit X2=P2^3;
sbit X3=P2^4;
sbit X4=P2^5;
sbit X5=P2^6;
sbit X6=P2^7;
sbit N1=P3^0;
sbit N2=P3^1;
sbit N3=P3^2;
sbit N4=P3^3;
sbit N5=P3^4;
sbit N6=P3^5;
sbit N7=P3^6;
sbit N8=P3^7;
//DS1302地址定义
#define ds1302_sec_add 0x80 //秒数据地址
#define ds1302_min_add 0x82 //分数据地址
#define ds1302_hr_add 0x84 //时数据地址
#define ds1302_date_add 0x86 //日数据地址
#define ds1302_month_add 0x88 //月数据地址
#define ds1302_day_add 0x8a //星期数据地址
#define ds1302_year_add 0x8c //年数据地址
#define ds1302_control_add 0x8e //控制数据地址
#define ds1302_charger_add 0x90
#define ds1302_clkburst_add 0xbe
//初始时间定义
uchar
time_buf[8] = {0x20,0x14,0x01,0x19,0x19,0x52,0x50,0x07}; //初始时间2010年6月1号23点59分55秒 星期二
uchar readtime[14];//当前时间
uchar sec_buf=0; //秒缓存
uchar sec_flag=0; //秒标志位
char code led_mod[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};//数码管显示地址
//功能:延时1毫秒
//入口参数:x
//出口参数:无
//说明:晶振为12M
void Delay_xms(uint x)
{
uint i,j;
for(i=0;i<x;i++)
for(j=0;j<112;j++);
}
//DS1302初始化函数
void ds1302_init(void)
{
RST=0; //RST脚置低
SCK=0; //SCK脚置低
}
//向DS1302写入一字节数据
void ds1302_write_byte(uchar addr, uchar d)
{
uchar i;
RST=1; //启动DS1302总线
//写入目标地址:addr
addr = addr & 0xFE; //最低位置零,寄存器0位为0时写,为1时读
for (i = 0; i < 8; i ++) {
if (addr & 0x01) {
IO=1;
}
else {
IO=0;
}
SCK=1; //产生时钟
SCK=0;
addr = addr >> 1;
}
//写入数据:d
for (i = 0; i < 8; i ++) {
if (d & 0x01) {
IO=1;
}
else {
IO=0;
}
SCK=1; //产生时钟
SCK=0;
d = d >> 1;
}
RST=0; //停止DS1302总线
}
//从DS1302读出一字节数据
uchar ds1302_read_byte(uchar addr) {
uchar i,temp;
RST=1; //启动DS1302总线
//写入目标地址:addr
addr = addr | 0x01; //最低位置高,寄存器0位为0时写,为1时读
for (i = 0; i < 8; i ++) {
if (addr & 0x01) {
IO=1;
}
else {
IO=0;
}
SCK=1;
SCK=0;
addr = addr >> 1;
}
//输出数据:temp
for (i = 0; i < 8; i ++) {
temp = temp >> 1;
if (IO) {
temp |= 0x80;
}
else {
temp &= 0x7F;
}
SCK=1;
SCK=0;
}
RST=0; //停止DS1302总线
return temp;
}
//向DS302写入时钟数据
void ds1302_write_time(void)
{
ds1302_write_byte(ds1302_control_add,0x00); //关闭写保护
ds1302_write_byte(ds1302_sec_add,0x80); //暂停时钟
//ds1302_write_byte(ds1302_charger_add,0xa9); //涓流充电
ds1302_write_byte(ds1302_year_add,time_buf[1]); //年
ds1302_write_byte(ds1302_month_add,time_buf[2]); //月
ds1302_write_byte(ds1302_date_add,time_buf[3]); //日
ds1302_write_byte(ds1302_hr_add,time_buf[4]); //时
ds1302_write_byte(ds1302_min_add,time_buf[5]); //分
ds1302_write_byte(ds1302_sec_add,time_buf[6]); //秒
ds1302_write_byte(ds1302_day_add,time_buf[7]); //周
ds1302_write_byte(ds1302_control_add,0x80); //打开写保护
}
//从DS302读出时钟数据
void ds1302_read_time(void)
{
time_buf[1]=ds1302_read_byte(ds1302_year_add); //年
time_buf[2]=ds1302_read_byte(ds1302_month_add); //月
time_buf[3]=ds1302_read_byte(ds1302_date_add); //日
time_buf[4]=ds1302_read_byte(ds1302_hr_add); //时
time_buf[5]=ds1302_read_byte(ds1302_min_add); //分
time_buf[6]=(ds1302_read_byte(ds1302_sec_add))&0x7f;//秒,屏蔽秒的第7位,避免超出59
time_buf[7]=ds1302_read_byte(ds1302_day_add); //周
}
//主函数
void main(void)
{
char i;
bit temp;
Delay_xms(50);//等待系统稳定
ds1302_init(); //DS1302初始化
Delay_xms(10);
ds1302_write_time(); //写入初始值
while(1)
{
ds1302_read_time(); //读取时间
readtime[0]=(time_buf[0]>>4); //分离出年千位
readtime[1]=(time_buf[0]&0x0F); //分离出年百位
readtime[2]=(time_buf[1]>>4); //分离出年十位
readtime[3]=(time_buf[1]&0x0F); //分离出年个位
readtime[4]=(time_buf[2]>>4); //分离出月十位
readtime[5]=(time_buf[2]&0x0F); //分离出月个位
readtime[6]=(time_buf[3]>>4); //分离出日十位
readtime[7]=(time_buf[3]&0x0F); //分离出日个位
readtime[8]=(time_buf[4]>>4); //分离出小时十位
readtime[9]=(time_buf[4]&0x0F); //分离出小时个位
readtime[10]=(time_buf[5]>>4); //分离出分钟十位
readtime[11]=(time_buf[5]&0x0F); //分离出分钟个位
readtime[12]=(time_buf[6]>>4); //分离出秒钟十位
readtime[13]=(time_buf[6]&0x0F); //分离出秒钟个位
if(readtime[13]!=sec_buf);
//显示小时
X1=0;X2=1;X3=1;X4=1;X5=1;X6=1; N1=1;N2=1;N3=1;N4=1;N5=1;N6=1;N7=1;N8=1;
for(i=0;i<=7;i++)
{
CLK=0;
temp=(bit)(_crol_(led_mod[readtime[8]],i)&0x80);
AB=temp;
CLK=1;
}
Delay_xms(55);
X1=1;X2=0;X3=1;X4=1;X5=1;X6=1; N1=1;N2=1;N3=1;N4=1;N5=1;N6=1;N7=1;N8=1;
for(i=0;i<=7;i++)
{
CLK=0;
temp=(bit)(_crol_(led_mod[readtime[9]],i)&0x80);
AB=temp;
CLK=1;
}
Delay_xms(55);
//显示分钟
X1=1;X2=1;X3=0;X4=1;X5=1;X6=1; N1=1;N2=1;N3=1;N4=1;N5=1;N6=1;N7=1;N8=1;
for(i=0;i<=7;i++)
{
CLK=0;
temp=(bit)(_crol_(led_mod[readtime[10]],i)&0x80);
AB=temp;
CLK=1;
}
Delay_xms(10);
X1=1;X2=1;X3=1;X4=0;X5=1;X6=1; N1=1;N2=1;N3=1;N4=1;N5=1;N6=1;N7=1;N8=1;
for(i=0;i<=7;i++)
{
CLK=0;
temp=(bit)(_crol_(led_mod[readtime[11]],i)&0x80);
AB=temp;
CLK=1;
}
Delay_xms(10);
//小时秒
X1=1;X2=1;X3=1;X4=1;X5=0;X6=1
3=1; N1=1;N2=1;N3=1;N4=1;N5=1;N6=1;N7=1;N8=1;
for(i=0;i<=7;i++)
{
CLK=0;
temp=(bit)(_crol_(led_mod[readtime[12]],i)&0x80);
AB=temp;
CLK=1;
}
Delay_xms(10);
X1=1;X2=1;X3=1;X4=1;X5=1;X6=0; N1=1;N2=1;N3=1;N4=1;N5=1;N6=1;N7=1;N8=1;
for(i=0;i<=7;i++)
{
CLK=0;
temp=(bit)(_crol_(led_mod[readtime[13]],i)&0x80);
AB=temp;
CLK=1;
}
Delay_xms(10);
//显示年
X1=1;X2=1;X3=1;X4=1;X5=1;X6=1; N1=0;N2=1;N3=1;N4=1;N5=1;N6=1;N7=1;N8=1;
for(i=0;i<=7;i++)
{
CLK=0;
temp=(bit)(_crol_(led_mod[readtime[0]],i)&0x80);
AB=temp;
CLK=1;
}
Delay_xms(10);
X1=1;X2=1;X3=1;X4=1;X5=1;X6=1; N1=1;N2=0;N3=1;N4=1;N5=1;N6=1;N7=1;N8=1;
for(i=0;i<=7;i++)
{
CLK=0;
temp=(bit)(_crol_(led_mod[readtime[1]],i)&0x80);
AB=temp;
CLK=1;
}
Delay_xms(10);
X1=1;X2=1;X3=1;X4=1;X5=1;X6=1; N1=1;N2=1;N3=0;N4=1;N5=1;N6=1;N7=1;N8=1;
for(i=0;i<=7;i++)
{
CLK=0;
temp=(bit)(_crol_(led_mod[readtime[2]],i)&0x80);
AB=temp;
CLK=1;
}
Delay_xms(10);
X1=1;X2=1;X3=1;X4=1;X5=1;X6=1; N1=1;N2=1;N3=1;N4=0;N5=1;N6=1;N7=1;N8=1;
for(i=0;i<=7;i++)
{
CLK=0;
temp=(bit)(_crol_(led_mod[readtime[3]],i)&0x80);
AB=temp;
CLK=1;
}
Delay_xms(10);
//显示月份
X1=1;X2=1;X3=1;X4=1;X5=1;X6=1; N1=1;N2=1;N3=1;N4=1;N5=0;N6=1;N7=1;N8=1;
for(i=0;i<=7;i++)
{
CLK=0;
temp=(bit)(_crol_(led_mod[readtime[4]],i)&0x80);
AB=temp;
CLK=1;
}
Delay_xms(10);
X1=1;X2=1;X3=1;X4=1;X5=1;X6=1; N1=1;N2=1;N3=1;N4=1;N5=1;N6=0;N7=1;N8=1;
for(i=0;i<=7;i++)
{
CLK=0;
temp=(bit)(_crol_(led_mod[readtime[5]],i)&0x80);
AB=temp;
CLK=1;
}
Delay_xms(10);
//显示天数
X1=1;X2=1;X3=1;X4=1;X5=1;X6=1; N1=1;N2=1;N3=1;N4=1;N5=1;N6=1;N7=0;N8=1;
for(i=0;i<=7;i++)
{
CLK=0;
temp=(bit)(_crol_(led_mod[readtime[6]],i)&0x80);
AB=temp;
CLK=1;
}
Delay_xms(10);
X1=1;X2=1;X3=1;X4=1;X5=1;X6=1; N1=1;N2=1;N3=1;N4=1;N5=1;N6=1;N7=1;N8=0;
for(i=0;i<=7;i++)
{
CLK=0;
temp=(bit)(_crol_(led_mod[readtime[7]],i)&0x80);
AB=temp;
CLK=1;
}
Delay_xms(10);
}
}
谢谢!
file:///C:UserssweetheartAppDataRoamingTencentUsers376355685QQWinTempRichOleWU4M3$]ZSQ0{N~@}9RPAAJN.jpg
1.jpg (86.21 KB, 下载次数: 0)
模拟2.jpg (14.5 KB, 下载次数: 0)
使用的原件3.jpg (127.5 KB, 下载次数: 0)
4.jpg (61.96 KB, 下载次数: 0)
5.jpg (58.03 KB, 下载次数: 0)
一周热门 更多>