欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 5105|回復: 1
收起左側

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

[復制鏈接]
ID:280979 發表于 2018-2-24 13:42 | 顯示全部樓層 |閱讀模式
Altium Designer畫的溫度開發板原理圖和PCB圖如下:(51hei附件中可下載工程文件)
0.png 0.png 0.png

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


【標注說明】
功能描述

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

源程序見附件

應用舉例“比較控制系統”
功能描述:板子;雙路溫控繼電器,兩個溫控探頭,上面的溫控探頭是A面顯示的溫度,下面的溫控探頭是B面顯示的溫度,
操作過程; 下完程序先設定C,先按加溫度鍵,然后再按減溫鍵,斷一下電再上電,這樣是為了設定掉電存儲
板子功能;  當A的溫度大于B的溫度到設定值時,繼電器A吸合,當再這個設定范圍時,斷開。有個問題,當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. //數碼管顯示段碼
  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};              //數碼管顯示緩沖區
  9. uchar i = 0;  //數碼管掃描動態索引
  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 //系統工作時鐘<20MHz 時,對IAP_CONTR 寄存器設置此值

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

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

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

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

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

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

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

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


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

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

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

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

  74. /***********************開機讀掉電存儲內容******************************************************/
  75.                            
  76.                            
  77.                             time2 = Byte_Read(0x03)*255+Byte_Read(0x02);                 //注意這是把高字節和低字節合在一起
  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;                                                        //功能設置,4個參數,4個周期為一個循環
  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地址中的數據
  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地址中的數據
  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(); // 注意  一定要隨著溫度讀取函數一起每秒更新啟動一次 不然就只能讀取到剛上電那一瞬間的溫度   啟動DS18B20
  183.                         res = Get18B20Temp(&temp);  //讀取當前溫度

  184.                         intT = temp*10 >> 4;             // 注意在這個地方temp*10就是精確1位小數點,*100就是精確兩位小數點 但是只能精確一位小數點   分離出溫度值整數部分
  185.             decT = temp & 0xF;            //分離出溫度值小數部分
  186.                 /*
  187.                                           if((intT <= time2) && (intT >= time3))                                          //注意  控制部分要放到  這個函數內 不然上電就會先比較  會有動作  放在這里就可以先讀取再比較  穩定
  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(); // 注意  一定要隨著溫度讀取函數一起每秒更新啟動一次 不然就只能讀取到剛上電那一瞬間的溫度   啟動DS18B20
  223.                         ress = Get18B20Tempp(&tempp);  //讀取當前溫度

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


  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;      //定時器計數頻率                 注意 因為晶振是11.0592,,12個震蕩周期才是一個機器周期,所以,計數器加一所用的頻率就是11059200/12
  246.     tmp = (tmp * ms) / 1000;  //計算所需的計數值   注意 上面的計數時間單位是秒,所以除以1000就轉化為ms了
  247.     tmp = 65536 - tmp;        //計算定時器重載值
  248.     tmp = tmp + 18;           //補償中斷響應延時造成的誤差
  249.     T0RH = (unsigned char)(tmp>>8);  //定時器重載值拆分為高低字節              注意  因為是char型所以這個數據如果不向左移動8位他就只能保存低位的8位數據,一個char型變量保存是從低8位先保存,保存完后如果有空間再保存高位,向右移動8位就是讓它從高位開始保存,這個16位計數換成二進制是 1111 1000 1101 1110
  250.     T0RL = (unsigned char)tmp;                            //直接保存低字節數據
  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. /*按鍵掃描函數*/
  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中斷服務函數,完成數碼管、按鍵掃描與秒表計數 */
  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();                            //按鍵掃描函數
  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. //讀一字節,調用前需打開IAP 功能,入口:DPTR = 字節地址,返回:A = 讀出字節
  331. INT8U Byte_Read(INT16U add)
  332. {
  333.     IAP_DATA = 0x00;
  334.     IAP_CONTR = ENABLE_ISP;         //打開IAP 功能, 設置Flash 操作等待時間
  335.     IAP_CMD = 0x01;                 //IAP/ISP/EEPROM 字節讀命令

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

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

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

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

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

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

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

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

  381. void IAP_Disable()
  382. {
  383.     //關閉IAP 功能, 清相關的特殊功能寄存器,使CPU 處于安全狀態,
  384.     //一次連續的IAP 操作完成之后建議關閉IAP 功能,不需要每次都關
  385.     IAP_CONTR = 0;      //關閉IAP 功能
  386.     IAP_CMD   = 0;      //清命令寄存器,使命令寄存器無命令,此句可不用
  387.     IAP_TRIG  = 0;      //清命令觸發寄存器,使命令觸發寄存器無觸發,此句可不用
  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. }
復制代碼

【圖片展示】


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


回復

使用道具 舉報

ID:703644 發表于 2020-3-13 13:22 | 顯示全部樓層
請問有沒有溫度加熱控制電路
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表