找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4534|回复: 3
打印 上一主题 下一主题
收起左侧

WIFI中国移动云平台 EDP协议的点灯和上传温湿度单片机源程序

[复制链接]
跳转到指定楼层
楼主
ID:535575 发表于 2019-5-25 15:44 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
                         WIFI                       EDP协议的点灯和上传温湿度
                     这个程序我自己改的是利用双串口例程        EDP协议的例程    改成的

单片机源程序如下:
  1. #define MAIN_Fosc                22118400L        //定义主时钟
  2. #include        "STC15Fxxxx.H"
  3. #include   <string.h>
  4. #define                Baudrate1        115200UL
  5. #define                Baudrate2        115200UL


  6. bit        B_TX1_Busy;        //发送忙标志
  7. bit        B_TX2_Busy;        //发送忙标志

  8. void        UART1_config(u8 brt);        // 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
  9. void        UART2_config(u8 brt);        // 选择波特率, 2: 使用Timer2做波特率, 其它值: 无效.
  10. void         PrintString1(u8 *puts);
  11. void         PrintString2(u8 *puts);

  12. bit Haertbeat_Flag;
  13. bit Haertbeat_Detection;
  14. u8  Rec_Char;
  15. void PrintString2(u8 *puts);
  16. void PrintString_Text(u8 *puts);
  17. void wifi_Inti();
  18. void Delay10000ms()        ;        
  19. void Delay3000ms();



  20. void RH(void);
  21. void COM(void);
  22. void Delay18ms();
  23. void Delay_10us()        ;
  24. void PrintString_Data(u8 *puts);
  25. void Up_temperature();
  26. void Up_humidity();
  27. //----------------定义区--------------------//
  28. //----------------------------------------------//
  29. u8  U8FLAG;
  30. u8  U8count,U8temp;
  31. u8  U8T_data_H,U8T_data_L,U8RH_data_H,U8RH_data_L,U8checkdata;
  32. u8  U8T_data_H_temp,U8T_data_L_temp,U8RH_data_H_temp,U8RH_data_L_temp,U8checkdata_temp;
  33. u8  U8comdata;
  34. u8  disbuf_h[]={0,0};
  35. u8  disbuf_t[]={0,0};
  36. u8 code temperature_Data1[]={0X80,0X15,0X00,0X05,0X00,0X11,0X2C,0X3B,0X74,0X65,0X6D,0X70,0X65,0X72,0X61,0X74,0X75,0X72,0X65,0X20,0X2C,0xff};
  37. u8 code humidity_Data2[]={0X80,0X12,0X00,0X05,0X00,0X0E,0X2C,0X3B,0X68,0X75,0X6D,0X69,0X64,0X69,0X74,0X79,0X20,0X2C,0xff};
  38.         bit Haertbeat_Flag;
  39. bit Haertbeat_Detection;
  40. u8  Rec_Char;
  41. u8  Rec_Num;
  42. u8  Com_Turn_Light ;


  43. u8 Rec_Fax_Text[]={0x00,0x00,0x00,0x00,0x00,0x00,0x00};
  44. unsigned char code Heartbeat[]={0xC0,0x00,0xff};
  45. u8 code Connect_Com[]={0X10,0X32,0X00,0X03,0X45,0X44,0X50,0X01,0X40,0X01,0X2C,0X00,0X09,0X35,0X31,0X38,0X39,0X38,0X38,0X32,0X37,
  46.         0X31,0X00,0X1C,0X63,0X52,0X6E,0X67,0X4F,0X50,0X4B,0X3D,0X33,0X6C,0X4D,0X65,0X78,0X32,0X41,0X75,0X45,0X69,0X32,0X41,0X37,0X63,0X6D,0X58,0X58,0X38,0X63,0X3D,0xff};
  47. u8 code Save_Data[]={0X80,0X63,0X00,0X01,0X00,0X5F,0X7B,0X0A,0X09,0X22,0X64,0X61,0X74,0X61,0X73,0X74,0X72,0X65,0X61,0X6D,0X73,0X22,0X3A,0X09,0X5B,0X7B,0X0A,0X09,0X09,0X09,
  48.         0X22,0X69,0X64,0X22,0X3A,0X09,0X22,0X74,0X65,0X6D,0X70,0X65,0X72,0X61,0X74,0X75,0X72,0X65,0X22,0X2C,0X0A,0X09,0X09,0X09,0X22,0X64,0X61,0X74,0X61,0X70,0X6F,0X69,0X6E,        0X74,        0X73,0X22,0X3A,
  49.         0X09,0X5B,0X7B,0X0A,0X09,0X09,0X09,0X09,0X09,0X22,0X76,0X61,0X6C,0X75,0X65,0X22,0X3A,0X09,0X38,0X30,0X0A,0X09,0X09,0X09,0X09,0X7D,0X5D,0X0A,0X09,0X09,0X7D,0X5D,0X0A,0X7D,0xff};
  50. void   Haertbeat_Response()
  51. {
  52.         
  53.   unsigned         char j;

  54.         for(j=0;j<3;j++)
  55.                 {
  56.                           PrintString_Text(Heartbeat);
  57.                     Delay3000ms();
  58.                           Delay3000ms();
  59.            if( Haertbeat_Flag == 1)
  60.                              break;        
  61.            }        
  62.     if( Haertbeat_Flag == 1)
  63.         Haertbeat_Flag   = 0;
  64.     else
  65.            {
  66.       wifi_Inti();
  67.                          Delay3000ms();
  68.                         PrintString_Text(Connect_Com);
  69.                          Delay3000ms();
  70.      }

  71. }
  72. //========================================================================
  73. // 函数: void main(void)
  74. // 描述: 主函数。
  75. // 参数: none.
  76. // 返回: none.
  77. // 版本: VER1.0
  78. // 日期: 2014-11-28
  79. // 备注:
  80. //========================================================================
  81. int main(void)
  82. {
  83.         P0M1 = 0;        P0M0 = 0;        //设置为准双向口
  84.         P1M1 = 0;        P1M0 = 0;        //设置为准双向口
  85.         P2M1 = 0;        P2M0 = 0;        //设置为准双向口
  86.         P3M1 = 0;        P3M0 = 0;        //设置为准双向口
  87.         P4M1 = 0;        P4M0 = 0;        //设置为准双向口
  88.         P5M1 = 0;        P5M0 = 0;        //设置为准双向口
  89.         P6M1 = 0;        P6M0 = 0;        //设置为准双向口
  90.         P7M1 = 0;        P7M0 = 0;        //设置为准双向口

  91.         UART1_config(1);        // 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
  92.         UART2_config(2);        // 选择波特率, 2: 使用Timer2做波特率, 其它值: 无效.
  93.         EA = 1;                                    //允许全局中断
  94.         
  95.                 wifi_Inti();
  96.           PrintString_Text(Connect_Com);
  97. //                Delay10000ms();
  98. //          PrintString_Text(Save_Data);        
  99.                 Delay3000ms();
  100.          
  101.         
  102.         
  103.         while(1)
  104. {
  105.      Haertbeat_Response();
  106.            Delay18ms();
  107.            RH();
  108.           Delay_10us()        ;
  109.            Up_temperature();
  110.          Delay_10us()        ;
  111.            Up_humidity();
  112.      Delay_10us()        ;
  113. }
  114.   
  115. }
  116. //========================================================================
  117. // 函数: void PrintString1(u8 *puts)
  118. // 描述: 串口1发送字符串函数。
  119. // 参数: puts:  字符串指针.
  120. // 返回: none.
  121. // 版本: VER1.0
  122. // 日期: 2014-11-28
  123. // 备注:
  124. //========================================================================
  125. void PrintString1(u8 *puts)
  126. {
  127.   for (; *puts != 0;        puts++)           //遇到停止符0结束
  128.         {
  129.                 SBUF = *puts;
  130.                 B_TX1_Busy = 1;
  131.                 while(B_TX1_Busy);
  132.         }
  133. }
  134. //========================================================================
  135. // 函数: void PrintString2(u8 *puts)
  136. // 描述: 串口2发送字符串函数。
  137. // 参数: puts:  字符串指针.
  138. // 返回: none.
  139. // 版本: VER1.0
  140. // 日期: 2014-11-28
  141. // 备注:
  142. //========================================================================
  143. void PrintString2(u8 *puts)
  144. {
  145.   for (;*puts != 0;puts++)           //遇到停止符0结束
  146.         {
  147.                 S2BUF = *puts;
  148.                 B_TX2_Busy = 1;
  149.                 while(B_TX2_Busy);
  150.         }
  151. }


  152. void PrintString_Text(u8 *puts)
  153. {
  154.   for (;*puts != 0xff;puts++)           //遇到停止符0结束
  155.         {
  156.                 S2BUF = *puts;
  157.                 B_TX2_Busy = 1;
  158.                 while(B_TX2_Busy);
  159.         }
  160. }


  161. void PrintString_Data(u8 *puts)
  162. {
  163.   for (;*puts != 0xff;puts++)           //遇到停止符0结束
  164.         {
  165.                 S2BUF = *puts;
  166.                 B_TX2_Busy = 1;
  167.                 while(B_TX2_Busy);
  168.         }
  169. }



  170. //========================================================================
  171. // 函数: SetTimer2Baudraye(u16 dat)
  172. // 描述: 设置Timer2做波特率发生器。
  173. // 参数: dat: Timer2的重装值.
  174. // 返回: none.
  175. // 版本: VER1.0
  176. // 日期: 2014-11-28
  177. // 备注:
  178. //========================================================================
  179. void        SetTimer2Baudraye(u16 dat)
  180. {
  181.         AUXR &= ~(1<<4);        //Timer stop
  182.         AUXR &= ~(1<<3);        //Timer2 set As Timer
  183.         AUXR |=  (1<<2);        //Timer2 set as 1T mode
  184.         TH2 = dat / 256;
  185.         TL2 = dat % 256;
  186.         IE2  &= ~(1<<2);        //禁止中断
  187.         AUXR |=  (1<<4);        //Timer run enable
  188. }
  189. //========================================================================
  190. // 函数: void        UART1_config(u8 brt)
  191. // 描述: UART1初始化函数。
  192. // 参数: brt: 选择波特率, 2: 使用Timer2做波特率, 其它值: 使用Timer1做波特率.
  193. // 返回: none.
  194. // 版本: VER1.0
  195. // 日期: 2014-11-28
  196. // 备注:
  197. //========================================================================
  198. void        UART1_config(u8 brt)
  199. {
  200.         /*********** 波特率使用定时器2 *****************/
  201.         if(brt == 2)
  202.         {
  203.                 AUXR |= 0x01;                //S1 BRT Use Timer2;
  204.                 SetTimer2Baudraye(65536UL - (MAIN_Fosc / 4) / Baudrate1);
  205.         }
  206.         /*********** 波特率使用定时器1 *****************/
  207.         else
  208.         {
  209.                 TR1 = 0;
  210.                 AUXR &= ~0x01;                //S1 BRT Use Timer1;
  211.                 AUXR |=  (1<<6);        //Timer1 set as 1T mode
  212.                 TMOD &= ~(1<<6);        //Timer1 set As Timer
  213.                 TMOD &= ~0x30;                //Timer1_16bitAutoReload;
  214.                 TH1 = (u8)((65536UL - (MAIN_Fosc / 4) / Baudrate1) / 256);
  215.                 TL1 = (u8)((65536UL - (MAIN_Fosc / 4) / Baudrate1) % 256);
  216.                 ET1 = 0;        //禁止中断
  217.                 INT_CLKO &= ~0x02;        //不输出时钟
  218.                 TR1  = 1;
  219.         }
  220.         /*************************************************/
  221.         SCON = (SCON & 0x3f) | 0x40;        //UART1模式, 0x00: 同步移位输出, 0x40: 8位数据,可变波特率, 0x80: 9位数据,固定波特率, 0xc0: 9位数据,可变波特率
  222. //        PS  = 1;        //高优先级中断
  223.         ES  = 1;        //允许中断
  224.         REN = 1;        //允许接收
  225.         P_SW1 &= 0x3f;
  226.         //P_SW1 |= 0x00;
  227.         //P_SW1 |= 0x80;                //UART1 switch to, 0x00: P3.0 P3.1, 0x40: P3.6 P3.7, 0x80: P1.6 P1.7 (必须使用内部时钟)
  228. //        PCON2 |=  (1<<4);        //内部短路RXD与TXD, 做中继, ENABLE,DISABLE
  229.         B_TX1_Busy = 0;
  230. }
  231. //========================================================================
  232. // 函数: void        UART2_config(u8 brt)
  233. // 描述: UART2初始化函数。
  234. // 参数: brt: 选择波特率, 2: 使用Timer2做波特率, 其它值: 无效.
  235. // 返回: none.
  236. // 版本: VER1.0
  237. // 日期: 2014-11-28
  238. // 备注:
  239. //========================================================================
  240. void        UART2_config(u8 brt)        // 选择波特率, 2: 使用Timer2做波特率, 其它值: 无效.
  241. {
  242.         if(brt == 2)
  243.         {
  244.                 SetTimer2Baudraye(65536UL - (MAIN_Fosc / 4) / Baudrate2);
  245.                 S2CON &= ~(1<<7);        // 8位数据, 1位起始位, 1位停止位, 无校验
  246.                 IE2   |= 1;                        //允许中断
  247.                 S2CON |= (1<<4);        //允许接收
  248.                 P_SW2 &= ~0x01;        
  249.                 //P_SW2 |= 1;                        //UART2 switch to: 0: P1.0 P1.1,  1: P4.6 P4.7
  250.                 B_TX2_Busy = 0;
  251.         }
  252. }
  253. //========================================================================
  254. // 函数: void UART1_int (void) interrupt UART1_VECTOR
  255. // 描述: UART1中断函数。
  256. // 参数: nine.
  257. // 返回: none.
  258. // 版本: VER1.0
  259. // 日期: 2014-11-28
  260. // 备注:
  261. //========================================================================
  262. void UART1_int (void) interrupt UART1_VECTOR
  263. {
  264.         if(RI)
  265.         {
  266.                 RI = 0;        
  267.         }
  268.         if(TI)
  269.         {
  270.                 TI = 0;
  271.                 B_TX1_Busy = 0;
  272.         }
  273. }
  274. //========================================================================
  275. // 函数: void UART2_int (void) interrupt UART2_VECTOR
  276. // 描述: UART2中断函数。
  277. // 参数: nine.
  278. // 返回: none.
  279. // 版本: VER1.0
  280. // 日期: 2014-11-28
  281. // 备注:
  282. //========================================================================
  283. void UART2_int (void) interrupt UART2_VECTOR

  284. {
  285.         if((S2CON & 1) != 0)
  286.         {
  287.                
  288.                 S2CON &= ~1;        //Clear Rx flag        
  289.           Rec_Char = S2BUF;        
  290.                 SBUF = Rec_Char;
  291.                 //SBUF = S2BUF;                        
  292.         }
  293.         if(Rec_Char == 0xD0)
  294.         {
  295.                  Haertbeat_Detection = 1;               
  296.         }
  297.         else
  298.         {
  299.                                 if ((Rec_Char == 0x00) && (Haertbeat_Detection == 1))
  300.                                 {  
  301.                      Haertbeat_Flag=1;
  302.                         }
  303.                         else
  304.                                 Haertbeat_Detection = 0;
  305.         
  306.                         Rec_Fax_Text[Rec_Num]  =   Rec_Char;
  307.                          if (Rec_Char=='{')
  308.                          {
  309.                            Com_Turn_Light = 1;
  310.                          }
  311.                         if (Com_Turn_Light == 1)
  312.                          {
  313.                            if (Rec_Fax_Text[Rec_Num] == '}')
  314.                                  {
  315.                                    Com_Turn_Light = 0;
  316.                                          Rec_Num=0;
  317.                             if(strstr((const char*)Rec_Fax_Text,"LED01")!=NULL)
  318.                                         {
  319.                                           P00 = 0;
  320.                                         }
  321.                                         else
  322.                                                 if (strstr((const char*)Rec_Fax_Text,"LED00")!=NULL)
  323.                                                 {
  324.                                                   P00 = 1;
  325.                                                 }
  326.                                  }
  327.                                 else Rec_Num++;
  328.                          }
  329.                 }
  330.         
  331.    if((S2CON & 2) !=0)
  332.                  {
  333.                 S2CON &= ~2;        //Clear Tx flag
  334.                 B_TX2_Busy = 0;
  335.      }
  336. }


  337. //========================================================================
  338. // 函数:
  339. // 备注:
  340. //========================================================================

  341. void wifi_Inti()
  342. {
  343.         
  344.           PrintString2("+++");
  345.           Delay10000ms();        
  346.           Delay10000ms();
  347.           PrintString2("AT\r\n");
  348.           Delay10000ms();
  349.     PrintString2("AT+CWMODE=3\r\n");
  350.           Delay10000ms();
  351.     PrintString2("AT+RST\r\n");
  352.            Delay10000ms();        
  353. PrintString2("AT+CWJAP=\"QQ_MI\",\"12345678\"\r\n");
  354.         //  PrintString2("AT+CWJAP=\"iPhoneSE\",\"12345678\"\r\n");
  355.                 Delay10000ms();
  356.                 Delay10000ms();
  357.           Delay10000ms();        
  358.           Delay10000ms();
  359.                 Delay10000ms();
  360.           Delay10000ms();        
  361.     PrintString2("AT+CIPSTART=\"TCP\",\"183.230.40.39\",876\r\n");
  362.     Delay10000ms();        
  363.           Delay10000ms();
  364.     PrintString2("AT+CIPMODE=1\r\n");
  365.                 Delay10000ms();
  366.           PrintString2("AT+CIPSEND\r\n");
  367.                 Delay10000ms();
  368.                   
  369. }
  370. //========================================================================
  371. // 函数:
  372. // 备注:
  373. //========================================================================

  374. void Delay10000ms()                //@11.0592MHz
  375. {
  376.         unsigned char i, j, k;

  377.         _nop_();
  378.         _nop_();
  379.         i = 165;
  380.         j = 59;
  381.         k = 28;
  382.         do
  383.         {
  384.                 do
  385.                 {
  386.                         while (--k);
  387.                 } while (--j);
  388.         } while (--i);
  389. }


  390. void Delay3000ms()                //@11.0592MHz
  391. {
  392.         unsigned char i, j, k;

  393.         _nop_();
  394.         _nop_();
  395.         i = 127;
  396.         j = 18;
  397.         k = 107;
  398.         do
  399.         {
  400.                 do
  401.                 {
  402.                         while (--k);
  403.                 } while (--j);
  404.         } while (--i);
  405. }

  406. void Delay_10us()                //@22.1184MHz
  407. {
  408.         unsigned char i;

  409.         _nop_();
  410.         _nop_();
  411.         _nop_();
  412.         i = 52;
  413.         while (--i);
  414. }


  415. void Delay18ms()                //@22.1184MHz
  416. {
  417.         unsigned char i, j, k;

  418.         _nop_();
  419.         i = 2;
  420.         j = 132;
  421.         k = 67;
  422.         do
  423.         {
  424.                 do
  425.                 {
  426.                         while (--k);
  427.                 } while (--j);
  428.         } while (--i);
  429. }

  430. //========================================================================
  431. // 函数:
  432. // 备注:
  433. //========================================================================

  434. void COM(void)
  435. {     
  436.         u8 i;
  437.   for(i=0;i<8;i++)           
  438.         {
  439.                 U8FLAG=2;        
  440.           while((!P20)&&U8FLAG++);
  441.                 Delay_10us();
  442.                 Delay_10us();
  443.           Delay_10us();
  444.           U8temp=0;
  445.           if(P20)U8temp=1;
  446.                 U8FLAG=2;
  447.           while((P20)&&U8FLAG++);
  448.                 //超时则跳出for循环                  
  449.           if(U8FLAG==1)break;
  450.           //判断数据位是0还是1                  
  451.                 //如果高电平高过预定0高电平值则数据位为 1
  452.           U8comdata<<=1;
  453.           U8comdata|=U8temp;        //0
  454.         }//rofc
  455. }
  456. //========================================================================
  457. // 函数:
  458. // 备注:
  459. //========================================================================
  460. void RH(void)
  461. {
  462.           //主机拉低18ms
  463.    P20=0;
  464.         Delay18ms();
  465.          P20=1;
  466.          //总线由上拉电阻拉高 主机延时20us
  467.          Delay_10us();
  468.          Delay_10us();
  469.          Delay_10us();
  470.          Delay_10us();
  471.          //主机设为输入 判断从机响应信号
  472.          P20=1;
  473.          //判断从机是否有低电平响应信号 如不响应则跳出,响应则向下运行         
  474.          if(!P20)                 //T !         
  475.          {
  476.            U8FLAG=2;
  477.            //判断从机是否发出 80us 的低电平响应信号是否结束         
  478.            while((!P20)&&U8FLAG++);
  479.            U8FLAG=2;
  480.            //判断从机是否发出 80us 的高电平,如发出则进入数据接收状态
  481.            while((P20)&&U8FLAG++);
  482.            //数据接收状态                 
  483.            COM();
  484.            U8RH_data_H_temp=U8comdata;
  485.            COM();
  486.            U8RH_data_L_temp=U8comdata;
  487.            COM();
  488.            U8T_data_H_temp=U8comdata;
  489.            COM();
  490.            U8T_data_L_temp=U8comdata;
  491.            COM();
  492.            U8checkdata_temp=U8comdata;
  493.            P20=1;
  494.          //数据校验
  495.          
  496.            U8temp=(U8T_data_H_temp+U8T_data_L_temp+U8RH_data_H_temp+U8RH_data_L_temp);
  497.            if(U8temp==U8checkdata_temp)
  498.            {
  499.                      U8RH_data_H=U8RH_data_H_temp;
  500.                      U8RH_data_L=U8RH_data_L_temp;
  501.                     U8T_data_H=U8T_data_H_temp;
  502.                      U8T_data_L=U8T_data_L_temp;
  503.                      U8checkdata=U8checkdata_temp;
  504.                         
  505.                          disbuf_h[0]=U8RH_data_H/10+0x30;
  506.                          disbuf_h[1]=U8RH_data_H%10+0x30;
  507.                          disbuf_t[0]=U8T_data_H/10+0x30;
  508.                          disbuf_t[1]=U8T_data_H%10+0x30;
  509.                         

  510.                         
  511.            }//fi
  512.         }//fi
  513. }
  514.         


  515. //========================================================================
  516. // 函数:
  517. // 备注:  (u8 *puts)
  518. //========================================================================

  519. void Up_humidity()
  520. {
  521.         u8 i;
  522.   PrintString_Data(humidity_Data2);
  523.   for (i=0;i<2;i++)
  524.   {
  525.                 S2BUF=disbuf_h[i];
  526.                 B_TX2_Busy = 1;
  527.                 while(B_TX2_Busy);
  528.         }
  529. }

  530. //========================================================================
  531. // 函数:
  532. // 备注:  (u8 *puts)
  533. //========================================================================
  534. void Up_temperature()
  535. {
  536.         u8 i;
  537.   PrintString_Data(temperature_Data1);
  538.   for (i=0;i<2;i++)
  539.   {
  540.                 S2BUF=disbuf_t[i];
  541.                 B_TX2_Busy = 1;
  542.                 while(B_TX2_Busy);
  543.         }
  544. }
复制代码

所有资料51hei提供下载:
08-双串口中断收发.rar (87.2 KB, 下载次数: 24)


评分

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

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏5 分享淘帖 顶1 踩
回复

使用道具 举报

沙发
ID:273904 发表于 2019-5-31 23:47 来自手机 | 只看该作者
能问一下楼主什么专业的吗?
回复

使用道具 举报

板凳
ID:315093 发表于 2020-1-16 13:56 | 只看该作者
楼主,有没有JSON在51上的应用实例?
回复

使用道具 举报

地板
ID:564281 发表于 2020-2-23 14:13 | 只看该作者
楼主用什么软件写的啊?是51单片机吗?
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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