44.基于51单片机的万年历设计(仿真+实物)

44.基于51单片机的万年历设计(仿真+实物)

44.基于51单片机的万年历设计(仿真+实物)

一、设计任务:

本设计由数据显示模块、温度采集模块、时间处理模块和调整设置模块四个模块组成。系统以AT89S52单片机为控制器,以串行时钟日历芯片DS1302记录日历和时间,它可以对年、月、日、时、分、秒进行计时,还具有闰年补偿等多种功能。温度采集选用DS18B20芯片,万年历采用直观的数字显示,数据显示采用1602A液晶显示模块,可以在LCD上同时显示年、月、日、星期、时、分、秒,还具有时间校准等功能。此万年历具有读取方便、显示直观、功能多样、电路简洁、成本低廉等诸多优点,具有广阔的市场前景。

二、设计要求:

(1)用4个按键实现所有功能,计时准确。

(2)可以设定闹钟功能。

(3)有阴历功能,平年闰年准确无误。

(4)液晶能显示年、月、日、星期、时、分、秒、温度。

资料包括:

image.png

原理图:

image.png

仿真图:

image.png

实物图:

image.png

程序运行图:

image.png

efine uchar unsigned char
#define wd 1				//定义 是否有温度功能  =0时无温度,=1时有温度
#include "eeprom52.h"

#define yh 0x80 //LCD第一行的初始位置,因为LCD1602字符地址首位D7恒定为1(100000000=80)
#define er 0x80+0x40 //LCD第二行初始位置(因为第二行第一个字符位置地址是0x40)

//液晶屏的与C51之间的引脚连接定义(显示数据线接C51的P0口)
sbit en=P2^7;
sbit rw=P2^6;   //如果硬件上rw接地,就不用写这句和后面的rw=0了
sbit rs=P2^5;


//校时按键与C51的引脚连接定义

sbit set=P3^0;  	//设置键
sbit add=P3^1;  	//加键
sbit dec=P3^2;  	//减键
sbit seeNL_NZ=P3^3;	//查看农历/闹钟

sbit DQ=P3^7;		//
sbit buzzer=P2^0;	//蜂鸣器,通过三极管8550驱动,端口低电平响

sbit led=P2^4; 		//LCD背光开关
bit  led1=1;
bit NZ_sdgb=1;
unsigned char temp_miao;
unsigned char bltime;  //背光亮的时间

//DS1302时钟芯片与C51之间的引脚连接定义
sbit DSIO=P1^1;
sbit SCLK=P1^0;
sbit RST=P1^2;

char a,miao,shi,fen,ri,yue,week,setn,nian;
int temp;
uint flag;
//flag用于读取头文件中的温度值,和显示温度值
bit c_moon;

char nz_shi,nz_fen,setNZn;    	//定义闹钟变量
uchar shangyimiao,bsn,temp_hour;			//记录上一秒时间
uchar T_NL_NZ;							//计数器
bit timerOn=0;							//闹钟启用标志位
bit baoshi=0;							//整点报时标志位
bit  p_r=0;		 						//平年/润年  =0表示平年,=1表示润年
data uchar year_moon,month_moon,day_moon;

sbit ACC0=ACC^0;
sbit ACC7=ACC^7;
/************************************************************
ACC累加器=A
ACC.0=E0H 

ACC.0就是ACC的第0位。Acc可以位寻址。

累加器ACC是一个8位的存储单元,是用来放数据的。但是,这个存储单元有其特殊的地位,
是单片机中一个非常关键的单元,很多运算都要通过ACC来进行。以后在学习指令时,
常用A来表示累加器。但有一些地方例外,比如在PUSH指令中,就必须用ACC这样的名字。
一般的说法,A代表了累加器中的内容、而ACC代表的是累加器的地址。 
***************************************************************/

/******************把数据保存到单片机内部eeprom中******************/
void write_eeprom()
{
	SectorErase(0x2000);
	byte_write(0x2000, nz_shi);
	byte_write(0x2001, nz_fen);
	byte_write(0x2002, timerOn);
	byte_write(0x2060, a_a);	
}

/******************把数据从单片机内部eeprom中读出来*****************/
void read_eeprom()
{
	nz_shi   = byte_read(0x2000);
	nz_fen = byte_read(0x2001);
	timerOn = byte_read(0x2002);
	a_a      = byte_read(0x2060);
}

/**************开机自检eeprom初始化*****************/
void init_eeprom() 
{
	read_eeprom();		//先读
	if(a_a != 1)		//新的单片机初始单片机内问eeprom
	{
		nz_shi   = 12;
		nz_fen = 30;
		timerOn=0;
		a_a = 1;
		write_eeprom();	   //保存数据
	}	
}

//********阳历转换阴历表************************************
code uchar year_code[597]={
                    0x04,0xAe,0x53,    //1901 0
                    0x0A,0x57,0x48,    //1902 3
                    0x55,0x26,0xBd,    //1903 6
                    0x0d,0x26,0x50,    //1904 9
                    0x0d,0x95,0x44,    //1905 12
                    0x46,0xAA,0xB9,    //1906 15
                    0x05,0x6A,0x4d,    //1907 18
                    0x09,0xAd,0x42,    //1908 21
                    0x24,0xAe,0xB6,    //1909
                    0x04,0xAe,0x4A,    //1910
                    0x6A,0x4d,0xBe,    //1911
                    0x0A,0x4d,0x52,    //1912
                    0x0d,0x25,0x46,    //1913
                    0x5d,0x52,0xBA,    //1914
                    0x0B,0x54,0x4e,    //1915
                    0x0d,0x6A,0x43,    //1916
                    0x29,0x6d,0x37,    //1917
                    0x09,0x5B,0x4B,    //1918
                    0x74,0x9B,0xC1,    //1919
                    0x04,0x97,0x54,    //1920
                    0x0A,0x4B,0x48,    //1921
                    0x5B,0x25,0xBC,    //1922
                    0x06,0xA5,0x50,    //1923
                    0x06,0xd4,0x45,    //1924
                    0x4A,0xdA,0xB8,    //1925
                    0x02,0xB6,0x4d,    //1926
                    0x09,0x57,0x42,    //1927
                    0x24,0x97,0xB7,    //1928
                    0x04,0x97,0x4A,    //1929
                    0x66,0x4B,0x3e,    //1930
                    0x0d,0x4A,0x51,    //1931
                    0x0e,0xA5,0x46,    //1932
                    0x56,0xd4,0xBA,    //1933
                    0x05,0xAd,0x4e,    //1934
                    0x02,0xB6,0x44,    //1935
                    0x39,0x37,0x38,    //1936
                    0x09,0x2e,0x4B,    //1937
                    0x7C,0x96,0xBf,    //1938
                    0x0C,0x95,0x53,    //1939
                    0x0d,0x4A,0x48,    //1940
                    0x6d,0xA5,0x3B,    //1941
                    0x0B,0x55,0x4f,    //1942
                    0x05,0x6A,0x45,    //1943
                    0x4A,0xAd,0xB9,    //1944
                    0x02,0x5d,0x4d,    //1945
                    0x09,0x2d,0x42,    //1946
                    0x2C,0x95,0xB6,    //1947
                    0x0A,0x95,0x4A,    //1948
                    0x7B,0x4A,0xBd,    //1949
                    0x06,0xCA,0x51,    //1950
                    0x0B,0x55,0x46,    //1951
                    0x55,0x5A,0xBB,    //1952
                    0x04,0xdA,0x4e,    //1953
                    0x0A,0x5B,0x43,    //1954
                    0x35,0x2B,0xB8,    //1955
                    0x05,0x2B,0x4C,    //1956
                    0x8A,0x95,0x3f,    //1957
                    0x0e,0x95,0x52,    //1958
                    0x06,0xAA,0x48,    //1959
                    0x7A,0xd5,0x3C,    //1960
                    0x0A,0xB5,0x4f,    //1961
                    0x04,0xB6,0x45,    //1962
                    0x4A,0x57,0x39,    //1963
                    0x0A,0x57,0x4d,    //1964
                    0x05,0x26,0x42,    //1965
                    0x3e,0x93,0x35,    //1966
                    0x0d,0x95,0x49,    //1967
                    0x75,0xAA,0xBe,    //1968
                    0x05,0x6A,0x51,    //1969
                    0x09,0x6d,0x46,    //1970
                    0x54,0xAe,0xBB,    //1971
                    0x04,0xAd,0x4f,    //1972
                    0x0A,0x4d,0x43,    //1973
                    0x4d,0x26,0xB7,    //1974
                    0x0d,0x25,0x4B,    //1975
                    0x8d,0x52,0xBf,    //1976
                    0x0B,0x54,0x52,    //1977
                    0x0B,0x6A,0x47,    //1978
                    0x69,0x6d,0x3C,    //1979
                    0x09,0x5B,0x50,    //1980
                    0x04,0x9B,0x45,    //1981

  • 10
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: DHT11温湿度检测器是一款常见的温湿度传感器,可以用于测量环境中的温度和湿度。基于51单片机的Proteus仿真代码是指通过使用51单片机(一种微控制器)和Proteus(一种电路仿真软件)来模拟DHT11温湿度检测器的工作原理和功能。 在Proteus中仿真DHT11温湿度检测器,首先需要将51单片机与DHT11传感器进行连接。通常,DHT11传感器具有三个引脚:VCC、DATA和GND。其中,VCC用于供电,DATA用于数据传输,GND用于接地。将这些引脚与51单片机的相应引脚进行连接。 接下来,需要编写51单片机的代码,使其能够通过DATA引脚与DHT11传感器进行通信,并读取温湿度信息。具体的代码实现可以使用C语言来编写。代码的主要思路是通过51单片机发送特定的信号给DHT11传感器,并读取传感器返回的温湿度数据。 在代码中,需要定义相应的引脚和变量,以及编写相关的函数,如发送信号函数、读取数据函数等。这些函数将帮助实现与DHT11传感器的通信,并将获取的温湿度数据存储到变量中。 最后,在Proteus中运行该代码,并观察仿真结果。可以通过监测51单片机输出的温湿度数据是否正确来验证代码的正确性。如果仿真结果符合预期,则说明基于51单片机的Proteus仿真代码成功模拟了DHT11温湿度检测器的工作原理和功能。 总而言之,基于51单片机的Proteus仿真代码可以通过在Proteus中连接DHT11传感器并编写相应的代码来模拟DHT11温湿度检测器的工作原理和功能,并通过观察仿真结果来验证代码的正确性。 ### 回答2: DHT11温湿度检测器是一种常见的传感器,用于测量周围环境的温度和湿度。在基于51单片机的Proteus仿真中,我们可以通过编写相应的代码来模拟这个过程。 首先,我们需要添加51单片机和DHT11传感器模块到Proteus的电路设计中。然后,我们可以开始编写代码。 首先,我们需要定义引脚的连接关系,即将数据线连接到51单片机的相应引脚上。通过查询DHT11的规格手册,我们可以确定数据线连接到单片机的哪个引脚上。 接下来,我们可以编写主程序来获取温湿度数据。程序首先需要对DHT11进行初始化,然后通过发送开始信号来触发温湿度测量。然后,程序读取传感器发送的数据,解析温度和湿度数值。最后,将获取的温湿度数据显示出来。 在编程过程中,我们需要使用51单片机的相应的端口设置输入和输出,并使用基本的串行通信协议(如UART)来与DHT11传感器进行通信。 在Proteus仿真中,我们可以通过编写代码并连接相应的电路组件来模拟整个过程。我们可以进行仿真运行,并观察在仿真界面上显示的温湿度数值,以验证代码的正确性。 综上所述,基于51单片机的Proteus仿真中,可以通过编写相应的代码来模拟DHT11温湿度检测器的工作过程。使用合适的引脚连接和相应的数据交互协议,我们可以获取并显示温湿度数据。 ### 回答3: DHT11温湿度检测器是一款常用的温湿度传感器,可用于测量周围环境的温度和湿度。在这个仿真实验中,我们采用Proteus软件来模拟51单片机的工作,并使用DHT11传感器来实时测量温湿度。 首先,我们需要在Proteus中搭建51单片机仿真环境。选择一个适合的51单片机模型,并连接相应的外部晶振和电源电压。然后,在引脚配置中将DHT11的数据引脚连接到51单片机的某一个IO口上。 接下来,我们需要编写51单片机的代码。首先,定义相应的宏和引入头文件,如下所示: #include <reg51.h> #define DHT11_IO P1 然后,我们需要编写相应的函数来控制DHT11传感器。首先是发送开始信号的函数: void send_start_signal() { DHT11_IO = 0; // 将数据引脚置低 delay_ms(18); // 延时18ms DHT11_IO = 1; // 将数据引脚置高 delay_us(30); // 延时30us while(DHT11_IO); // 等待DHT11响应 while(!DHT11_IO); // 等待DHT11开始信号 } 然后是读取传感器数据的函数: unsigned char read_data() { unsigned char i, j, data = 0; for(i = 0; i < 8; i++) { while(!DHT11_IO); // 等待数据位开始 delay_us(40); // 延时40us if(DHT11_IO) { j = 1; while(DHT11_IO); // 等待1的结束 } else { j = 0; while(!DHT11_IO); // 等待0的结束 } data = (data << 1) | j; // 将数据添加到data变量中 } return data; } 最后,我们需要在主函数中调用相应的函数来实现温湿度的测量。首先发送开始信号,然后读取湿度和温度数据,并将其保存到相应的变量中,如下所示: void main() { unsigned char temp, humi; send_start_signal(); // 发送开始信号 humi = read_data(); // 读取湿度数据 temp = read_data(); // 读取温度数据 // 在这里可以对温湿度数据进行处理和显示 } 通过上述代码,我们可以实现在Proteus中对DHT11温湿度检测器进行仿真。当仿真运行时,可以通过读取温湿度数据,并进行相应的处理和显示。这样,我们就可以仿真出DHT11温湿度检测器的基于51单片机的工作原理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值