久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3895|回復: 0
打印 上一主題 下一主題
收起左側

51單片機智能藍牙APP定時器開關插座喂食器藥盒程序 原理圖

[復制鏈接]
跳轉到指定樓層
樓主
電路原理圖如下:


單片機源程序如下:
  1. #include <reg52.h>
  2. #include <intrins.h>
  3. #include <stdio.h>
  4. #include "delay.h"
  5. #include "ds1302.h"
  6. #include "1602.h"

  7. sbit relay = P1^3;//接口定義



  8. unsigned char dis0[16];//定義顯示區域臨時存儲數組
  9. unsigned char dis1[16];
  10. unsigned char dis2[16];

  11. unsigned char ReadTimeFlag= 0;//讀取時間標志
  12. unsigned char SetFlag =0;        //時間設置標志
  13. unsigned char i;
  14. unsigned char relayFlag=0;        //繼電器狀態標志

  15. unsigned long times_20ms=0xaaaaaaaa;        //定時器計數 初始值可以任意值 這里隨便賦值為0xaaaaaaaa
  16. unsigned char uart_i =0;                   //串口接收計數
  17. unsigned char time_buf2[17]={20,18,4,1,12,55,00,6};//空年月日時分秒周;           //更新時間數組
  18. bit ReadTempFlag;//定義讀時間標志

  19. unsigned char repotimes ;
  20. unsigned char disFlag ;        //更新

  21. xdata unsigned char dsHour_start_01 = 8;         //定時時分
  22. xdata unsigned char dsMin_start_01 = 0;
  23. xdata unsigned char dsHour_end_01 = 18;         
  24. xdata unsigned char dsMin_end_01 = 30;

  25. //xdata unsigned char dsHour_start_01 = 8;         //A組定時時分
  26. //xdata unsigned char dsMin_start_01 = 0;
  27. //xdata unsigned char dsH02_A = 12;         
  28. //xdata unsigned char dsM02_A = 30;

  29. unsigned char timeOverFlag =0;

  30. xdata unsigned char firstin =0;                          //首次接收到標志
  31. xdata unsigned char tab[20];                                  //串口數據暫存
  32. xdata unsigned char Count=0;                                  //串口接收計數
  33. xdata unsigned char  uartbusy =0;                          //串口判忙

  34. void Init_Timer0(void);                 //函數聲明
  35. void uartSendStr(unsigned char *s,unsigned char length);
  36. void UART_Init(void);
  37. void uartSendByte(unsigned char dat);

  38. void main(void)
  39. {        
  40.         Init_Timer0();        //定時器0初始化
  41.                 times_20ms = 0; //初始化對應值   
  42.         UART_Init();
  43.         
  44.         relay = 0;//打開
  45.         DelayMs(200);            //延時有助于穩定
  46.         relay = 1;//關閉
  47.         
  48.         Ds1302_Init();
  49. //         Ds1302_Write_Time();
  50.         Ds1302_Read_Time();//讀取時間參數

  51.         uartSendStr("ready ok !",10);

  52.         LCD_Init();           //初始化液晶
  53.         DelayMs(20);          //延時有助于穩定
  54.         LCD_Clear();
  55.         LCD_Write_String(0,0,"my desiger! ");
  56.                   
  57.         while(1)
  58.         {                                       
  59.                  
  60.                 if(SetFlag==1)     //如果接收到串口信息則更新時鐘
  61.                 {
  62.                         for(i=0;i<8;i++)
  63.                         {
  64.                                 time_buf1[i]=time_buf2[2*i]*10+time_buf2[2*i+1];//數據整合,如2個數 1和5整合成15
  65.                         }
  66.                         Ds1302_Write_Time();//接收更新的時間然后寫入ds1302
  67.                         SetFlag=0;          //時鐘信息更新后標志位清零
  68.                 }
  69.                 if(disFlag == 1) //定時讀取ds1302 定時時間到 則標志位置1,處理過時間參數標志位清零
  70.                 {
  71.                         disFlag=0;  //標志位清零
  72.                         Ds1302_Read_Time();//讀取時間參數

  73.                         if((time_buf1[4]>=dsHour_start_01)&&(time_buf1[4]<=dsHour_end_01))  //對比時間段1
  74.                         {

  75.                                 if((dsHour_start_01 != dsHour_end_01))  //設置起止時不再同一小時
  76.                                 {
  77.                                         if((time_buf1[4]>dsHour_start_01)&&(time_buf1[4]<dsHour_end_01))        //兩個時 范圍內
  78.                                         {
  79.                                                 timeOverFlag = 1;//打開                                                        
  80.                                         }
  81.                                         else if((time_buf1[4] == dsHour_start_01) && (time_buf1[5]>=dsMin_start_01))  //啟停不在一個小時內 當前時間在啟動時內
  82.                                         {
  83.                                                  timeOverFlag = 1;//打開        
  84.                                         }
  85.                                         else if((time_buf1[4] == dsHour_end_01) && (time_buf1[5]<dsMin_end_01)) //啟停不在一個小時內 當前時間在停止時內
  86.                                         {
  87.                                                  timeOverFlag = 1;//打開        
  88.                                         }
  89.                                         else
  90.                                         {timeOverFlag = 0;}                                                               
  91.                                 }
  92.                                 else if((dsHour_end_01==dsHour_start_01))  //同一個小時內
  93.                                 {
  94.                                         if((time_buf1[5]>=dsMin_start_01) && (time_buf1[5]<dsMin_end_01)) //統一小時分鐘范圍內
  95.                                         {timeOverFlag = 1;}//打開                                                                        
  96.                                         else
  97.                                         {timeOverFlag = 0;}          //關閉
  98.                                 }
  99.                         }
  100.                         else
  101.                         {
  102.                                 timeOverFlag = 0;          //關閉
  103.                         }
  104.                         if(timeOverFlag == 1){relay = 0;}//打開 繼電器控制
  105.                         else {relay =1 ;}//關閉
  106.                         
  107.                         sprintf(dis0,"%02d-%02d-%02d-%d",(int)time_buf1[1],(int)time_buf1[2],(int)time_buf1[3],(int)time_buf1[7]);//年月日周 步數
  108.                         LCD_Write_String(0,0,dis0); //顯示數據

  109.                         sprintf(dis0,"s%02d:%02d",(int)dsHour_start_01,(int)dsMin_start_01);//起始時間
  110.                         LCD_Write_String(10,0,dis0); //顯示數據
  111.                         
  112.                         sprintf(dis1,"%02d:%02d:%02d  ",(int)time_buf1[4],(int)time_buf1[5],(int)time_buf1[6]);//時分秒                                                               
  113.                         LCD_Write_String(0,1,dis1); //顯示數據
  114.                         
  115.                         sprintf(dis1," e%02d:%02d",(int)dsHour_end_01,(int)dsMin_end_01);//結束時間                                                        
  116.                         LCD_Write_String(9,1,dis1); //顯示數據                        

  117.                         repotimes++;         
  118.                         if(repotimes >= 8)          //定時上報
  119.                         {
  120.                                 repotimes = 0;//上報時間
  121.         
  122.                                 sprintf(dis0,"*D20%02d%02d%02d#",(int)time_buf1[1],(int)time_buf1[2],(int)time_buf1[3],(int)time_buf1[7]);//年月日周
  123.                                 uartSendStr(dis0,11); //發送數據
  124.                                 uartSendStr("\r\n",2);
  125.         
  126.                                 sprintf(dis1,"*T%02d%02d%02d#",(int)time_buf1[4],(int)time_buf1[5],(int)time_buf1[6]);//時分秒                                                               
  127.                                 uartSendStr(dis1,9); //發送數據
  128.                                 uartSendStr("\r\n",2);
  129.         
  130.                                 sprintf(dis2,"*S%02d:%02d~%02d:%02d#",(int)dsHour_start_01,(int)dsMin_start_01,(int)dsHour_end_01,(int)dsMin_end_01);//打印                                
  131.                                 uartSendStr(dis2,14); //發送數據
  132.                                 uartSendStr("\r\n",2);
  133.                         }

  134.                 }


  135.         }
  136. }

  137. void Init_Timer0(void)
  138. {
  139. //**All notes can be deleted and modified**//
  140.   TMOD |= 0x10;          //使用模式1,16位定時器,使用"|"符號可以在使用多個定時器時不受影響                     
  141.         TH0=(65536-20000)/256;                  //重新賦值 20ms
  142.         TL0=(65536-20000)%256;
  143.         EA=1;            //總中斷打開
  144.         ET0=1;           //定時器中斷打開
  145.         TR0=1;           //定時器開關打開
  146. }

  147. void Timer0_isr(void) interrupt 1
  148. {
  149.         TH0=(65536-20000)/256;                  //重新賦值 20ms
  150.         TL0=(65536-20000)%256;
  151.         times_20ms++;  //計時++

  152.         if(times_20ms%5==0)
  153.         {
  154.                 disFlag=1;          //定時更新顯示 100ms
  155.         }         

  156.         if(uartbusy>0)           //串口數據采集處理
  157.         {uartbusy--;} //串口一定時間內接收到數據
  158.         else
  159.         {
  160.                 firstin =0; //重新賦值接收數據
  161.                 Count=0;//接收計數
  162.         }

  163. }


  164. void UART_Init(void)
  165. {
  166.     SCON  = 0x50;                        // SCON: 模式 1, 8-bit UART, 使能接收  
  167.     TMOD |= 0x20;               // TMOD: timer 1, mode 2, 8-bit 重裝
  168.     TH1   = 0xFD;               // TH1:  重裝值 9600 波特率 晶振 11.0592MHz
  169.         TL1 = TH1;  
  170.     TR1   = 1;                  // TR1:  timer 1 打開                        
  171.     EA    = 1;                  //打開總中斷
  172.     ES    = 1;                  //打開串口中斷
  173. }

  174. void uartSendByte(unsigned char dat)
  175. {
  176.         unsigned char time_out;
  177.         time_out=0x00;
  178.         SBUF = dat;                          //將數據放入SBUF中
  179.         while((!TI)&&(time_out<100))  //檢測是否發送出去
  180.         {time_out++;DelayUs2x(10);}        //未發送出去 進行短暫延時
  181.         TI = 0;                                                //清除ti標志
  182. }

  183. void uartSendStr(unsigned char *s,unsigned char length)
  184. {
  185.         unsigned char NUM;
  186.         NUM=0x00;
  187.         while(NUM<length)        //發送長度對比
  188.         {
  189.                 uartSendByte(*s);  //放松單字節數據
  190.                 s++;                  //指針++
  191.                 NUM++;                  //下一個++
  192.            }
  193. }

  194. void UART_SER (void) interrupt 4         //串行中斷服務程序
  195. {
  196.         unsigned char r_buf;
  197.         if(RI)                        //判斷是接收中斷產生
  198.         {
  199.                 RI=0;                      //標志位清零
  200.                 r_buf = SBUF;
  201.                 uartbusy = 20;
  202.                 if(r_buf=='*')                //接收到起始標志
  203.                 {                        
  204.                         firstin = 1; //接收標志成功
  205.                         Count = 0;
  206.                         tab[Count++]=r_buf;
  207.                 }
  208.                 else if(firstin == 1)          //接收到其實標志成功
  209.                 {
  210.                         tab[Count++]=r_buf;
  211.                         if((Count>=18)&&(tab[17] == '#')) //接收到設置時間命令
  212.                         {
  213.                                 for(i=0;i<16;i++)
  214.                                 {
  215.                                          time_buf2[i]=tab[1+i]&0x0F; //提取設置值
  216.                                 }
  217.                                 SetFlag=1 ;                 //設置時間標志置位
  218.                                 firstin =0;
  219.                                 Count=0;                                
  220.                         }
  221.                         else if((Count>=14)&&(tab[13] == '#')) //接收到設置時間段//**All notes can be deleted and modified**//
  222.                         {
  223.                                 if(tab[2] == 'T')
  224.                                 {
  225.                                         dsHour_start_01 =( tab[3] - '0'        )*10 + (tab[4]-'0');  //起始時間提取
  226.                                         dsMin_start_01 =( tab[5] - '0'        )*10 + (tab[6]-'0');

  227.                                         dsHour_end_01 =( tab[8] - '0'        )*10 + (tab[9]-'0'); //結束時間提取
  228.                                         dsMin_end_01 =( tab[10] - '0'        )*10 + (tab[11]-'0');                                                                        
  229.                                 }                                
  230.                                 firstin =0;
  231.                                 Count=0;
  232.                         }
  233.                         else if(Count>=20) //接收數據很長 但是不是所需要的
  234.                         {               
  235.                                 firstin =0;
  236.                                 Count=0;
  237.                         }        
  238.                 }
  239.         }
  240.         if(TI)  //如果是發送標志位,清零
  241.         TI=0;
  242. }
復制代碼

代碼: 51-162、程序-單片機源碼.zip (90.66 KB, 下載次數: 48)






評分

參與人數 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏6 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 99re在线视频| 精品久久久久久国产 | 天天躁日日躁狠狠的躁天龙影院 | 蜜桃传媒av| 性色视频 | 一区二区精品在线 | 免费看91 | 日韩免费视频一区二区 | 国产欧美性成人精品午夜 | 91亚洲国产成人久久精品网站 | 国产日韩欧美激情 | 久久久久久国产精品 | 欧美日韩一区二区三区四区 | 久久久久国产精品免费免费搜索 | 亚洲激精日韩激精欧美精品 | 超碰在线人| 91精品国产一区二区在线观看 | 国产一区二区在线免费 | 欧美日韩综合精品 | 国产精品九九视频 | 69性欧美高清影院 | 日韩午夜影院 | 亚洲欧美高清 | 午夜影院网站 | 日韩免费毛片视频 | 999免费视频| 免费一区二区三区 | 日本精a在线观看 | 成年人视频在线免费观看 | 国产日韩欧美在线观看 | 欧美精品一区免费 | 久久久精品视 | 亚洲国产偷 | 亚洲色欲色欲www | 中文字幕加勒比 | 91精品在线播放 | 中文字幕一区二区三区四区五区 | 亚洲精品视频网站在线观看 | 少妇无套高潮一二三区 | 久热久草| 国产乱码高清区二区三区在线 |