基于51单片机的万年历proteus仿真原理图方案设计

链接:https://pan.baidu.com/s/1PJ6Vc4R6mjLmKOG_VDYzZg
提取码:btlq

系统框图
在这里插入图片描述
原理图
在这里插入图片描述
仿真图
在这里插入图片描述
最小系统电路
STC89C52的最小系统如图3-3所示,整个最小系统由三个部分组成,晶振电路部分、复位电路部分、电源电路等三个部分组成。
晶振电路包括2个30pF的电容C2和C3,以及12M的晶振X1。电容的作用在这里是起振作用,帮助晶振更容易的起振,取值范围是15-33pF。晶振的取值也可以是24M,晶振的取值越高,单片机的执行速度越快。在进行电路设计的时候,晶振部分越靠近单片机越好。
单片机复位电路就好比电脑的重启部分,当电脑在使用中出现死机,按下重启按钮电脑内部的程序从头开始执行。单片机也一样,当单片机系统在运行中,受到环境干扰出现程序跑飞的时候,按下复位按钮内部的程序自动从头开始执行。
复位电路由10uF的极性电容C1和10K的电阻R4构成。利用电容电压不能突变的性质,可以知道,当系统一上电,RESET脚将会出现高电平,并且这个高电平持续的时间由电路的RC值来决定。典型的51单片机当RESET脚的高电平持续两个机器周期以上就将复位,所以适当组合RC的取值就可以保证可靠的复位。
最后一个是电源部分,采用5V的USB直接供电,可采用手机充电器、电脑USB口、移动电源等设备进行供电。
此外,除了单片机最小系统的3个部分之外,这里还多了一些外部电路。
由于STC89C52的P0口是漏极开路输出,因此在P0口接了一个10K的排阻R1,使得P0口可以作为普通的I/O口使用,本设计用P0口来做液晶的数据口。
特别注意的是,对于31脚(EA),当接高电平时,单片机在复位后从内部ROM的0000H开始执行;当接低电平时,复位后直接从外部ROM的0000H开始执行。由于我们的程序存储在了单片机内部,所以EA要接高电平,保证单片机是从内部读取程序去执行的

液晶显示电路

液晶显示器是一种显示器件,具有小体积、轻重量、低功耗等特色。由于其功耗低、显示的信息量大(例如,文本,图形,曲线等)、无电磁辐射、使用寿命长,它已被广泛应用在便携式电子产品。
本系统显示采用了工业字符型液晶模块1602,可显示2行16个字符,能方便显示英文字母大小写、阿拉伯数字、常用符号等。通过自定义还可显示简单的汉字。
本系统采用的1602是一款物美价廉的液晶显示屏,可以显示2行标准字符,每行共有16个字符。在通信系统,智能操作仪表和办公设备的自动化中被广泛的应用,主要功能是显示ASCII字符,因此被称为“字符型显示装置”。当在内部没有适合的汉字库的液晶类型显示器想要表达汉字的时候,第一步就是要获得想要的汉文或者图形的子模数据。子模块的软件不能直接提取的子模块的数据5×8点阵,可以从手工提取汉字的字体以模具。第二步,把取得的汉字子模数据保存在液晶存储器里面。

时钟模块
DS1302简介
DS1302是由美国DALLAS公司推出的具有涓细电流充电能力的低功耗实时时钟芯片。现在流行的串行时钟电路很多,如DS1302、 DS1307、PCF8485等。这些电路的接口简单、价格低廉、使用方便,被广泛地采用。
本文介绍的实时时钟电路DS1302是DALLAS公司的一种具有涓细电流充电能力的电路,主要特点是采用串行数据传输,可为掉电保护电源提供可编程的充电功能,并且可以关闭充电功能。采用普通32.768kHz晶振。是一种高性能、低功耗、带RAM的实时时钟芯片,它可以对年、月、日、周、时、分、秒进行计时,具有闰年补偿功能,工作电压为2.0V~5.5V。采用三线接口与CPU进行同步通信,并可采用突发方式一次传送多个字节的时钟信号或RAM数据。DS1302内部有一个31×8的用于临时性存放数据的RAM寄存器。DS1302是DS1202的升级产品,与DS1202兼容,但增加了主电源/后备电源双电源引脚,同时提供了对后备电源进行涓细电流充电的能力。

DS18B20传感器电路
DS18B20简介
(1)概述
DS18B20(图3-10)是美国DALLAS半导体公司推出的第一片支持“一线总线”接口的温度传感器,它具有微型化,低功耗,高性能,抗干扰能力强,易配微处理器等优点,可直接将温度转化成数字信号处理器处理。测量的温度范围是-55125℃,测温误差0.5℃。可编程分辨率912位,对应的可分辨温度分别为0.5℃,0.25℃,0.125℃和0.0625℃。相较热电偶传感器而言可实现高精度测温。

部分程序:

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

#define uchar unsigned char	// 以后unsigned char就可以用uchar代替
#define uint  unsigned int	// 以后unsigned int 就可以用uint 代替

sfr ISP_DATA  = 0xe2;				// 数据寄存器
sfr ISP_ADDRH = 0xe3;				// 地址寄存器高八位
sfr ISP_ADDRL = 0xe4;				// 地址寄存器低八位
sfr ISP_CMD   = 0xe5;				// 命令寄存器
sfr ISP_TRIG  = 0xe6;				// 命令触发寄存器
sfr ISP_CONTR = 0xe7;				// 命令寄存器

sbit LcdRs_P    = P2^7;       // 1602液晶的RS管脚       
sbit LcdRw_P    = P2^6;       // 1602液晶的RW管脚 
sbit LcdEn_P    = P2^5;       // 1602液晶的EN管脚
sbit RST_P      = P1^3;				// 时钟芯片DS1302的RST管脚
sbit SDA_P      = P1^2;				// 时钟芯片DS1302的SDA管脚
sbit SCK_P      = P1^1;				// 时钟芯片DS1302的SCK管脚
sbit KeySet_P   = P3^2;				// 设置时间按键
sbit KeyClock_P = P3^3;				// 设置闹钟按键
sbit KeyDown_P  = P3^4;				// 减按键
sbit KeyUp_P    = P3^5;				// 加按键
sbit Buzzer_P   = P2^0;				// 蜂鸣器
sbit DQ         = P1^0;				// DS18B20传感器的引脚定义


uchar TimeBuff[7]={17,9,1,6,18,30,40};				// 时间数组,默认2017年9月1日,星期五,18:30:40
// TimeBuff[0] 代表年份,范围00-99
// TimeBuff[1] 代表月份,范围1-12
// TimeBuff[2] 代表日期,范围1-31
// TimeBuff[3] 代表星期,范围1-7,1是星期天,2是星期一... ...
// TimeBuff[4] 代表小时,范围00-23
// TimeBuff[5] 代表分钟,范围00-59
// TimeBuff[6] 代表秒钟,范围00-59


uchar Clock_Hour;					// 闹钟的小时
uchar Clock_Minute;				// 闹钟的分钟
uchar Clock_Swt;					// 闹钟的开关
uchar Buzzer_Flag=0;			// 蜂鸣器工作标志



/*********************************************************/
// 单片机内部EEPROM不使能
/*********************************************************/
void ISP_Disable()
{
	ISP_CONTR = 0;
	ISP_ADDRH = 0;
	ISP_ADDRL = 0;
}


/*********************************************************/
// 从单片机内部EEPROM读一个字节,从0x2000地址开始
/*********************************************************/
unsigned char EEPROM_Read(unsigned int add)
{
	ISP_DATA  = 0x00;
	ISP_CONTR = 0x83;
	ISP_CMD   = 0x01;
	ISP_ADDRH = (unsigned char)(add>>8);
	ISP_ADDRL = (unsigned char)(add&0xff);
	// 对STC89C51系列来说,每次要写入0x46,再写入0xB9,ISP/IAP才会生效
	ISP_TRIG  = 0x46;	   
	ISP_TRIG  = 0xB9;
	_nop_();
	ISP_Disable();
	return (ISP_DATA);
}


/*********************************************************/
// 往单片机内部EEPROM写一个字节,从0x2000地址开始
/*********************************************************/

.

.

  • 24
    点赞
  • 143
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值