92-基于stm32单片机智能家居智能窗帘控制系统Proteus仿真+程序源码

STM32单片机驱动的智能窗帘控制系统设计与实现
本文介绍了基于STM32单片机的智能窗帘控制系统,包括硬件组成、手动/自动模式控制、光照感应及LCD1602显示功能。还提供了Proteus仿真、C语言编程和程序源码的详细教程。

一:功能介绍

1、采用stm32单片机+LCD1602+DHT11温湿度传感器+DS1302传感器+光敏电阻+按键+电机,制作一个智能窗帘控制系统;

2、通过按键设置手动和自动模式,并且手动模式下可以通过按键控制窗帘打开和关闭;

3、自动模式下,可以通过光照强度来自动控制窗帘,当光照过低,自动关闭窗帘(夜晚);反之则打开窗帘(白天);

4、LCD1602显示ds1302时钟的时间和采集的温湿度、光照强度、以及当前的控制状态(自动或者手动);

二:仿真演示视频+程序简要讲解:(程序有中文注释,新手容易看懂)

92-基于stm32单片机智能家居智能窗帘控制系统Proteus仿真+程序源码+讲解视频

三:设计软件介绍

本设计使用C语言编程设计,程序代码采用keil5编写,程序有中文注释,新手容易看懂,仿真采用Proteus软件进行仿真演示视频使用的是Proteus8.9版本;资料包里有相关软件包,可自行下载安装。

四:程序打开方法

特别注意:下载资料包以后一定要先解压!(建议解压到桌面上,文件路径太深会导致程序打开异常),解压后再用keil5打开。

52f1630451943ae3bbd3f0b95844abca.png

c11d461ccd01bbc6f1132b9843b20d4a.png

程序部分展示,有中文注释,新手容易看懂
//IO口操作,只对单一的IO口!
//确保n的值小于16!
#define PAout(n)   BIT_ADDR(GPIOA_ODR_Addr,n)  //输出 
#define PAin(n)    BIT_ADDR(GPIOA_IDR_Addr,n)  //输入 


#define PBout(n)   BIT_ADDR(GPIOB_ODR_Addr,n)  //输出 
#define PBin(n)    BIT_ADDR(GPIOB_IDR_Addr,n)  //输入 


#define PCout(n)   BIT_ADDR(GPIOC_ODR_Addr,n)  //输出 
#define PCin(n)    BIT_ADDR(GPIOC_IDR_Addr,n)  //输入 


#define PDout(n)   BIT_ADDR(GPIOD_ODR_Addr,n)  //输出 
#define PDin(n)    BIT_ADDR(GPIOD_IDR_Addr,n)  //输入 


#define PEout(n)   BIT_ADDR(GPIOE_ODR_Addr,n)  //输出 
#define PEin(n)    BIT_ADDR(GPIOE_IDR_Addr,n)  //输入


#define PFout(n)   BIT_ADDR(GPIOF_ODR_Addr,n)  //输出 
#define PFin(n)    BIT_ADDR(GPIOF_IDR_Addr,n)  //输入


#define PGout(n)   BIT_ADDR(GPIOG_ODR_Addr,n)  //输出 
#define PGin(n)    BIT_ADDR(GPIOG_IDR_Addr,n)  //输入


char buf=1,buf1=0;//buf是手动自动状态1:自动  0:手动     buf1是手动打开和关闭的状态  0:打开  1:关闭


//毫秒级的延时
void delay_ms(u16 time)
{    
   u16 i=0;  
   while(time--)
   {
      i=800;  //自己定义
      while(i--) ;    
   }
}








/*****************DHT11********************/
extern void DHT11_receive( int *h, int *t);
/*****************引脚配置********************/
void GPIO_Configuration(void)
{
  GPIO_InitTypeDef GPIO_InitStructure;
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOB| RCC_APB2Periph_GPIOC| RCC_APB2Periph_GPIOC,ENABLE);
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE);
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1,ENABLE);
  //LCD1602 管脚      
  GPIO_InitStructure.GPIO_Pin =  GPIO_Pin_8| GPIO_Pin_9| GPIO_Pin_10| GPIO_Pin_11| GPIO_Pin_12| GPIO_Pin_13| GPIO_Pin_14| GPIO_Pin_15;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_2MHz;  
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_OD;
  GPIO_Init(GPIOA, &GPIO_InitStructure);
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8 |GPIO_Pin_9|GPIO_Pin_10;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_2MHz;  
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  GPIO_Init(GPIOB, &GPIO_InitStructure);      
  //DHT11 
  GPIO_InitStructure.GPIO_Pin =  GPIO_Pin_15;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_2MHz;  
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_OD;
  GPIO_Init(GPIOB, &GPIO_InitStructure);  
  //按键
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0| GPIO_Pin_1| GPIO_Pin_2| GPIO_Pin_3| GPIO_Pin_4| GPIO_Pin_5;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_2MHz;  
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;;
  GPIO_Init(GPIOB, &GPIO_InitStructure);  
  //配置 PA0 ADC采集模式    
  GPIO_InitStructure.GPIO_Pin =  GPIO_Pin_0;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN; 
  GPIO_Init(GPIOA, &GPIO_InitStructure);
  //电机
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_14|GPIO_Pin_6;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;  
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
  GPIO_Init(GPIOB, &GPIO_InitStructure);  


}
/* ADC配置 */
void ADC_Set(void)
{
  ADC_InitTypeDef ADC_InitStructure;//ADC结构体变量//注意在一个语句快内变量的声明要放在可执行语句的前面,否则出错,因此要放在ADC1_GPIO_Config();前面
  ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;//ADC1和ADC2工作在独立模式
  ADC_InitStructure.ADC_ScanConvMode =        DISABLE; //使能扫描
  ADC_InitStructure.ADC_ContinuousConvMode = ENABLE;//ADC转换工作在连续模式
  ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;//由软件控制转换,不使用外部触发
  ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;//转换数据右对齐
  ADC_InitStructure.ADC_NbrOfChannel = 1;//转换通道为1
  ADC_Init(ADC1, &ADC_InitStructure); //初始化ADC   
  ADC_RegularChannelConfig(ADC1, ADC_Channel_0, 1, ADC_SampleTime_28Cycles5);
  ADC_Cmd(ADC1, ENABLE);//使能ADC1
  ADC_SoftwareStartConvCmd(ADC1, ENABLE);
}


int  wendu,shidu,guangqiang;      //保存温度     湿度     光强
int  xiaoshi=70,fenzhong=20;// 湿度设定 光强设定
u8 time_data[8];//保存时间的数组   


int nian=12,yue=34,ri=56;//保存年 月 日 
int shi=12,fen=34,miao=56;//保存 
//这里对按键进行扫描

:仿真文件(采用Proteus打开)

6e4ff3372ff1dc7c56ac8d5e4ac8a880.png

0b3721153953a79e8f67cff3f5546c74.png

9d2d74e1105f78001c354c685e22e232.png

六:资料清单展示(文件中包含的相关资料)

bbfd7ae7d3531af187a57b3cc1712afe.png

百度云盘资料下载链接

### 基于STM32单片机智能家居控制系统Proteus仿真教程 #### 设计概述 在智能家居控制系统的设计中,使用了STM32作为核心控制器[^3]。该系统能够实现多种功能,包括但不限于通过串口接收指令并执行相应操作,如控制灯光和空调等设备的状态变化。 #### 软硬件准备 - **开发工具**: Keil5用于编写程序代码,并且支持中文注释以便初学者理解[^1]。 - **仿真平台**: 使用Proteus软件进行电路原理图绘制及逻辑验证工作。特别指出,在不同版本之间可能存在兼容性差异,因此建议按照具体项目需求选用合适的版本号,比如提到过的8.9或8.11版。 #### 功能描述 此案例展示了如何利用虚拟串口技术连接PC端与嵌入式目标板之间的通讯接口,从而允许用户通过命令行形式向MCU发送特定编码的消息字符串来触发预定义的动作序列。例如,“1”代表开启第一个房间内的照明设施;而“4”则用来启动模拟为空调装置的服务电机运转。 ```c printf("\r\n这是一个简单的智能家居仿真模拟\r\n"); printf("使用USART参数为:%d 8-N-1 \r\n", DEBUG_USART_BAUDRATE); // 输出可用指令列表供测试人员参照输入 ``` 上述代码片段来自实际应用场合下的初始化过程部分,它不仅设置了调试用异步收发器的工作模式(即波特率、字符长度),还打印了一条欢迎信息连同一系列可供选择的操作指南给终端用户查看。 #### 控制机制 对于更复杂的场景而言,则可能涉及到多模态交互手段的应用——除了基本的文字型API之外,还有图形化UI界面的支持选项。以智能窗帘为例,其提供了三种不同的调控途径:一是经由手机APP远程下达指示;二是依靠本地物理按钮即时响应;三是依据环境条件自主判断何时展开/收缩遮阳帘布料[^4]。 #### 数据展示 为了提高用户体验感,往往还会配备一块小型液晶屏实时反馈当前各项指标数值以及最近一次动作的结果摘要。像下面这样: ![OLED Display](https://example.com/oled_display.png) 请注意这里仅作为一个示意性的插图位置预留说明,并无真实的图片链接指向[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值