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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 4884|回復(fù): 1
打印 上一主題 下一主題
收起左側(cè)

單片機雙路可編程溫度控制系統(tǒng)原理圖與PCB源碼等資料 溫度測量 比較 報警

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:280979 發(fā)表于 2018-2-24 13:42 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
Altium Designer畫的溫度開發(fā)板原理圖和PCB圖如下:(51hei附件中可下載工程文件)


雙路可編程溫度控制系統(tǒng)產(chǎn)品使用手冊
【簡要說明】
  • 尺寸:長72mmX寬86mmX高20mm
    二、 主要芯片:單片機、DS18B20、數(shù)碼管
    三、 工作電壓:輸入電壓小于12V,另有24V 可選。功耗小于2W
    四、 特點:1、具有輸出電壓指示燈。
    2、輸出具有指示燈
    3、采用螺旋壓接端子。
    4、強大的濾波電路。
    5、具有四位數(shù)碼管顯示,可以顯示小數(shù)點。
    6、具有系統(tǒng)復(fù)位功能
    7、具有完善的保護電路:電流限制、熱關(guān)斷電路、電源防接反功能、續(xù)流保護、光耦隔離
    8、可接兩個DS18B20傳感器
    9、兩路繼電器獨立工作控制
            10、可以自由編程,提供參考程序
            11、繼電器所有觸點全部輸出
            12、三個輸入控制按鍵,通過程序也可以自由設(shè)定
            13、工作穩(wěn)定可靠。           
            14、工作溫度范圍-40℃~+70℃
            15、工作濕度 40%  ~ 80%RH
            16、可裝入槽型板,并安裝在DIN導(dǎo)軌上。
DS18B20基本知識
 DS18B20數(shù)字溫度計是DALLAS公司生產(chǎn)的1-Wire,即單總線器件,具有線路簡單,體積小的特點。因此用它來組成一個測溫系統(tǒng),具有線路簡單,在一根通信線,可以掛很多這樣的數(shù)字溫度計,十分方便。
1、DS18B20產(chǎn)品的特點
  (1)、只要求一個端口即可實現(xiàn)通信。
  (2)、在DS18B20中的每個器件上都有獨一無二的序列號。
  (3)、實際應(yīng)用中不需要外部任何元器件即可實現(xiàn)測溫。
 。4)、測量溫度范圍在-55。C到+125。C之間。
 。5)、數(shù)字溫度計的分辨率用戶可以從9位到12位選擇。
  (6)、內(nèi)部有溫度上、下限告警設(shè)置。
2、DS18B20的引腳介紹
  TO-92封裝的DS18B20的引腳排列見圖1,其引腳功能描述見表1。
(底視圖)圖1
 
表1 DS18B20詳細引腳功能描述
序號
名稱
引腳功能描述
1
GND
地信號
2
DQ
數(shù)據(jù)輸入/輸出引腳。開漏單總線接口引腳。當被用著在寄生電源下,也可以向器件提供電源。
3
VDD
可選擇的VDD引腳。當工作于寄生電源時,此引腳必須接地。
3. DS18B20的使用方法
由于DS18B20采用的是1-Wire總線協(xié)議方式,即在一根數(shù)據(jù)線實現(xiàn)數(shù)據(jù)的雙向傳輸,而對AT89S51單片機來說,硬件上并不支持單總線協(xié)議,因此,我們必須采用軟件的方法來模擬單總線的協(xié)議時序來完成對DS18B20芯片的訪問。
由于DS18B20是在一根I/O線上讀寫數(shù)據(jù),因此,對讀寫的數(shù)據(jù)位有著嚴格的時序要求。DS18B20有嚴格的通信協(xié)議來保證各位數(shù)據(jù)傳輸?shù)恼_性和完整性。該協(xié)議定義了幾種信號的時序:初始化時序、讀時序、寫時序。所有時序都是將主機作為主設(shè)備,單總線器件作為從設(shè)備。而每一次命令和數(shù)據(jù)的傳輸都是從主機主動啟動寫時序開始,如果要求單總線器件回送數(shù)據(jù),在進行寫命令后,主機需啟動讀時序完成數(shù)據(jù)接收。數(shù)據(jù)和命令的傳輸都是低位在先。


【標注說明】
功能描述

原理圖
PCB
元件清單
元件清單
應(yīng)用舉例“恒溫控制”
設(shè)定某個溫度值,當溫度大于這個溫度時繼電器工作,小于這個設(shè)定值時停止。設(shè)定溫度值具有掉電記憶功能。

源程序見附件

應(yīng)用舉例“比較控制系統(tǒng)”
功能描述:板子;雙路溫控繼電器,兩個溫控探頭,上面的溫控探頭是A面顯示的溫度,下面的溫控探頭是B面顯示的溫度,
操作過程; 下完程序先設(shè)定C,先按加溫度鍵,然后再按減溫鍵,斷一下電再上電,這樣是為了設(shè)定掉電存儲
板子功能;  當A的溫度大于B的溫度到設(shè)定值時,繼電器A吸合,當再這個設(shè)定范圍時,斷開。有個問題,當B大于A時也會吸合。
  1. #include<reg52.h>
  2. #include<math.h>
  3. #include "INTRINS.H"
  4. #define uchar unsigned char
  5. #define uint  unsigned int
  6. //數(shù)碼管顯示段碼
  7. code unsigned char duan[]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90,0x88, 0x83,  0xC6,  0xBF,0x7f};

  8. unsigned char dong[4] = { 0xFF, 0xFF, 0xFF, 0xFF};              //數(shù)碼管顯示緩沖區(qū)
  9. uchar i = 0;  //數(shù)碼管掃描動態(tài)索引
  10. uint time2,time3;
  11. uchar gai = 0;
  12. uchar mode = 1;                 //換頁變量

  13. /********************掉電存儲*********************************************/
  14. typedef unsigned char  INT8U;
  15. typedef unsigned int   INT16U;

  16. sfr IAP_DATA    = 0xC2;
  17. sfr IAP_ADDRH   = 0xC3;
  18. sfr IAP_ADDRL   = 0xC4;
  19. sfr IAP_CMD     = 0xC5;
  20. sfr IAP_TRIG    = 0xC6;
  21. sfr IAP_CONTR   = 0xC7;
  22. #define ENABLE_ISP 0x82 //系統(tǒng)工作時鐘<20MHz 時,對IAP_CONTR 寄存器設(shè)置此值

  23. union union_temp16
  24. {
  25.     INT16U un_temp16;
  26.     INT8U  un_temp8[2];
  27. }my_unTemp16;

  28. INT8U Byte_Read(INT16U add);              //讀一字節(jié),調(diào)用前需打開IAP 功能
  29. void Byte_Program(INT16U add, INT8U ch);  //字節(jié)編程,調(diào)用前需打開IAP 功能
  30. void Sector_Erase(INT16U add);            //擦除扇區(qū)
  31. void IAP_Disable();                       //關(guān)閉IAP 功能
  32. void Delay();
  33. /******************************18b20*************************************************************/
  34. bit flag1s = 0;          //1s定時標志

  35. extern bit Start18B20();   //18b20初始化函數(shù)
  36. extern bit Get18B20Temp(int *temp);              //18b20溫度讀取函數(shù)
  37. /******************************第二路溫控*************************************************/
  38. bit flag1ss = 0;          //1s定時標志

  39. extern bit Start18B200();   //18b20初始化函數(shù)
  40. extern bit Get18B20Tempp(int *tempp);              //18b20溫度讀取函數(shù)
  41. /*******************************************************************************************/

  42. sbit wei1 = P2^3;              //數(shù)碼管的位斷開關(guān)
  43. sbit wei2 = P2^4;            
  44. sbit wei3 = P2^5;
  45. sbit wei4 = P2^6;            
  46.             
  47. bit d1 = 1;   //換畫面按鍵當前值
  48. bit d2 = 1;                //計數(shù)加按鍵當前值
  49. bit d3 = 1;                //計數(shù)減按鍵當前值

  50. sbit s1 =   P2^0;    //計數(shù)加
  51. sbit s2 =   P2^1;              //計數(shù)減
  52. sbit s3 =   P2^2;              //換畫面按鈕

  53. sbit out1 = P1^2;              //高溫啟動
  54. sbit out2 = P1^3;              //低溫啟動

  55. uchar T0RH = 0;  //T0重載值的高字節(jié)
  56. uchar T0RL = 0;  //T0重載值的低字節(jié)


  57. void peizhit0(uint ms);              //配置t0定時器
  58. void key();                                                        //按鍵掃描函數(shù)

  59. void main()
  60. {
  61.               bit q1 = 1;
  62.               bit q2 = 1;
  63.               bit q3 = 1;
  64. /***********************18b20***************************************/
  65.               int intT, decT;  //溫度值的整數(shù)和小數(shù)部分
  66.               bit res ;
  67.     int temp;        //讀取到的當前溫度值
  68.               /***********************第二路18b20***************************************/
  69.               int  intTT, decTT;  //溫度值的整數(shù)和小數(shù)部分
  70.               bit ress ;
  71.     int tempp;        //讀取到的當前溫度值

  72.               Start18B20(); /*啟動DS18B20*/

  73.               Start18B200(); /*啟動DS18B20*/

  74. /***********************開機讀掉電存儲內(nèi)容******************************************************/
  75.                            
  76.                            
  77.                             time2 = Byte_Read(0x03)*255+Byte_Read(0x02);                 //注意這是把高字節(jié)和低字節(jié)合在一起
  78.                             time3 = Byte_Read(0x05)*255+Byte_Read(0x04);                 //讀三的時間
  79.                   EA = 1;       //開總中斷
  80.                   peizhit0(1);  //配置T0定時1ms

  81.               while(1)
  82.               {
  83. /*********************第一個按鍵換頁按鍵************************************/
  84.                             if(d3 != q3)
  85.                             {
  86.                                           q3 = d3;
  87.                                           if(d3 == 0)
  88.                                           {
  89.                                                         mode = mode+1;                                                        //功能設(shè)置,4個參數(shù),4個周期為一個循環(huán)
  90.                                                         if(mode == 4)
  91.                                                         {
  92.                                                                       mode = 1;
  93.                                                         }
  94.                                           }
  95.                             }
  96. /*******************************第二個按鍵按下*************************/

  97.                             if(d2 != q2)
  98.                                           {
  99.                                                         q2 = d2;
  100.                                                         if(d2 == 0)
  101.                                                         {
  102.                                                          
  103.                                                                       if(mode ==2)
  104.                                                                       {
  105.                                                                                     if(time2>0)
  106.                                                                                     {
  107.                                                                                                   time2--;
  108.                                                                                     }
  109.                                                                       }
  110.                                                                       else if(mode ==3)
  111.                                                                       {
  112.                                                                                     if(time3>0)
  113.                                                                                     {
  114.                                                                                                   time3--;
  115.                                                                                     }
  116.                                                                       }

  117.                                                                       EA = 0;
  118.                                                                       Sector_Erase(0);           //擦除0x01地址中的數(shù)據(jù)
  119.                                                                      
  120.                                                                       Byte_Program(0x02,time2);
  121.                                                                       Byte_Program(0x03,time2>>8);
  122.                                                                       Byte_Program(0x04,time3);
  123.                                                                       Byte_Program(0x05,time3>>8);
  124.                                                                       EA = 1;
  125.                                                         }
  126.                                              }
  127. /*****************************第二個按鍵按下***************************/

  128.                             if(d1 != q1)
  129.                                           {
  130.                                                         q1 = d1;
  131.                                                         if(d1 == 0)
  132.                                                         {
  133.                                                          
  134.                                                                       if(mode ==2)                                                                        // b
  135.                                                                       {
  136.                                                                                     time2 = (time2+1)%999;                                          
  137.                                                                       }
  138.                                                                       else if(mode ==3)
  139.                                                                       {
  140.                                                                                     time3 = (time3+1)%999;//c                                          
  141.                                                                       }

  142.                                                                       EA = 0;
  143.                                                                       Sector_Erase(0);           //擦除0x01地址中的數(shù)據(jù)
  144.                                                                      
  145.                                                                       Byte_Program(0x02,time2);
  146.                                                                       Byte_Program(0x03,time2>>8);
  147.                                                                       Byte_Program(0x04,time3);
  148.                                                                       Byte_Program(0x05,time3>>8);
  149.                                                                       EA = 1;
  150.                                                         }
  151.                                              }

  152.   /***************第一層顯示**************************/
  153.                                              if(mode == 1)                                                                        
  154.                                           {
  155.                                                       
  156.                                                         dong[0] = duan [10];
  157.                                                         dong[1] = duan [intT/100%10];
  158.                                     dong[2] = duan [intT/10%10];
  159.                                     dong[3] = duan [intT%10];
  160.                                           }
  161.                               /*************第二層顯示**************************/
  162.                                              if(mode == 2)                                                                        
  163.                                           {
  164.                                                         dong[0] = duan [11];
  165.                                                         dong[1] = duan [intTT/100%10];
  166.                                     dong[2] = duan [intTT/10%10];
  167.                                     dong[3] = duan [intTT%10];
  168.                                           }
  169.                             /*************第三層顯示**************************/
  170.                                              if(mode == 3)                                                                        
  171.                                           {
  172.                                                         dong[0] = duan [12];
  173.                                                         dong[1] = duan [time3/100%10];
  174.                                     dong[2] = duan [time3/10%10];
  175.                                     dong[3] = duan [time3%10];
  176.                                           }
  177. /*****************************溫控部分**************************************************/

  178.                   if (flag1s)  //每秒更新一次溫度
  179.         {
  180.                                             flag1s = 0;
  181.                                                gai++;
  182.                                             Start18B20(); // 注意  一定要隨著溫度讀取函數(shù)一起每秒更新啟動一次 不然就只能讀取到剛上電那一瞬間的溫度   啟動DS18B20
  183.                         res = Get18B20Temp(&temp);  //讀取當前溫度

  184.                         intT = temp*10 >> 4;             // 注意在這個地方temp*10就是精確1位小數(shù)點,*100就是精確兩位小數(shù)點 但是只能精確一位小數(shù)點   分離出溫度值整數(shù)部分
  185.             decT = temp & 0xF;            //分離出溫度值小數(shù)部分
  186.                 /*
  187.                                           if((intT <= time2) && (intT >= time3))                                          //注意  控制部分要放到  這個函數(shù)內(nèi) 不然上電就會先比較  會有動作  放在這里就可以先讀取再比較  穩(wěn)定
  188.                             {
  189.                                           out2 = 1;
  190.                                           out1 = 1;            
  191.                             }
  192.                             if(intT >= time2)
  193.                             {
  194.                                           out2 = 1;
  195.                                           //out1 = 0;
  196.                                           if(gai >= 3)
  197.                                           {
  198.                                                         gai = 0;
  199.                                                         out1 = ~out1;            
  200.                                           }
  201.                             }
  202.                            
  203.                             if(intT <= time3)
  204.                             {
  205.                                           out1 = 1;
  206.                                           //out2 = 0;
  207.                                                         if(gai >= 3)
  208.                                           {
  209.                                                         gai = 0;
  210.                                                         out2 = ~out2;            
  211.                                           }
  212.             
  213.                             }
  214.     */
  215.                 }
  216.                            
  217.                
  218.                 if (flag1ss)  //每秒更新一次溫度
  219.         {
  220.                                             flag1ss = 0;
  221.                                              
  222.                                             Start18B200(); // 注意  一定要隨著溫度讀取函數(shù)一起每秒更新啟動一次 不然就只能讀取到剛上電那一瞬間的溫度   啟動DS18B20
  223.                         ress = Get18B20Tempp(&tempp);  //讀取當前溫度

  224.                         intTT = tempp*10 >> 4;             // 注意在這個地方temp*10就是精確1位小數(shù)點,*100就是精確兩位小數(shù)點 但是只能精確一位小數(shù)點   分離出溫度值整數(shù)部分
  225.             decTT = tempp & 0xF;            //分離出溫度值小數(shù)部分


  226.                                          
  227.       }
  228.               /*************************************************************/
  229.               if((intT-intTT) >= time3)
  230.               {
  231.                             out2 = 0;
  232.               }
  233.               else
  234.               {
  235.                             out2 = 1;
  236.               }
  237.                                          
  238. /************************************************************************/
  239.               }            
  240. }

  241. /* 配置并啟動T0,ms-T0定時時間 */
  242. void peizhit0(uint ms)
  243. {
  244.     unsigned long tmp;  //臨時變量

  245.     tmp = 11059200 / 12;      //定時器計數(shù)頻率                 注意 因為晶振是11.0592,,12個震蕩周期才是一個機器周期,所以,計數(shù)器加一所用的頻率就是11059200/12
  246.     tmp = (tmp * ms) / 1000;  //計算所需的計數(shù)值   注意 上面的計數(shù)時間單位是秒,所以除以1000就轉(zhuǎn)化為ms了
  247.     tmp = 65536 - tmp;        //計算定時器重載值
  248.     tmp = tmp + 18;           //補償中斷響應(yīng)延時造成的誤差
  249.     T0RH = (unsigned char)(tmp>>8);  //定時器重載值拆分為高低字節(jié)              注意  因為是char型所以這個數(shù)據(jù)如果不向左移動8位他就只能保存低位的8位數(shù)據(jù),一個char型變量保存是從低8位先保存,保存完后如果有空間再保存高位,向右移動8位就是讓它從高位開始保存,這個16位計數(shù)換成二進制是 1111 1000 1101 1110
  250.     T0RL = (unsigned char)tmp;                            //直接保存低字節(jié)數(shù)據(jù)
  251.     TMOD &= 0xF0;   //清零T0的控制位
  252.     TMOD |= 0x01;   //配置T0為模式1
  253.     TH0 = T0RH;     //加載T0重載值
  254.     TL0 = T0RL;
  255.     ET0 = 1;        //使能T0中斷
  256.     TR0 = 1;        //啟動T0
  257. }
  258. /*按鍵掃描函數(shù)*/
  259. void key()
  260. {
  261.               static uchar saomiaozhi[3] = {1,1,1};
  262.               saomiaozhi[0] = (saomiaozhi[0]<<1) | s1;
  263.               saomiaozhi[1] = (saomiaozhi[1]<<1) | s2;
  264.               saomiaozhi[2] = (saomiaozhi[2]<<1) | s3;

  265.               if(saomiaozhi[0] == 0x00)
  266.               {
  267.                             d1 = 0;
  268.               }
  269.               if(saomiaozhi[0] == 0xff)
  270.               {
  271.                             d1 = 1;
  272.               }
  273.               if(saomiaozhi[1] == 0x00)
  274.               {
  275.                             d2 = 0;
  276.               }
  277.               if(saomiaozhi[1] == 0xff)
  278.               {
  279.                             d2 = 1;
  280.               }
  281.               if(saomiaozhi[2] == 0x00)
  282.               {
  283.                             d3 = 0;
  284.               }
  285.               if(saomiaozhi[2] == 0xff)
  286.               {
  287.                             d3 = 1;
  288.               }
  289.             
  290. }

  291. /* T0中斷服務(wù)函數(shù),完成數(shù)碼管、按鍵掃描與秒表計數(shù) */
  292. void t0() interrupt 1
  293. {
  294.               static uchar c = 0;
  295.               static unsigned int tmr1s = 0;
  296.               static unsigned int tmr1ss = 0;
  297.     TH0 = T0RH;  //重新加載重載值
  298.     TL0 = T0RL;
  299.               c++;
  300.               tmr1s++;
  301.               tmr1ss++;
  302.               if (tmr1s >= 1000)  //定時1s
  303.     {
  304.         tmr1s = 0;
  305.         flag1s = 1;
  306.                            
  307.     }
  308.               if (tmr1ss >= 1000)  //定時1s
  309.     {
  310.         tmr1ss = 0;
  311.         flag1ss = 1;
  312.                            
  313.     }
  314.               if(c >= 2)
  315.               {  c = 0;
  316.                  key();                            //按鍵掃描函數(shù)
  317.               }

  318.               P0 = 0xff;
  319.               switch (i)
  320.    {
  321.                    case 0: wei1 = 0; wei2 = 1; wei3 = 1;wei4 = 1; i++;  P0 = dong[0];     break;
  322.                 case 1: wei1 = 1; wei2 = 0; wei3 = 1;wei4 = 1; i++;  P0 = dong[1];     break;
  323.                 case 2: wei1 = 1; wei2 = 1; wei3 = 0;wei4 = 1; i++;  P0 = dong[2];     break;
  324.                 case 3: wei1 = 1; wei2 = 1; wei3 = 0;wei4 = 1; i++;  P0 = 0x7f;     break;
  325.                 case 4: wei1 = 1; wei2 = 1; wei3 = 1;wei4 = 0; i=0;  P0 = dong[3];     break;
  326.                 default: break;
  327.               }
  328. }
  329. /******************************掉電儲存功能********************************************************/
  330. //讀一字節(jié),調(diào)用前需打開IAP 功能,入口:DPTR = 字節(jié)地址,返回:A = 讀出字節(jié)
  331. INT8U Byte_Read(INT16U add)
  332. {
  333.     IAP_DATA = 0x00;
  334.     IAP_CONTR = ENABLE_ISP;         //打開IAP 功能, 設(shè)置Flash 操作等待時間
  335.     IAP_CMD = 0x01;                 //IAP/ISP/EEPROM 字節(jié)讀命令

  336.     my_unTemp16.un_temp16 = add;
  337.     IAP_ADDRH = my_unTemp16.un_temp8[0];    //設(shè)置目標單元地址的高8 位地址
  338.     IAP_ADDRL = my_unTemp16.un_temp8[1];    //設(shè)置目標單元地址的低8 位地址

  339.     //EA = 0;
  340.     IAP_TRIG = 0x5A;   //先送 5Ah,再送A5h 到ISP/IAP 觸發(fā)寄存器,每次都需如此
  341.     IAP_TRIG = 0xA5;   //送完A5h 后,ISP/IAP 命令立即被觸發(fā)起動
  342.     _nop_();
  343.     //EA = 1;
  344.     IAP_Disable();  //關(guān)閉IAP 功能, 清相關(guān)的特殊功能寄存器,使CPU 處于安全狀態(tài),
  345.                     //一次連續(xù)的IAP 操作完成之后建議關(guān)閉IAP 功能,不需要每次都關(guān)
  346.     return (IAP_DATA);
  347. }

  348. //字節(jié)編程,調(diào)用前需打開IAP 功能,入口:DPTR = 字節(jié)地址, A= 須編程字節(jié)的數(shù)據(jù)
  349. void Byte_Program(INT16U add, INT8U ch)
  350. {
  351.     IAP_CONTR = ENABLE_ISP;         //打開 IAP 功能, 設(shè)置Flash 操作等待時間
  352.     IAP_CMD = 0x02;                 //IAP/ISP/EEPROM 字節(jié)編程命令

  353.     my_unTemp16.un_temp16 = add;
  354.     IAP_ADDRH = my_unTemp16.un_temp8[0];    //設(shè)置目標單元地址的高8 位地址
  355.     IAP_ADDRL = my_unTemp16.un_temp8[1];    //設(shè)置目標單元地址的低8 位地址

  356.     IAP_DATA = ch;                  //要編程的數(shù)據(jù)先送進IAP_DATA 寄存器
  357.     //EA = 0;
  358.     IAP_TRIG = 0x5A;   //先送 5Ah,再送A5h 到ISP/IAP 觸發(fā)寄存器,每次都需如此
  359.     IAP_TRIG = 0xA5;   //送完A5h 后,ISP/IAP 命令立即被觸發(fā)起動
  360.     _nop_();
  361.     //EA = 1;
  362.     IAP_Disable();  //關(guān)閉IAP 功能, 清相關(guān)的特殊功能寄存器,使CPU 處于安全狀態(tài),
  363.                     //一次連續(xù)的IAP 操作完成之后建議關(guān)閉IAP 功能,不需要每次都關(guān)
  364. }

  365. //擦除扇區(qū), 入口:DPTR = 扇區(qū)地址
  366. void Sector_Erase(INT16U add)
  367. {
  368.     IAP_CONTR = ENABLE_ISP;         //打開IAP 功能, 設(shè)置Flash 操作等待時間
  369.     IAP_CMD = 0x03;                 //IAP/ISP/EEPROM 扇區(qū)擦除命令

  370.     my_unTemp16.un_temp16 = add;
  371.     IAP_ADDRH = my_unTemp16.un_temp8[0];    //設(shè)置目標單元地址的高8 位地址
  372.     IAP_ADDRL = my_unTemp16.un_temp8[1];    //設(shè)置目標單元地址的低8 位地址

  373.     //EA = 0;
  374.     IAP_TRIG = 0x5A;   //先送 5Ah,再送A5h 到ISP/IAP 觸發(fā)寄存器,每次都需如此
  375.     IAP_TRIG = 0xA5;   //送完A5h 后,ISP/IAP 命令立即被觸發(fā)起動
  376.     _nop_();
  377.     //EA = 1;
  378.     IAP_Disable();  //關(guān)閉IAP 功能, 清相關(guān)的特殊功能寄存器,使CPU 處于安全狀態(tài),
  379.                     //一次連續(xù)的IAP 操作完成之后建議關(guān)閉IAP 功能,不需要每次都關(guān)
  380. }

  381. void IAP_Disable()
  382. {
  383.     //關(guān)閉IAP 功能, 清相關(guān)的特殊功能寄存器,使CPU 處于安全狀態(tài),
  384.     //一次連續(xù)的IAP 操作完成之后建議關(guān)閉IAP 功能,不需要每次都關(guān)
  385.     IAP_CONTR = 0;      //關(guān)閉IAP 功能
  386.     IAP_CMD   = 0;      //清命令寄存器,使命令寄存器無命令,此句可不用
  387.     IAP_TRIG  = 0;      //清命令觸發(fā)寄存器,使命令觸發(fā)寄存器無觸發(fā),此句可不用
  388.     IAP_ADDRH = 0;
  389.     IAP_ADDRL = 0;
  390. }

  391. void Delay()
  392. {
  393.     INT8U i;
  394.     INT16U d=5000;
  395.     while (d--)
  396.     {
  397.         i=255;
  398.         while (i--);
  399.     }
  400. }
復(fù)制代碼

【圖片展示】


全部資料51hei下載地址:
GYJ-0070_單路可編程溫度控制系統(tǒng)DXP資料.rar (2.02 MB, 下載次數(shù): 50)
GYJ-0070_雙路可編程溫度控制系統(tǒng)產(chǎn)品使用手冊.doc (2.49 MB, 下載次數(shù): 26)
GYJ-0070_單路可編程溫度控制系統(tǒng)原理圖及PCB圖.pdf (510.51 KB, 下載次數(shù): 35)
GYJ-0070_單路可編程溫度控制系統(tǒng)發(fā)貨資料.rar (394.06 KB, 下載次數(shù): 38)


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

使用道具 舉報

沙發(fā)
ID:703644 發(fā)表于 2020-3-13 13:22 | 只看該作者
請問有沒有溫度加熱控制電路
回復(fù)

使用道具 舉報

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

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 精品国产aⅴ| 欧美久久久久久久久 | 久在线视频 | 精品欧美一区免费观看α√ | 69堂永久69tangcom | 爱爱综合网| 中文字幕av在线一二三区 | 天天夜天天操 | 国产午夜精品视频 | 黄视频免费 | 国产精品国产成人国产三级 | 古装人性做爰av网站 | 特黄色一级毛片 | 天天干b| 综合久久色 | 国产精品一区二区三区久久 | 精品av| 亚洲成人午夜电影 | 欧美一区二区在线免费观看 | 中文字幕av在线播放 | 亚洲精品久久久久avwww潮水 | 久草电影网 | 久久久久一区二区三区 | 国产精品一区二区久久久久 | 久久久www成人免费无遮挡大片 | 99久久婷婷国产综合精品 | 亚洲成人免费网址 | 亚洲精品久久久久久一区二区 | 午夜精品一区二区三区在线观看 | 亚洲永久| 正在播放国产精品 | 亚洲美女视频 | 亚洲毛片网站 | 国产成人网 | 自拍 亚洲 欧美 老师 丝袜 | 欧美一区在线看 | 国产片网站 | 中文字幕欧美一区二区 | 天堂资源 | 美日韩精品 | 粉嫩一区二区三区性色av |