一、基本介绍
项目名:
基于单片机的车内环境监测系统设计
项目名:车内环境监测
单片机类型:STM32F103C8T6
具体功能:
1、通过DHT11检测温湿度
2、通过MQ-135检测有害气体浓度
3、通过人体热释电检测是否有人,如果有人,若有害气体浓度大于设置最大值,则声光报警,并自动开启通风系统
4、通过按键设置有害气浓度最大值、手动控制通风
5、通过显示屏显示测量数据
扩展功能:通过蓝牙,将数据发送到手机端,并可远程控制通风
二、资料总览
实物资料
仿真资料
三、51单片机部分资料展示
1、实物图展示
单片机型号:STC89C52
供电接口:TYPE-C
板子类型:PCB集成板,厚度1.2,两层板(上下层覆铜接地)
器件类型:元器件基本上为插针式,个别降压芯片会使用贴片式。
2、仿真图展示
仿真软件版本:proteus8.9
电路连线方式:网络标号连线方式
注意:部分实物元器件仿真中没有,仿真中会用其他工作原理相似的元件代替,这样可能导致实物程序和仿真程序不一样
3、原理图展示
软件版本:AD2013
电路连线方式:网络标号连线方式
注意:原理图只是画出了模块的引脚图,而并不是模块的内部结构图
4、PCB图展示
由原理图导出,中间有一个项目编号,隐藏在单片机底座下,插入单片机后不会看到。
两层板,上下覆铜接地。
四、32单片机部分资料展示
1、实物图展示
单片机型号:STM32F103C8T6
供电接口:TYPE-C
板子类型:PCB集成板,厚度1.2,两层板(上下层覆铜接地)
器件类型:元器件基本上为插针式,个别降压芯片会使用贴片式。
2、原理图展示
软件版本:AD2013
电路连线方式:网络标号连线方式
注意:原理图只是画出了模块的引脚图,而并不是模块的内部结构原理图
3、PCB图展示
由原理图导出,中间有一个项目编号,隐藏在单片机底座下,插入单片机后不会看到。
两层板,上下覆铜接地。
五、系统框图
绘制软件:VISIO
本设计以单片机为核心控制器,加上其他模块一起组成此次设计的整个系统,其中包括中控部分、输入部分和输出部分。中控部分采用了单片机控制器,其主要作用是获取输入部分的数据,经过内部处理,逻辑判断,最终控制输出部分。输入由五部分组成,第一部分是温湿度检测模块,通过该模块检测当前环境的温湿度;第二部分是(氨气、苯)空气质量检测模块,通过该模块可以检测当前环境中的氨气和苯浓度;第三部分是人体热释电检测模块,通过该模块可以检测当前车内是否有人;第四部分是按键模块,通过该模块可以切换界面、设置阈值、等;第五部分是供电模块,通过该模块可给整个系统进行供电。输出由三部分组成,第一部分是显示模块,通过该模块可以显示监测的数据以及设置的阈值;第二部分是继电器模块,检测到车内有人,且检测到车内有害气体浓度大于设置的最大值进行声光报警子哦对那个打开通风继电器。除此之外,蓝牙模块既作为输入又作为输出,蓝牙模块和手机进行连接,可以将监测的数据传输到用户手机端,用户也可以通过手机端发送指令控制继电器的工作及其模式的切换。具体系统框图如图3.1所示。
六、部分程序展示
软件版本:keil5
注意:逻辑程序和驱动程序分开,分布于main.c和其他.c文件
*******监测函数
*****/
void Monitor_function(void)
{
char fasong[32];
if(flag_display == 0) //测量界面
{
if(time_num % 2 == 0) //约400ms检测一次
{
Dht11_Get_Temp_Humi_Value(&temp_value ,&humi_value ); //获取温湿度
if(DO == 0)
gas_value = 60*((Get_Adc_Average(0,1)/4096.0)*3.3); //获取有害气体值
else
gas_value = 0;
}
}
if(time_num % 15 == 0) //约3s发送一次
{
sprintf(fasong,"温度:%d.%d℃\r\n",temp_value/10,temp_value%10);
UsartPrintf(USART1,fasong);
sprintf(fasong,"湿度:%d.%d%%%%\r\n",humi_value/10,humi_value%10);
UsartPrintf(USART1,fasong);
sprintf(fasong,"有害气体:%dppm\r\n",gas_value);
UsartPrintf(USART1,fasong);
}
if(USART1_WaitRecive() == 0)
{
if(strstr((char*)usart1_buf,"A") != NULL) //切换自动模式
{
flag_mode = 0;
}
else if(strstr((char*)usart1_buf,"B") != NULL) //通风继电器控制
{
RELAY_TF =~RELAY_TF;
flag_mode = 1;
}
USART1_Clear();
}
}
/****
*******显示函数
*****/
void Display_function(void)
{
switch(flag_display) //根据不同的显示模式标志位,显示不同的界面
{
case 0: //界面0:测量界面,显示各测量值、模式
Oled_ShowCHinese(1, 0, "温度:");
sprintf(display_buf,"%d.%dC ",temp_value/10,temp_value %10);
Oled_ShowString(1, 6, display_buf);
Oled_ShowCHinese(2, 0, "湿度:");
sprintf(display_buf,"%d.%d%% ",humi_value/10,humi_value%10);
Oled_ShowString(2, 6, display_buf);
Oled_ShowCHinese(3, 0, "有害气体:");
sprintf(display_buf,"%dppm ",gas_value);
Oled_ShowString(3, 10, display_buf);
// Oled_ShowCHinese(4, 0, "模式:");
if(flag_mode == 0)
Oled_ShowCHinese(4,1,"自动");
else
Oled_ShowCHinese(4,1,"手动");
if(RELAY_TF == 1)
Oled_ShowCHinese(4,5,"打开");
else
Oled_ShowCHinese(4,5,"关闭");
break;
case 1: //界面1:显示设置有害气体最大值
Oled_ShowCHinese(1,1,"设置有害气体");
Oled_ShowCHinese(2,2,"最大值");
if(time_num % 5 == 0)
{
sprintf(display_buf,"%d ",gas_max);
Oled_ShowString(3, 6, display_buf);
}
if(time_num % 10 == 0)
{
Oled_ShowString(3, 6, " ");
}
break;
default:
break;
}
}
/****
*******处理函数
*****/
void Manage_function(void)
{
if(flag_display == 0) //测量界面
{
if(flag_mode == 0) //如果处于自动模式
{
if(gas_value > gas_max && MAN == 0) //有人且有害气体大于设置最大值,通风继电器闭合、并声光报警
{
RELAY_TF = 1;
if(time_num % 2 == 0)
{
LED = ~LED;
BEEP = ~BEEP;
}
}
else
{
RELAY_TF= 0;
LED = 1;
BEEP = 0;
}
}
else //手动模式下,关闭声光报警
{
LED = 1;
BEEP = 0;
}
}
else //设置界面,关闭所有继电器及声光报警
{
LED = 1;
BEEP = 0;
RELAY_TF = 0;
}
}