打印
[其他ST产品]

stm32毕设 GSM的火灾与防盗报警系统

[复制链接]
1206|19
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
这两年开始毕业设计和毕业答辩的要求和难度不断提升,传统的毕设题目缺少创新和亮点,往往达不到毕业答辩的要求,这两年不断有学弟学妹告诉学长自己做的项目系统达不到老师的要求。

为了大家能够顺利以及最少的精力通过毕设,学长分享优质毕业设计项目,今天要分享的是

2848649d0f2f676bd.png (1.11 MB )

2848649d0f2f676bd.png

使用特权

评论回复
沙发
初级工程渣|  楼主 | 2023-6-29 12:59 | 只看该作者
主要功能
主要功能:一款基于单片机的智能防火防盗报警系统,主要可以实现火灾预警、防盗报警功能,当烟雾、温度传感器被触发时,会自动触发防火报警。当人体检测传感器被触发时,会自动触发防盗报警,触发警报后,GSM模块会自动给手机发送短信。

1.使用STC89C52RC单片机做主控制器。

2.使用LCD1602显示温度、烟雾、人体触发情况。

3.使用MQ-2检测烟雾值。

4.使用DS18B20检测温度值。

5.使用HC-SR501检测人体触发情况。

6.使用SIM900A模块给手机发送短信。

7.采集值超过预设阀值后,蜂鸣器报警提示。

8.四个按键进行布防功能和阀值设置。

该设计以单片机STC89C52为核心,作为控制器件。包括硬件和软件设计两个部分。

使用特权

评论回复
板凳
初级工程渣|  楼主 | 2023-6-29 12:59 | 只看该作者
硬件部分:
采用SIM800c作为我们的GSM通信模块,LCD1602作为显示,喇叭作为报警装置。并辅之一些外围器件,用C语言控制单片机来完成防火防盗系统的设计。整个报警系统由电源、单片机控制部分、信号检测部分、通信部分以及报警装置等五部分组成

使用特权

评论回复
地板
初级工程渣|  楼主 | 2023-6-29 13:00 | 只看该作者
软件部分:
单片机作为主控芯片完成信息采集、处理、通信、显示、报警等功能。
系统设计框图如下:

使用特权

评论回复
5
初级工程渣|  楼主 | 2023-6-29 13:01 | 只看该作者
硬件设计(原理图)

使用特权

评论回复
6
初级工程渣|  楼主 | 2023-6-29 13:01 | 只看该作者

使用特权

评论回复
7
初级工程渣|  楼主 | 2023-6-29 13:02 | 只看该作者
核心软件设计

使用特权

评论回复
8
初级工程渣|  楼主 | 2023-6-29 13:02 | 只看该作者
关键代码
#include<reg52.h>
#include<intrins.h>
#include "sim800.h"       
#define uchar unsigned char
#define uint  unsigned int
#define K_MG_MV    120/66
typedef unsigned char  U8;       /* defined for unsigned 8-bits integer variable           无符号8位整型变量  */
typedef unsigned int   U16;      /* defined for unsigned 16-bits integer variable           无符号16位整型变量 */

/********测试GSM是否启动**********/
int test_boot;
/********测试GSM是否注册网络**********/
int test_net_register;
/********GSM串口接收数据缓存**********/
unsigned char idata GSM_receive[60];
/********GSM串口接收计数器**********/
unsigned char  GSMDATA_count;
unsigned char *content_temp =  "Warning: over temperature\r\n";
unsigned char *content_smoke = "Warning: excessive smoke concentration\r\n";
unsigned char *content_body =  "Warning: body entry\r\n";

unsigned char str_yw[12];//烟雾值
unsigned char T_baojing = 30;  //温度报警值
unsigned int  C_baojing = 500; //烟雾浓度报警值

unsigned char T_buff[3];  //报警缓存
unsigned char H_buff[3];
unsigned char C_buff[4];

bit  sf_flag=0; //设防标志
unsigned char moshi=0;
unsigned char data1;
long Value;

sbit bADcs=P3^4;
sbit bADcl=P3^6;
sbit bADda=P3^5;

sbit  sf_led = P1^3;//   设防指示灯
sbit  shefang= P1^4;//   设防按键
sbit  shezhi = P1^5; //  设置
sbit  jia    = P1^6; //         加
sbit  jian   = P1^7; //  减       
sbit  BUZZER = P2^0; //  LED蜂鸣器
sbit  Infra         = P3^2; //  人体红外模块


unsigned char IntToString(unsigned char *str, int dat);
extern bit Start18B20();
extern bit Get18B20Temp(int *temp);                                //          ;;;;;、‘      
extern void InitLcd1602();
extern void LcdShowStr(unsigned char x, unsigned char y, unsigned char *str);
float intT, decT;  //温度值的整数和小数部分


long kssj()   //开始收集
{
   unsigned char i;

     bADcs = 0;//当ADC0832未工作时其CS输入端应为高电平,此时芯片禁用.
         bADcl=0;
         bADda=1;
         bADcl=1;
         bADcl=0;//i down
         bADda=1;
         bADcl=1;
         bADcl=0;        //   2 down
         bADda=0;
         bADcl=1;
         bADcl=0;        //   3 down
         bADda=1;
         bADcl=1;
         bADcl=0;        //   4 down

         for(i=8;i>0;i--)
                 {
               
                 data1<<=1;
                 bADcl=0;
                bADcl=1;
                if(bADda==1) data1|=0x01;
                           bADda=1;
                 }
                 bADcs=1;
                
       Value=data1*1.0/256*500;
          
           Value=Value*K_MG_MV;
           Value=Value-5;
           if(Value<0)Value=0;
           return Value;
}


void Key_set_scan()
{
         
        if(shezhi==0)
        {
           Delay_Ms(10);
                if(shezhi==0)
                {  
                   while(!shezhi);
                   InitLcd1602();     //初始化液晶
                   moshi++;
                   if(moshi >= 3)moshi = 0;
                   if(moshi == 0)
                   {
                     LcdShowStr(0, 0,"T:   C");
             LcdShowStr(7, 0,"C:    PPM");
                   }
                   else if(moshi == 1)
                   {
                      LcdShowStr(0, 1,"Set_T:   C");
                   }
                   else if(moshi == 2)
                   {
                              LcdShowStr(0, 1,"Set_C:    PPM");
                   }                          
                }
        }
       
        if(jia==0)
        {
           Delay_Ms(10);
                if(jia==0)
                {        
                        if(moshi==1)
                        {
                         T_baojing++ ;
                         if( T_baojing>=99 )T_baojing =99;
                        }
                        if(moshi==2)
                        {
                         C_baojing++ ;
                         if( C_baojing>=999 )C_baojing =999;
                        }               
                 }
         }
         if(jian == 0)
         {
            Delay_Ms(10);
           if(jian == 0)
           {
                if(moshi==1)
                        {
                         T_baojing-- ;
                         if( T_baojing<=0 )T_baojing =0;
                        }
                        if(moshi==2)
                        {
                         C_baojing-- ;
                         if( C_baojing<=0 )C_baojing =0;
                        }
           }
         }
         if(shefang == 0)
         {
           Delay_Ms(10);
           if(shefang == 0)
           {
             while(!shefang);
                 sf_flag =~ sf_flag;
                 if(sf_flag == 1) sf_led = 0;
                 else sf_led = 1;

           }
         }
                 
}
void wendu()
{
  bit res;
  int temp;  //读取到的当前温度值
  
  unsigned char len;
  unsigned char str_wd[5];   //温度缓冲区
            Get18B20Temp(&temp);  //读取当前温度
            res = Get18B20Temp(&temp);  //读取当前温度
            if (res)                    //读取成功时,刷新当前温度显示
            {               
                            intT = temp >> 4;          //分离出温度值整数部分
                decT = temp & 0xF;         //分离出温度值小数部分
                len = IntToString(str_wd, intT); //整数部分转换为字符串
                str_wd[len++] = '.';             //添加小数点
                decT = (decT*10) / 16;        //二进制的小数部分转换为1位十进制位
                str_wd[len++] = decT + '0';   //十进制小数位再转换为ASCII字符
                str_wd[len] = '\0';              //添加字符串结束符
                LcdShowStr(2, 0, str_wd);        //显示到液晶屏上
                         }
                    Start18B20();
}
/************主函数****************/
void main()
{
  unsigned char i;
  sf_flag = 0;
  Uart_Init();
  InitLcd1602();     //初始化液晶
  Start18B20();
  LcdShowStr(0, 0,"T:   C");
  LcdShowStr(7, 0,"C:    PPM");
  for(i = 0;i < 20;i++)//等待网络稳定
        {
                Delay_Ms(1000);
        }
                //测试是否已经开机,同时自适应波特率
        while(test_boot==No)
        {
                Send_String("AT\r\n");       
                Delay_Ms(100);
        }
                test_boot=No;

        //测试是否注册到网络
        while(test_net_register==No)
        {
                Send_String("AT+CREG?\r\n");         
                Delay_Ms(100);       
        }
        test_net_register=No;
        Receive_message();      //配置成接受短信模式


  while(1)
{
  Key_set_scan();//按键扫描
if(moshi == 0)          //设置模式切换
{
   kssj();   //开始收集 ,电压采集检测烟雾浓度
   Value =  Value-100;//烟雾浓度校准
   IntToString(str_yw,Value); //转换成字符串
   LcdShowStr(9, 0, str_yw); //烟雾浓度显示到液晶屏上
   wendu();         //温度检测并显示
   if(sf_flag == 1)
   {
      if(Value>=C_baojing||intT>T_baojing||Infra==1)
     {
              BUZZER = 0;                                                                                                     
       if(intT > T_baojing)
       {                           /*1234567890123456*/
        LcdShowStr(0,1,"temp");
            //   Send_message(content_temp);          //发温度超标短信
       }  else  LcdShowStr(0, 1,"    ");       
       if(Value >= C_baojing)     
       {                                 /*1234567890123456*/
         LcdShowStr(5,1,"smoke");  
             //   Send_message(content_smoke);          //发烟雾浓度超标短信
       }  else  LcdShowStr(5, 1,"     ");
       if(Infra == 1)        
       {                             /*1234567890123456*/
         LcdShowStr(11, 1,"body");  
             //   Send_message(content_body);          //发人体进入短信
       }  else  LcdShowStr(11,1,"    ");

     }
   else
     {
           BUZZER = 1;          /*1234567890123456*/
           LcdShowStr(0, 1," System normal  ");
     }
         }
}
   else if(moshi == 1)        //设置温度上限模式
   {       
   T_buff[0] = T_baojing/10+0x30;
   T_buff[1] = T_baojing%10+0x30;
   T_buff[2] = '\0';
   LcdShowStr(6, 1,T_buff);
   }
   else if(moshi == 2)         //设置烟雾浓度上限模式
   {
   C_buff[0] = C_baojing/100+0x30;
   C_buff[1] = C_baojing%100/10+0x30;
   C_buff[2] = C_baojing%10+0x30;
   C_buff[4] = '\0';
   LcdShowStr(6, 1,C_buff);
   }
                                                                                                          
}
}
/* 整型数转换为字符串,str-字符串指针,dat-待转换数,返回值-字符串长度 */
unsigned char IntToString(unsigned char *str, int dat)
{
    signed char i = 0;
    unsigned char len = 0;
    unsigned char buf[6];
   
    if (dat < 0)  //如果为负数,首先
       
    {
        dat = -dat;
        *str++ = '-';
        len++;
    }
    do {          //先转换为低位在前的十进制数组
        buf[i++] = dat % 10;
        dat /= 10;
    } while (dat > 0);
    len += i;     //i最后的值就是有效字符的个数
    while (i-- > 0)   //将数组值转换为ASCII码反向拷贝到接收指针上
    {
        *str++ = buf[i] + '0';
    }

    *str = '\0';  //添加字符串结束符
   
    return len;   //返回字符串长度
}
/*****************************************************************************
串口中断
/****************************************************************************/
void uart(void) interrupt 4
{
unsigned char UART_data;
        if(RI)
        {
                UART_data=SBUF;
                if(UART_data=='\n')
                {
                        if(GSM_receive[0]=='O'&&GSM_receive[1]=='K')
                        {
                                 test_boot=Yes;
                        }
                    //else
                        //        test_boot=No;
                    if(GSM_receive[0]=='+'&&GSM_receive[1]=='C'&&GSM_receive[2]=='R'&&GSM_receive[3]=='E'&&GSM_receive[4]=='G')
                    {
                            if(GSM_receive[7]=='1'||GSM_receive[9]=='1'||GSM_receive[9]=='5')
                           {
                                 test_net_register=Yes;
                           }
                    }                  
                    //        else
                    //  test_net_register=No;

                        if((GSM_receive[0]=='O')&&(GSM_receive[1]=='P')&&(GSM_receive[2]=='E')&&(GSM_receive[3]=='N'))          //大写OPEN
                      {       
                        //  CZ = 0;LcdShowStr(5, 1,"Open ");
                          }
                        if((GSM_receive[0]=='C')&&(GSM_receive[1]=='L')&&(GSM_receive[2]=='O')&&(GSM_receive[3]=='S')&&(GSM_receive[4]=='E'))
                      {       
                        //  CZ = 1;LcdShowStr(5, 1,"Close");
                          }                                               
                          GSMDATA_count=0;
                  }
                else
                {
                        GSM_receive[GSMDATA_count]=UART_data;
                        GSMDATA_count++;
                }
        }
        RI=0;
}

使用特权

评论回复
9
初级工程渣|  楼主 | 2023-6-29 13:03 | 只看该作者
实现效果

使用特权

评论回复
10
Undshing| | 2023-7-1 23:32 | 只看该作者
右下角什么模块啊?

使用特权

评论回复
11
公羊子丹| | 2023-12-30 07:17 | 只看该作者

应在操作时间内将胶料灌注完毕,否则影响流平

使用特权

评论回复
12
万图| | 2023-12-30 08:20 | 只看该作者

测试负载测试是在特定的测试条件下进行的

使用特权

评论回复
13
Uriah| | 2023-12-30 09:23 | 只看该作者

在测试中,可以改变负载电流,得到最大输出电流和输出电压

使用特权

评论回复
14
帛灿灿| | 2023-12-30 11:19 | 只看该作者

信号防雷电路应满足相应接口信号传输速率及带宽的需求,且接口与被保护设备兼容。

使用特权

评论回复
15
Bblythe| | 2023-12-30 12:22 | 只看该作者

随着对电路板模块的需求增加

使用特权

评论回复
16
周半梅| | 2023-12-30 14:18 | 只看该作者

防雷电路的输出残压值必须比被防护电路自身能够耐受的过电压峰值低,并有一定裕量

使用特权

评论回复
17
Pulitzer| | 2023-12-30 15:21 | 只看该作者

模信号是幅度相等且相位相同的信号

使用特权

评论回复
18
童雨竹| | 2023-12-30 17:17 | 只看该作者

Cfinal是CESD和人体电容的并联组合

使用特权

评论回复
19
Wordsworth| | 2023-12-30 18:20 | 只看该作者

构成各种滤波器对EMI进行滤波

使用特权

评论回复
20
Clyde011| | 2023-12-30 19:23 | 只看该作者

在动态测试之前,首先需要设定测试时间和测试频率

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

68

主题

676

帖子

0

粉丝