找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2909|回复: 0
收起左侧

单片机短信远程报警器程序设计(噪声,烟雾等模拟量或者数字量传感器模块可通用)

[复制链接]
ID:541089 发表于 2021-6-16 11:07 | 显示全部楼层 |阅读模式
      使用了GSM短信收发模块,用户只需要在代码中更改报警对象手机号码,报警器超过一定阈值可发送短信至手机,播报相关参数,并且本地蜂鸣器报警。
      短信模块收发指令回复判断改成延时判断,可适当更改延时值。上电等待初始化也为延时,可更改为接收到回复指令后初始化完成(代码还需要优化额,上传主要为一起学习)
      代码PCB以及相关模块资料已上传。
制作出来的实物图如下:

实物

实物


仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
烟雾传感器仿真中没有,其实就是传感器检测时相应的电阻值会变化,用滑动电位器代替就ok
51hei.png 51hei.png

Altium Designer画的原理图和PCB图如下:(51hei附件中可下载工程文件)

PCB_3D

PCB_3D

PCB_top

PCB_top

PCB_Bottom

PCB_Bottom


原理图

原理图


单片机源程序如下:
  1. #include <reg52.h> //包含头文件,一般情况不需要改动,头文件包含特殊功能寄存器的定义
  2. #include "intrins.h"                                                                                          
  3. #include "uart.h"
  4. #define     u8                          unsigned char
  5. #define     u16                   unsigned int
  6. #define     uchar                          unsigned char
  7. #define     uint                   unsigned int


  8. //常量
  9. #define Success 1U
  10. #define Failure 0U

  11. //定义变量
  12. unsigned long  Time_Cont = 0;       //定时器计数器

  13. char phoneNumber[] = "158888";                //替换成jls的电话号码
  14. //char phoneNumber[] = "158888";                //替换成lyg的电话号码
  15. //char phoneNumber[] = "1738888";                //替换成wc的电话号码
  16. char msg[] = "HELP!t:  .  n:    ";                //短信内容        
  17. //char text_send[] = "AT+CMGS=\"17347070063\"\r\n";                //替换成需要被拨打电话的号码
  18. //函数或者变量声明
  19. extern void delay_ms(unsigned int n);
  20. extern unsigned int sendCommand(char *Command, char *Response, unsigned long Timeout, unsigned char Retry);
  21. extern void errorLog();
  22. extern void soft_reset(void);
  23. extern void phone(char *number);
  24. extern void sendMessage(char *number,char *msg);
  25. void sendCommand_AT(char *Command,unsigned char times);

  26. uchar yushe_wendu=50;                                //温度预设值
  27. uchar yushe_yanwu=140;                                //烟雾预设值
  28. uint wendu;                                                                 //温度值全局变量
  29. uchar yanwu;                                                                 //用于读取ADC数据
  30. u16 xianshiyanwu_flag=0;
  31. //运行模式  
  32. uchar Mode=0;                                                                 //=1是设置温度阀值  =2是设置烟雾阀值        =0是正常监控模式
  33. //管脚声明
  34. sbit Led_Reg                 =P2^2;                                 //红灯
  35. sbit Led_Yellow  =P2^4;                                 //黄灯
  36. sbit Buzzer             =P2^0;                                 //蜂鸣器
  37. sbit Fan                      =P3^3;                                 //


  38. /********************************************************************
  39. * 名称 : delay_1ms()
  40. * 功能 : 延时1ms函数
  41. * 输入 : q
  42. * 输出 : 无
  43. ***********************************************************************/
  44. void delay_ms(uint q)
  45. {
  46.         uint i,j;
  47.         for(i=0;i<q;i++)
  48.                 for(j=0;j<110;j++);
  49. }
  50. /***********************************************************************************************************
  51. LCD1602相关函数
  52. ***********************************************************************************************************/

  53. //LCD管脚声明 (RW引脚实物直接接地,因为本设计只用到液晶的写操作,RW引脚一直是低电平)
  54. sbit LCDRS = P2^7;
  55. sbit LCDEN = P2^6;
  56. sbit D0                 = P0^0;
  57. sbit D1                 = P0^1;
  58. sbit D2                 = P0^2;
  59. sbit D3                 = P0^3;
  60. sbit D4                 = P0^4;
  61. sbit D5                 = P0^5;
  62. sbit D6                 = P0^6;
  63. sbit D7                 = P0^7;



  64. //LCD延时
  65. void LCDdelay(uint z)                  //该延时大约100us(不精确,液晶操作的延时不要求很精确)
  66. {
  67.   uint x,y;
  68.   for(x=z;x>0;x--)
  69.     for(y=10;y>0;y--);
  70. }
  71. void LCD_WriteData(u8 dat)         
  72. {
  73.         if(dat&0x01)D0=1;else D0=0;
  74.         if(dat&0x02)D1=1;else D1=0;
  75.         if(dat&0x04)D2=1;else D2=0;
  76.         if(dat&0x08)D3=1;else D3=0;
  77.         if(dat&0x10)D4=1;else D4=0;
  78.         if(dat&0x20)D5=1;else D5=0;
  79.         if(dat&0x40)D6=1;else D6=0;
  80.         if(dat&0x80)D7=1;else D7=0;
  81. }
  82. //写命令
  83. void write_com(uchar com)
  84. {
  85.   LCDRS=0;                                 
  86.         LCD_WriteData(com);
  87. //  DAT=com;
  88.   LCDdelay(5);
  89.   LCDEN=1;
  90.   LCDdelay(5);
  91.   LCDEN=0;
  92. }
  93. //写数据
  94. void write_data(uchar date)
  95. {
  96.   LCDRS=1;
  97.         LCD_WriteData(date);
  98. //  DAT=date;
  99.   LCDdelay(5);
  100.   LCDEN=1;
  101.   LCDdelay(5);
  102.   LCDEN=0;
  103. }

  104. /*------------------------------------------------
  105.               选择写入位置
  106. ------------------------------------------------*/
  107. void SelectPosition(unsigned char x,unsigned char y)
  108. {     
  109.         if (x == 0)
  110.         {     
  111.                 write_com(0x80 + y);     //表示第一行
  112.         }
  113.         else
  114.         {      
  115.                 write_com(0xC0 + y);      //表示第二行
  116.         }        
  117. }
  118. /*------------------------------------------------
  119.               写入字符串函数
  120. ------------------------------------------------*/
  121. void LCD_Write_String(unsigned char x,unsigned char y,unsigned char *s)
  122. {     
  123.         SelectPosition(x,y) ;
  124.         while (*s)
  125.         {     
  126.                 write_data( *s);     
  127.                 s ++;     
  128.         }
  129. }
  130. //========================================================================
  131. // 函数: void LCD_Write_Char(u8 x,u8 y,u16 s,u8 l)
  132. // 应用: LCD_Write_Char(0,1,366,4) ;
  133. // 描述: 在第0行第一个字节位置显示366的后4位,显示结果为 0366
  134. // 参数: x:行,y:列,s:要显示的字,l:显示的位数
  135. // 返回: none.
  136. // 版本: VER1.0
  137. // 日期: 2013-4-1
  138. // 备注: 最大显示65535
  139. //========================================================================
  140. void LCD_Write_Char(u8 x,u8 y,u16 s,u8 l)
  141. {     
  142.         SelectPosition(x,y) ;

  143.         if(l>=5)
  144.                 write_data(0x30+s/10000%10);        //万位
  145.         if(l>=4)
  146.                 write_data(0x30+s/1000%10);                //千位
  147.         if(l>=3)
  148.                 write_data(0x30+s/100%10);                //百位
  149.         if(l>=2)
  150.                 write_data(0x30+s/10%10);                        //十位
  151.         if(l>=1)
  152.                 write_data(0x30+s%10);                //个位

  153. }
  154. /*1602指令简介
  155.   write_com(0x38);//屏幕初始化
  156.   write_com(0x0c);//打开显示 无光标 无光标闪烁
  157.   write_com(0x0d);//打开显示 阴影闪烁
  158.   write_com(0x0d);//打开显示 阴影闪烁
  159. */
  160. //1602初始化
  161. void Init1602()
  162. {
  163.   uchar i=0;
  164.   write_com(0x38);//屏幕初始化
  165.   write_com(0x0c);//打开显示 无光标 无光标闪烁
  166.   write_com(0x06);//当读或写一个字符是指针后一一位
  167.   write_com(0x01);//清屏
  168.         
  169. }

  170. void Display_1602(yushe_wendu,yushe_yanwu,c,temp)
  171. {
  172.         //显示预设温度
  173.         LCD_Write_Char(0,6,yushe_wendu,2) ;
  174.         
  175.         //显示预设烟雾
  176.         LCD_Write_Char(0,13,yushe_yanwu,3) ;
  177.         
  178.         //时时温度
  179.         LCD_Write_Char(1,6,c/10,2) ;
  180.         write_data('.');
  181.         LCD_Write_Char(1,9,c%10,1) ;
  182.         
  183.         //时时烟雾
  184.         LCD_Write_Char(1,13,temp,3) ;
  185. }



  186. /***********************************************************************************************************
  187. ADC0832相关函数
  188. ***********************************************************************************************************/
  189. sbit ADCS         =P1^5; //ADC0832 片选
  190. sbit ADCLK  =P1^2; //ADC0832 时钟
  191. sbit ADDI         =P1^3; //ADC0832 数据输入                /*因为单片机的管脚是双向的,且ADC0832的数据输入输出不同时进行,
  192. sbit ADDO         =P1^3; //ADC0832 数据输出                /*为节省单片机引脚,简化电路所以输入输出连接在同一个引脚上



  193. //========================================================================
  194. // 函数: unsigned int Adc0832(unsigned char channel)
  195. // 应用:                 temp=Adc0832(0);
  196. // 描述: 读取0通道的AD值
  197. // 参数: channel:通道0和通道1选择
  198. // 返回: 选取通道的AD值
  199. // 版本: VER1.0
  200. // 日期: 2015-05-29
  201. // 备注:
  202. //========================================================================
  203. unsigned int Adc0832(unsigned char channel)
  204. {
  205.         uchar i=0;
  206.         uchar j;
  207.         uint dat=0;
  208.         uchar ndat=0;
  209.         uchar  Vot=0;

  210.         if(channel==0)channel=2;
  211.         if(channel==1)channel=3;
  212.         ADDI=1;
  213.         _nop_();
  214.         _nop_();
  215.         ADCS=0;//拉低CS端
  216.         _nop_();
  217.         _nop_();
  218.         ADCLK=1;//拉高CLK端
  219.         _nop_();
  220.         _nop_();
  221.         ADCLK=0;//拉低CLK端,形成下降沿1
  222.         _nop_();
  223.         _nop_();
  224.         ADCLK=1;//拉高CLK端
  225.         ADDI=channel&0x1;
  226.         _nop_();
  227.         _nop_();
  228.         ADCLK=0;//拉低CLK端,形成下降沿2
  229.         _nop_();
  230.         _nop_();
  231.         ADCLK=1;//拉高CLK端
  232.         ADDI=(channel>>1)&0x1;
  233.         _nop_();
  234.         _nop_();
  235.         ADCLK=0;//拉低CLK端,形成下降沿3
  236.         ADDI=1;//控制命令结束
  237.         _nop_();
  238.         _nop_();
  239.         dat=0;
  240.         for(i=0;i<8;i++)
  241.         {
  242.                 dat|=ADDO;//收数据
  243.                 ADCLK=1;
  244.                 _nop_();
  245.                 _nop_();
  246.                 ADCLK=0;//形成一次时钟脉冲
  247.                 _nop_();
  248.                 _nop_();
  249.                 dat<<=1;
  250.                 if(i==7)dat|=ADDO;
  251.         }
  252.         for(i=0;i<8;i++)
  253.         {
  254.                 j=0;
  255.                 j=j|ADDO;//收数据
  256.                 ADCLK=1;
  257.                 _nop_();
  258.                 _nop_();
  259.                 ADCLK=0;//形成一次时钟脉冲
  260.                 _nop_();
  261.                 _nop_();
  262.                 j=j<<7;
  263.                 ndat=ndat|j;
  264.                 if(i<7)ndat>>=1;
  265.         }
  266.         ADCS=1;//拉低CS端
  267.         ADCLK=0;//拉低CLK端
  268.         ADDO=1;//拉高数据端,回到初始状态
  269.         dat<<=8;
  270.         dat|=ndat;

  271.         return(dat);            //return ad data
  272. }

  273. /***********************************************************************************************************
  274. DS18B20相关函数
  275. ***********************************************************************************************************/

  276. sbit DQ = P1^0;                                 //ds18b20的数据引脚



  277. /*****延时子程序:该延时主要用于ds18b20延时*****/
  278. void Delay_DS18B20(int num)
  279. {
  280.   while(num--) ;
  281. }
  282. /*****初始化DS18B20*****/
  283. void Init_DS18B20(void)
  284. {
  285.   unsigned char x=0;
  286.   DQ = 1;         //DQ复位
  287.   Delay_DS18B20(8);    //稍做延时
  288.   DQ = 0;         //单片机将DQ拉低
  289.   Delay_DS18B20(80);   //精确延时,大于480us
  290.   DQ = 1;         //拉高总线
  291.   Delay_DS18B20(14);
  292.   x = DQ;           //稍做延时后,如果x=0则初始化成功,x=1则初始化失败
  293.   Delay_DS18B20(20);
  294. }
  295. /*****读一个字节*****/
  296. unsigned char ReadOneChar(void)
  297. {
  298.   unsigned char i=0;
  299.   unsigned char dat = 0;
  300.   for (i=8;i>0;i--)
  301.   {
  302.     DQ = 0;     // 给脉冲信号
  303.     dat>>=1;
  304.     DQ = 1;     // 给脉冲信号
  305.     if(DQ)
  306.     dat|=0x80;
  307.     Delay_DS18B20(4);
  308.   }
  309.   return(dat);
  310. }
  311. /*****写一个字节*****/
  312. void WriteOneChar(unsigned char dat)
  313. {
  314.   unsigned char i=0;
  315.   for (i=8; i>0; i--)
  316.   {
  317.     DQ = 0;
  318.     DQ = dat&0x01;
  319.     Delay_DS18B20(5);
  320.     DQ = 1;
  321.     dat>>=1;
  322.   }
  323. }
  324. /*****读取温度*****/
  325. unsigned int ReadTemperature(void)
  326. {
  327.   unsigned char a=0;
  328.   unsigned char b=0;
  329.   unsigned int t=0;
  330.   float tt=0;
  331.   Init_DS18B20();
  332.   WriteOneChar(0xCC);  //跳过读序号列号的操作
  333.   WriteOneChar(0x44);  //启动温度转换
  334.   Init_DS18B20();
  335.   WriteOneChar(0xCC);  //跳过读序号列号的操作
  336.   WriteOneChar(0xBE);  //读取温度寄存器
  337.   a=ReadOneChar();     //读低8位
  338.   b=ReadOneChar();    //读高8位
  339.   t=b;
  340.   t<<=8;
  341.   t=t|a;
  342.   tt=t*0.0625;
  343.   t= tt*10+0.5;     //放大10倍输出并四舍五入
  344.   return(t);
  345. }
  346. //=====================================================================================
  347. //=====================================================================================
  348. //=====================================================================================


  349. /*****校准温度*****/
  350. u16 check_wendu(void)
  351. {
  352.         u16 c;
  353.         c=ReadTemperature()-5;                          //获取温度值并减去DS18B20的温漂误差
  354.         if(c<1) c=0;
  355.         if(c>=999) c=999;
  356.         return c;
  357. }


  358. /***********************************************************************************************************
  359. 按键检测相关函数
  360. ***********************************************************************************************************/
  361. //按键
  362. sbit Key1=P1^6;                                 //设置键
  363. sbit Key2=P1^7;                                 //加按键
  364. sbit Key3=P3^2;                                 //减按键



  365. #define KEY_SET                 1                //设置
  366. #define KEY_ADD                        2                //加
  367. #define KEY_MINUS                3                //减


  368. //========================================================================
  369. // 函数: u8 Key_Scan()
  370. // 应用: temp=u8 Key_Scan();
  371. // 描述: 按键扫描并返回按下的键值
  372. // 参数: NONE
  373. // 返回: 按下的键值
  374. // 版本: VER1.0
  375. // 日期: 2015-05-29
  376. // 备注: 该函数带松手检测,按下键返回一次键值后返回0,直至第二次按键按下
  377. //========================================================================
  378. u8 Key_Scan()
  379. {         
  380.         static u8 key_up=1;//按键按松开标志
  381.         if(key_up&&(Key1==0||Key2==0||Key3==0))
  382.         {
  383.                 delay_ms(10);//去抖动
  384.                 key_up=0;
  385.                 if(Key1==0)                        return 1;
  386.                 else if(Key2==0)return 2;
  387.                 else if(Key3==0)return 3;
  388.         }
  389.         else if(Key1==1&&Key2==1&&Key3==1)
  390.                 key_up=1;            
  391.          return 0;// 无按键按下
  392. }



  393. void main (void)
  394. {
  395.         u8 key,text_flag=0,next_sendtext=0;

  396.         Init1602();                          //调用初始化显示函数
  397.         LCD_Write_String(0,0,"JIANG LIANG SEN ");  //开机界面
  398.         LCD_Write_String(1,0,"   WAITING    ");  
  399.         delay_ms(1000);
  400.         wendu=check_wendu();                  //初始化时调用温度读取函数 防止开机85°C
  401.         yanwu=Adc0832(0);                                //读取烟雾值
  402.         //
  403. //        wendu=check_wendu();                  //初始化时调用温度读取函数 防止开机85°C
  404.          //Display_1602(yushe_wendu,yushe_yanwu,wendu,yanwu);  //显示预设温度,预设烟雾,温度值,烟雾值

  405. //
  406.         delay_ms(1000);
  407.         Uart_Init();                                                  
  408.         delay_ms(1000);
  409.         delay_ms(1000);
  410.         delay_ms(1000);
  411. //        delay_ms(1000);
  412. //        if (sendCommand("AT\r\n", "OK\r\n", 3000, 10) == Success);
  413. //        else errorLog();
  414. //        delay_ms(10);

  415. //        if (sendCommand("AT+CPIN?\r\n", "READY", 1000, 10) == Success);
  416. //        else errorLog();
  417. //        delay_ms(10);
  418.         delay_ms(1000);
  419.         delay_ms(1000);
  420. //        sendCommand("AT+CMGF=1\r\n", "OK\r\n", 3000, 10);
  421.         sendCommand_AT("AT+CMGF=1\r\n",1);
  422.         LCD_Write_String(1,0,"   WAITING.   ");
  423.         //else errorLog();
  424. //        delay_ms(1000);
  425.         delay_ms(1000);
  426. //        sendCommand("AT+CSMP=17,167,0,8\r\n", "OK\r\n", 3000, 10);
  427.         sendCommand_AT("AT+CSMP=17,167,0,8\r\n",1);
  428.         //else errorLog();
  429.            delay_ms(10);
  430.         delay_ms(1000);
  431.         //sendCommand("AT+CSCS=\"GSM\"\r\n", "OK\r\n", 3000, 10) ;
  432.           sendCommand_AT("AT+CSCS=\"GSM\"\r\n",1);
  433.         //else errorLog();
  434.         delay_ms(10);
  435.         delay_ms(1000);
  436.         LCD_Write_String(1,0,"   WAITING..  ");
  437.         sendMessage(phoneNumber,"Ready");                //发送短信
  438.         
  439.         LCD_Write_String(0,0,"SET T:00   N:000");  //开机界面
  440.         LCD_Write_String(1,0,"NOW T:00.0 N:000");
  441.         Display_1602(yushe_wendu,yushe_yanwu,wendu,yanwu);  //显示预设温度,预设烟雾,温度值,烟雾值
  442.         while (1)                                                //主循环
  443.         {
  444.                 key=Key_Scan();                                        //按键扫描
  445.                 yanwu=Adc0832(0);                                //读取烟雾值
  446.                 wendu=check_wendu();          //读取温度值
  447.                
  448.                 if(key==KEY_SET)
  449.                 {
  450.                         Mode++;
  451.                 }
  452.                
  453.                 switch(Mode)                                                //判断模式的值
  454.                 {
  455.                         case 0:                                                                //监控模式
  456.                         {        xianshiyanwu_flag++;
  457.                                 if(xianshiyanwu_flag>=10)
  458.                                 {
  459.                                 Display_1602(yushe_wendu,yushe_yanwu,wendu,yanwu);  //显示预设温度,预设烟雾,温度值,烟雾值
  460.                                 xianshiyanwu_flag=0;
  461.                                 }
  462.                                 if(yanwu>=yushe_yanwu)          //烟雾值大于等于预设值时
  463.                                 { delay_ms(10);
  464.                                         yanwu=Adc0832(0);                                //读取烟雾值
  465.                                         if(yanwu>=yushe_yanwu)
  466.                                         {
  467.                                         Led_Reg=0;                                          //烟雾指示灯亮
  468.                                         Fan=0;
  469.                                         Buzzer=0;                                                  //蜂鸣器报警
  470.                                         text_flag=1;
  471.                                         Display_1602(yushe_wendu,yushe_yanwu,wendu,yanwu);  //显示预设温度,预设烟雾,温度值,烟雾值
  472.                                         }
  473.                                 //        sendMessage(phoneNumber,msg);                //发送短信
  474.                                 }
  475.                                 else                                                                                  //烟雾值小于预设值时
  476.                                 {
  477.                                         Led_Reg=1;                                          //关掉报警灯
  478.                                         Fan=1;
  479.                                 }
  480.                                 if(wendu>=(yushe_wendu*10))          //温度大于等于预设温度值时(为什么是大于预设值*10:因为我们要显示的温度是有小数点后一位,是一个3位数,25.9°C时实际读的数是259,所以判断预设值时将预设值*10)
  481.                                 {        delay_ms(10);
  482.                                         wendu=check_wendu();          //读取温度值
  483.                                         if(wendu>=(yushe_wendu*10))
  484.                                         {
  485.                                         Buzzer=0;                                                  //打开蜂鸣器报警
  486.                                         Led_Yellow=0;                                          //打开温度报警灯
  487.                                         text_flag=1;
  488.                                         Display_1602(yushe_wendu,yushe_yanwu,wendu,yanwu);  //显示预设温度,预设烟雾,温度值,烟雾值
  489.                                         }
  490.                                 //        sendMessage(phoneNumber,"temp Help!");                //发送短信
  491.                                 }
  492.                                 else                                                                                  //温度值小于预设值时
  493.                                 {
  494.                                         Led_Yellow=1;                                          //关闭报警灯
  495.                                 }
  496.                                 if((yanwu<yushe_yanwu)&&(wendu<(yushe_wendu*10)))          //当烟雾小于预设值并且温度也小于预设值时 (&&:逻辑与,左右两边的表达式都成立(都为真,也就是1)时,该if语句才成立)
  497.                                 {
  498.                                         Buzzer=1;                                                  //停止报警
  499.                                 }
  500.                                 break;
  501.                         }
  502.                         case 1://预设温度模式
  503.                         {
  504.                                 SelectPosition(0,5) ;                                        //指定位置
  505.                            write_com(0x0d);                                                        //阴影闪烁
  506.                                 if(key==KEY_ADD)                                                        //加键按下
  507.                                 {
  508.                                         yushe_wendu++;                                            //预设温度值(阀值)加1
  509.                                         if(yushe_wendu>=99)                                         //当阀值加到大于等于99时
  510.                                         yushe_wendu=99;                                                         //阀值固定为99
  511.                                         LCD_Write_Char(0,6,yushe_wendu,2) ;//显示预设温度
  512.                                 }
  513.                                 if(key==KEY_MINUS)                                                 //减键按下
  514.                                 {
  515.                                         if(yushe_wendu<=1)                                        //当温度上限值减小到1时
  516.                                         yushe_wendu=1;                          //固定为1
  517.                                         yushe_wendu--;                                                        //预设温度值减一,最小为0
  518.                                         LCD_Write_Char(0,6,yushe_wendu,2) ;//显示预设温度
  519.                                 }
  520.                                 break;                                                                                          //执行后跳出switch
  521.                         }
  522.                         case 2:                                //预设烟雾模式
  523.                         {
  524.                                 SelectPosition(0,12) ;                                //指定位置        
  525.                            write_com(0x0d);                                                        //打开显示 无光标 光标闪烁
  526.                                 if(key==KEY_ADD)                                                        //加键按下
  527.                                 {
  528.                                         if(yushe_yanwu>=255)        //当阀值加到大于等于255时
  529.                                         yushe_yanwu=254;            //阀值固定为254
  530.                                         yushe_yanwu++;                                            //预设烟雾值(阀值)加1,最大为255
  531.                                         LCD_Write_Char(0,13,yushe_yanwu,3) ;//显示预设烟雾
  532.                                 }
  533.                                 if(key==KEY_MINUS)                                                //减键按下
  534.                                 {
  535.                                         if(yushe_yanwu<=1)                                        //当烟雾上限值减小到1时
  536.                                                 yushe_yanwu=1;                  //固定为1
  537.                                         yushe_yanwu--;                                                        //预设温度值减一,最小为0         
  538.                                         LCD_Write_Char(0,13,yushe_yanwu,3) ;//显示预设烟雾
  539.                                 }
  540.                                 break;
  541.                         }
  542.                         default        :        
  543.                         {
  544.                                 write_com(0x38);//屏幕初始化
  545.                                 write_com(0x0c);//打开显示 无光标 无光标闪烁
  546.                                 Mode=0;                        //恢复正常模式
  547.                                 break;
  548.                         }
  549.                 }
  550.                 if(text_flag==1&&(next_sendtext>200))
  551.                 {
  552.                 //发送此时报警温度噪声值
  553.                 msg[7]=wendu/100%10+0x30;
  554.                   msg[8]=wendu/10%10+0x30;
  555.                   msg[10]=wendu%10+0x30;
  556.                  msg[14]=yanwu/100%10+0x30;
  557.                   msg[15]=yanwu/10%10+0x30;
  558.                   msg[16]=yanwu%10+0x30;
  559.                
  560.                 sendMessage(phoneNumber,msg);                //发送短信
  561.                 text_flag=0;
  562.                 next_sendtext=0;
  563.                 }
  564.                 if(next_sendtext<250)
  565.                 {
  566.                 next_sendtext++;
  567.                 }
  568.                
  569.         }

  570. }





  571. //
  572. void sendMessage(char *number,char *msg)
  573. {
  574.         xdata char send_buf[20] = {0};
  575.         memset(send_buf, 0, 20);    //清空
  576.         strcpy(send_buf, "AT+CMGS=\"");
  577.         strcat(send_buf, number);
  578.         strcat(send_buf, "\"\r\n");
  579.         if (sendCommand(send_buf, ">", 3000, 2) == Success);
  580.         else errorLog();
  581.          delay_ms(1000);
  582.         if (sendCommand(msg, msg, 3000, 2) == Success);
  583.         else errorLog();
  584.          delay_ms(1000);
  585. ……………………

  586. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
wcs_zaosheng.7z (4.48 MB, 下载次数: 53)

评分

参与人数 1黑币 +100 收起 理由
admin + 100 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表