找回密码
 立即注册

QQ登录

只需一步,快速开始

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

单片机数显温度控制器设计资料

[复制链接]
ID:187115 发表于 2017-8-25 11:29 | 显示全部楼层 |阅读模式
自己搞的   
Altium Designer画的原理图和PCB图如下:(51hei附件中可下载工程文件)
0.png 0.png

单片机源程序如下:
  1. #include "102.h"                                                                                 //声音  暂停
  2. #include "EEPROM.h"

  3. unsigned char in;
  4. sbit fmq = P5^4;
  5. unsigned char key=0;
  6. unsigned char wendu;
  7. bit         fl100ms;
  8. unsigned char yanshi;
  9. unsigned char te;
  10. unsigned int time;
  11. int wenduh=500;
  12. int        wendul=200;
  13. unsigned char huicha;
  14. unsigned int tempflg[2];
  15. signed int temp[2];
  16. bit gz;
  17. bit gzbz=0;
  18. void baocuen();
  19. void duqu();
  20. void sy();
  21. void sy2();
  22. unsigned char ysbz;
  23. unsigned int syt;
  24. unsigned int ysjs;
  25. void main()
  26. {
  27.    unsigned u;
  28.    init();
  29.    while(1)
  30.    {  
  31.        ADC_convert();
  32.            panduan();
  33.            sy2();
  34.            if(temp[0]<0)
  35.               { u=abs(temp[0]);
  36.                     dis1(21 ,u/100,u%100/10);
  37.                   }
  38.                 else if(temp[0]>999)
  39.                   {        dis1(temp[0]/1000 ,temp[0]%1000/100,temp[0]%100/10);}
  40.                 else  
  41.                   dis1(temp[0]/100 ,(temp[0]%100/10)+10,temp[0]%10);
  42.           
  43.                 if(!set)
  44.                 {        sy();
  45.                          while(1)
  46.                                   {
  47.                                            if(temp[0]<0)
  48.                                               {
  49.                                                         temp[0]=abs(temp[0]);
  50.                                                     dis1(21 ,temp[0]/10,temp[0]%10);
  51.                                                   }
  52.                                         else if(temp[0]>999)
  53.                                                   {       
  54.                                                         dis1(temp[0]/1000 ,temp[0]%1000/100,temp[0]%100/10);
  55.                                                 }
  56.                                         else  
  57.                                                   dis1(temp[0]/100 ,(temp[0]%100/10)+10,temp[0]%10);
  58.                                    if(set)
  59.                                            {
  60.                                                 out=0;
  61.                                                   shezhi();
  62.                                                 baocuen();
  63.                                                   goto loop2;
  64.                                         }                                         
  65.                             }
  66.        
  67.                                 loop2:te=0;
  68.                    }
  69.    if(!up)
  70.          {  sy();
  71.            if(temp[0]<0)
  72.               { temp[0]=abs(temp[0]);
  73.                     dis1(21 ,temp[0]/10,temp[0]%10);
  74.                   }
  75.                 else if(temp[0]>999)
  76.                   {        dis1(temp[0]/1000 ,temp[0]%1000/100,temp[0]%100/10);}
  77.                 else  
  78.                   dis1(temp[0]/100 ,(temp[0]%100/10)+10,temp[0]%10);
  79.                  if(up)
  80.                  {
  81.                    P3=0;
  82.                    LED1=LED2=LED3=0;
  83.                    out=0;
  84.                    fmq=0;
  85.                     while(1)
  86.                         {
  87.                          CLK_DIV = 0x07;  //将IDL(PCON.0)置1,MCU将进入空闲模式
  88.                                 _nop_(); //此时CPU?时钟,不执行指?
  89.                       if(!up)
  90.                           {        sy();
  91.                              while(1)
  92.                                  {
  93.                                    if(up)
  94.                                    {
  95.                                      CLK_DIV = 0x00;
  96.                                          goto loop2;}
  97.                         }
  98.                         }
  99.                         }}}                                       
  100. }
  101. }

  102. void init()
  103. {
  104.         AUXR &= 0x7F;                //定时器时钟12T模式
  105.            TMOD=0x01;     //设置T0为自动装入的16位定时器
  106.         TL0 = (65536-10000)/256;
  107.         TH0 = (65536-10000)%256;  
  108.     P3M1 = 0x00;   
  109.         P3M0 = 0xff;
  110.         P1M1 = 0x00;
  111.         P1M0 = 0x00;  
  112.         P5M1 = 0x00;
  113.         P5M0 = 0xff;
  114.         EA = 1;
  115.         ET0=1;
  116.         TR0=1;

  117.         InitADC();
  118.         duqu();
  119.               }

  120. void Timer0Init(void) interrupt 1                //2毫秒@11.0592MHz
  121. {   


  122.         unsigned char te;
  123.         bit biaozhi7=1;

  124.         TL0 = 0xCD;                //设置定时初值
  125.         TH0 = 0xF8;                //设置定时初值       
  126.         te++;
  127.         time++;
  128.         WDT_CONTR=0x37;             //喂狗  8.4S
  129.         //////////////////////////////
  130.         if(te>220)
  131.         {
  132.           fl100ms=1;
  133.           te=0;
  134.          }
  135.          syt++;
  136.          if(syt==100)
  137.          { fmq=0;}
  138.          ysjs++;

  139.        
  140. }


  141. void ADC_convert(void)                                                   //ad数据得出
  142. {
  143.           
  144.   if(fl100ms==1)
  145.         {          
  146.         GetADCResult(1,&tempflg[0]);         //1-通道号   temp[0]-ADC转换数值
  147.         fl100ms=0;
  148.         }
  149.         temp[0] = (signed int) ( ( 3950.0 / ( 11.33657 + log( 6.04 * (float)tempflg[0] / ( 1024.0 - (float)tempflg[0] ) ) ) - 278.15) * 10 );//273.15
  150. }
  151. void shezhi()
  152. {
  153.   unsigned b;
  154.   unsigned mode=0;
  155.   bit caidan=0;
  156.   bit a=1;
  157.   dis1(20 ,21,mode);
  158.   while(1)
  159.   {       
  160.            if(caidan==0)
  161.         {
  162.                 dis1(20 ,21,mode);
  163.         if(!up)
  164.            {         sy();
  165.                     a=1;
  166.                      while(a)
  167.                                  {
  168.                                            dis1(20 ,21,mode);
  169.                                            if(up)
  170.                                                    {
  171.                                                        mode++;
  172.                                                        if(mode>4)
  173.                                                                    {mode=0;}
  174.                                                            a=0;
  175.                                                 }
  176.                              }
  177.                 }

  178.          if(!down)
  179.            {         sy();
  180.                               { a=1;
  181.                              while(a)
  182.                                          {
  183.                                                    dis1(20 ,21,mode);
  184.                                                    if(down)
  185.                                                            {                            
  186.                                                          if(mode==0)
  187.                                                                  {mode=4;}
  188.                                                             else        mode--;
  189.                                                            a=0;
  190.                                                         }
  191.                                         }
  192.                                 }
  193.                 }
  194.            if(!set)
  195.                            {
  196.                                 sy();
  197.                                    time=0;
  198.                              a=1;
  199.                              while(a)
  200.                                          {
  201.                                                 dis1(20 ,21,mode);
  202.                                                    if(set)
  203.                                                            {
  204.                                                               if(time>100)
  205.                                                                           {        sy();
  206.                                                                                   goto loop1;}
  207.                                                                   else
  208.                                                                           {         caidan=1;
  209.                                                                                   a=0;
  210.                                                                         }      
  211.                                                      }
  212.           
  213.                                          }
  214.                         }
  215.         }
  216.          if(caidan==1)
  217.          {
  218.                            if(mode==0)
  219.                                    {
  220.                                         dis1(0,0,gz);
  221.                                 }
  222.                            if(mode==1)
  223.                                    {
  224.                                         if(wenduh<0)
  225.                                               {
  226.                                                          b=abs(wenduh);
  227.                                                     dis1(21 ,b/100,b%100/10);
  228.                                                   }
  229.                                         else if(wenduh>999)
  230.                                           {       
  231.                                                 dis1(wenduh/1000 ,wenduh%1000/100,wenduh%100/10);
  232.                                         }
  233.                                         else  
  234.                                                   dis1(wenduh/100 ,(wenduh%100/10)+10,wenduh%10);
  235.                                 }
  236.                         if(mode==2)
  237.                                    {
  238.                                         if(wenduh<0)
  239.                                               {
  240.                                                          b=abs(wendul);
  241.                                                     dis1(21 ,b/100,b%100/10);
  242.                                                   }
  243.                                         else if(wendul>999)
  244.                                                   {       
  245.                                                         dis1(wendul/1000 ,wendul%1000/100,wendul%100/10);
  246.                                                 }
  247.                                         else  
  248.                                                   dis1(wendul/100 ,(wendul%100/10)+10,wendul%10);
  249.                                 }
  250.                         if(mode==4)
  251.                                 {  
  252.                                         dis1(yanshi/100 ,yanshi%100/10,yanshi%10);}
  253.            if(!up)
  254.            {
  255.                            sy();
  256.                            time=0;
  257.                      a=1;
  258.                  while(a)
  259.                   {         if(mode==0)
  260.                               { dis1(0,0,gz);}
  261.                             if(mode==1)
  262.                                    {if(wenduh<0)
  263.                                       { b=abs(wenduh);
  264.                                             dis1(21 ,b/100,b%100/10);
  265.                                           }
  266.                                 else if(wenduh>999)
  267.                                           {       
  268.                                                 dis1(wenduh/1000 ,wenduh%1000/100,wenduh%100/10);
  269.                                         }
  270.                                 else  
  271.                                           dis1(wenduh/100 ,wenduh%100/10+10,wenduh%10);
  272.                                 }
  273.                         if(mode==2)
  274.                                    {
  275.                                         if(wenduh<0)
  276.                                       {
  277.                                                  b=abs(wendul);
  278.                                                     dis1(21 ,b/100,b%100/10);
  279.                                           }
  280.                                         else if(wendul>999)
  281.                                                   {       
  282.                                                         dis1(wendul/1000 ,wendul%1000/100,wendul%100/10);
  283.                                                 }
  284.                                         else  
  285.                                                   dis1(wendul/100 ,wendul%100/10+10,wendul%10);
  286.                                 }
  287.                     if(mode==4)
  288.                                 {  
  289.                                         dis1(yanshi/100 ,yanshi%100/10,yanshi%10);
  290.                                 }
  291.                   if(up)
  292.                    {
  293.                                    a=0;
  294.                              if(mode==0)
  295.                                           {
  296.                                                 if(gz==0)
  297.                                                         {gz=1;}
  298.                                                 else
  299.                                                         gz=0;
  300.                                           }
  301.                             if(mode==1)                           //温度上限
  302.                                           {
  303.                                             if(wenduh>1000)
  304.                                                         {
  305.                                                                 wenduh=wenduh+10;
  306.                                                         }
  307.                                                    else if(wenduh<0)
  308.                                                         {
  309.                                                                 wenduh=wenduh+10;
  310.                                                         }
  311.                                                 else
  312.                                                         wenduh++;
  313.                                                 if(wenduh>1200)
  314.                                                         {
  315.                                                                 wenduh=-550;
  316.                                                         }
  317.                                          }
  318.                             if(mode==4)
  319.                                         {
  320.                                                  if(yanshi==180)
  321.                                                      {       
  322.                                                                 yanshi=0;
  323.                                                         }
  324.                                                  else  yanshi++;
  325.                                            }
  326.                                 if(mode==2)                          //温度下线
  327.                                           {
  328.                                                    if(wendul>1000)
  329.                                                         {
  330.                                                                 wendul=wendul+10;
  331.                                                         }
  332.                                                    else if(wendul<0)
  333.                                                         {
  334.                                                                 wendul=wendul+10;
  335.                                                         }
  336.                                                 else
  337.                                                         wendul++;
  338.                                                 if(wendul>1200)
  339.                                                         {
  340.                                                                 wendul=-550;
  341.                                                         }
  342.                                            }
  343.                                  if(mode==3)                          //回差
  344.                                           {
  345.                                                 huicha++;
  346.                                                 if(huicha>200)
  347.                                                 {
  348.                                                         wendul=0;
  349.                                                 }
  350.                                            }
  351.                 }
  352.                 if(time>300)
  353.                         {
  354.                                   if(mode==1)                           //温度上限
  355.                                           {                                   
  356.                                                 wenduh=wenduh+1;
  357.                                                 if(wenduh>1200)
  358.                                                         {
  359.                                                                 wenduh=-550;
  360.                                                         }
  361.                                            }
  362.                                 if(mode==2)                          //温度下线
  363.                                           {
  364.                                                 wendul=wendul+1;
  365.                                                 if(wendul>1200)
  366.                                                         {
  367.                                                                 wendul=-550;
  368.                                                         }
  369.                                             }
  370.                    if(mode==4)                          //温度下线
  371.                                   {       
  372.                                         yanshi=yanshi+1;
  373.                                         if(yanshi>180)
  374.                                                 {
  375.                                                         yanshi=0;
  376.                                                 }
  377.                                     }
  378.                         }
  379.                 }
  380.           }
  381.                 if(!down)
  382.                            {
  383.                                 sy();
  384.                                 time=0;       
  385.                                 a=1;
  386.                                 while(a)
  387.                                         {       
  388.                                                  if(mode==0)
  389.                                                            {
  390.                                                                 dis1(0,0,gz);
  391.                                                         }
  392.                                                    if(mode==1)
  393.                                                            {
  394.                                                                 if(wenduh<0)
  395.                                                                       {
  396.                                                                                 b=abs(wenduh);
  397.                                                                                    dis1(21 ,b/100,b%100/10);
  398.                                                                           }
  399.                                                                 else if(wenduh>999)
  400.                                                                           {       
  401.                                                                                 dis1(wenduh/1000 ,wenduh%1000/100,wenduh%100/10);
  402.                                                                         }
  403.                                                                 else  
  404.                                                                           dis1(wenduh/100 ,wenduh%100/10+10,wenduh%10);
  405.                                                         }
  406.                                                 if(mode==2)
  407.                                                            {
  408.                                                                 if(wenduh<0)
  409.                                                                       {
  410.                                                                                 b=abs(wendul);
  411.                                                                             dis1(21 ,b/100,b%100/10);
  412.                                                                           }
  413.                                                                 else if(wendul>999)
  414.                                                                                   {       
  415.                                                                                         dis1(wendul/1000 ,wendul%1000/100,wendul%100/10);
  416.                                                                                 }
  417.                                                                 else  
  418.                                                                           dis1(wendul/100 ,wendul%100/10+10,wendul%10);}
  419.                                                  if(mode==4)
  420.                                                         {  
  421.                                                                 dis1(yanshi/100 ,yanshi%100/10,yanshi%10);
  422.                                                         }
  423.                                                     if(down)
  424.                                                            {
  425.                                                                 a=0;
  426.                                                                 if(mode==0)
  427.                                                                           {
  428.                                                                                 if(gz==0)
  429.                                                                                         {
  430.                                                                                                 gz=1;
  431.                                                                                         }
  432.                                                                                 else
  433.                                                                                         gz=0;
  434.                                                                           }
  435.                                                                 if(mode==1)                           //温度上限
  436.                                                                           {  
  437.                                                                               if(wenduh>999)
  438.                                                                              {
  439.                                                                                                 wenduh=wenduh-10;
  440.                                                                                         }
  441.                                                                                 else  if(wenduh<0)
  442.                                                                             {
  443.                                                                                                 wenduh=wenduh-10;
  444.                                                                                         }
  445.                                                                                 else        wenduh--;
  446.                                                                                 if(wenduh<-550)       
  447.                                                                                         {
  448.                                                                                                 wenduh=1200;
  449.                                                                                         }
  450.                                                                            }
  451.                                                                 if(mode==2)                          //温度下线
  452.                                                                           {
  453.                                                                                   if(wendul>999)
  454.                                                                              {
  455.                                                                                                 wendul=wendul-10;
  456.                                                                                         }
  457.                                                                                 else  if(wendul<0)
  458.                                                                             {
  459.                                                                                                 wendul=wendul-10;
  460.                                                                                         }
  461.                                                                                   else        wendul--;
  462.                                                                                 if(wendul<-550)
  463.                                                                                         {
  464.                                                                                                 wendul=1200;
  465.                                                                                         }
  466.                                                                            }
  467.                                                                 if(mode==3)                          //回差
  468.                                                                           {
  469.                                                                                 huicha--;
  470.                                                                                 if(huicha<0)
  471.                                                                                         {
  472.                                                                                                 wendul=200;
  473.                                                                                         }
  474.                                                                            }
  475.                                                                  
  476.                                                                 if(mode==4)
  477.                                                                          {   
  478.                                                                                 if(yanshi==0)
  479.                                                                                        {
  480.                                                                                                 yanshi=180;
  481.                                                                                         }
  482.                                                                                  else yanshi--;
  483.                                                                         }
  484.                                                         }                             
  485.                                         if(time>300)
  486.                                                 {
  487.                                                           if(mode==1)                           //温度上限
  488.                                                                   {
  489.                                                                         wenduh=wenduh-1;
  490.                                                                         if(wenduh<-550)
  491.                                                                                 {
  492.                                                                                         wenduh=1200;
  493.                                                                                 }
  494.                                                                    }
  495.                                                         if(mode==2)                          //温度下线
  496.                                                                   {
  497.                                                                         wendul=wenduh-1;
  498.                                                                         if(wendul<-550)
  499.                                                                                 {
  500.                                                                                         wendul=1200;
  501.                                                                                 }
  502.                                                                     }
  503.                                                            if(mode==4)                          //yanshi
  504.                                                                   {
  505.                                                                         if(yanshi==0)
  506.                                                                                 {       
  507.                                                                                         yanshi=180;
  508.                                                                                 }
  509.                                                                         else yanshi=yanshi-1;
  510.                                                                     }
  511.                                                 }
  512.                                 }
  513.                          }                       
  514.                   if(!set)
  515.                           {       
  516.                                 sy();
  517.                                   a=1;
  518.                                   while(a)
  519.                                           {
  520.                                             if(mode==0)
  521.                                                            {
  522.                                                                  dis1(0,0,gz);
  523.                                                         }
  524.                                                    if(mode==1)
  525.                                                            {
  526.                                                                 if(wenduh<0)
  527.                                                                       {
  528.                                                                                 b=abs(wenduh);
  529.                                                                             dis1(11 ,b/100,b%100/10);
  530.                                                                           }       
  531.                                                                 else if(wenduh>999)
  532.                                                                           {       
  533.                                                                                 dis1(wenduh/1000 ,wenduh%1000/100,wenduh%100/10);
  534.                                                                         }
  535.                                                                 else  
  536.                                                                                   dis1(wenduh/100 ,wenduh%100/10+10,wenduh%10);
  537.                                                         }
  538.                                                 if(mode==2)
  539.                                                            {
  540.                                                                 if(wenduh<0)
  541.                                                                       {
  542.                                                                                 b=abs(wendul);
  543.                                                                             dis1(11 ,b/100,b%100/10);
  544.                                                                           }
  545.                                                                 else if(wendul>999)
  546.                                                                           {       
  547.                                                                                  dis1(wendul/1000 ,wendul%1000/100,wendul%100/10);
  548.                                                                         }
  549.                                                                 else   
  550.                                                                                 dis1(wendul/100 ,wendul%100/10+10,wendul%10);
  551.                                                         }
  552.                                          if(mode==4)
  553.                                                 {  
  554.                                                         dis1(yanshi/100 ,yanshi%100/10,yanshi%10);
  555.                                                 }   
  556.                                           if(set)
  557.                                             {
  558.                                                         a=0;
  559.                                                            caidan=0;
  560.                                                 }
  561.                                   }
  562.                   }
  563.        
  564.        
  565.                 }
  566.         }
  567. loop1:baocuen(); //baocun();                                                          //保存函数还没写
  568. }
  569. void panduan()
  570. {
  571.   signed int a;
  572.   if(gz==0)                                                                                        //制冷模式
  573.         { a=wenduh+huicha;
  574.            if(gzbz==0)
  575.                            {
  576.                                 if(temp[0]>a)
  577.                                      {                                                   
  578.                                                    gzbz=1;
  579.                                           }
  580.                                 ysjs=0;
  581.                                 ysbz=0;
  582.                         }
  583.                 if(gzbz==1)
  584.                            {
  585.                                 if(temp[0]<wenduh)
  586.                                      {
  587.                                                    out=0;
  588.                                                    gzbz=0;
  589.                                           }
  590.                         }
  591.                 }
  592. if(gz==1)                                                                                        //加热模式
  593.         {         a=wenduh-huicha;
  594.                    if(gzbz==0)
  595.                            {
  596.                                 if(temp[0]<a)
  597.                                      {
  598.                                                    gzbz=1;
  599.                                           }
  600.                                    ysjs=0;
  601.                                   ysbz=0;
  602.                         }
  603.                 if(gzbz==1)
  604.                            {
  605.                                 if(temp[0]>wendul)
  606.                                      {
  607.                                                    out=0;
  608.                                                   gzbz=0;
  609.                                           }
  610.                         }
  611.         }
  612. if(gzbz==1)
  613. {
  614.    if(ysjs>500)
  615.     {ysbz++;
  616.           ysjs=0;
  617.         }
  618.         if(ysbz==yanshi)
  619.         {out=1;}                                       
  620. }
  621. }
  622. void baocuen()
  623. {     bit q1,q2;
  624.       int h,l;
  625. ……………………

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

所有资料51hei提供下载:
源码:
2017102.zip (92.11 KB, 下载次数: 40)

评分

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

查看全部评分

回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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