找回密码
 立即注册

QQ登录

只需一步,快速开始

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

51单片机在板子上数码管反应迟钝 定时器误差很大怎么办?

[复制链接]
跳转到指定楼层
楼主
ID:695575 发表于 2022-3-6 17:30 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  1. #include "reg52.h"
  2. #include "HX711.h"
  3. #include "uart.h"
  4. #include "LCD1602.h"
  5. #include "temp.h"

  6. typedef unsigned char u8;
  7. typedef unsigned int u16;

  8. u16 KEY_NUM=0;
  9. unsigned long HX711_Buffer=0;
  10. unsigned long Weight_Maopi=0;Weight_Shiwu=0;
  11. bit Flag_OK=0;


  12. sbit key_stop = P3^0;
  13. sbit key_star = P3^1;
  14. sbit key_fen = P3^2;
  15. sbit key_shi = P3^3;

  16. sbit LSA=P2^2;
  17. sbit LSB=P2^3;
  18. sbit LSC=P2^4;

  19. u8 DisplayDataTemp[8];
  20. u8 DisplayWeight[8];
  21. u8 DisplayData[8];

  22. u8 code smgduan[11]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x67,0x6f};
  23. u8 miao=0;
  24. u8 fen=0;
  25. u8 shi=0;
  26. u8 miao_L,miao_H,fen_L,fen_H,shi_L,shi_H;

  27. u8 State=1;
  28. u16 counter=0;



  29. void delay(u16 x){  
  30.         while(x--)
  31.                 ;
  32. }

  33. void Delay_ms(u16 n)
  34. {
  35.         u16 i,j;
  36.         for(i=0;i<n;i++)
  37.                 for(j=0;j<123;j++);
  38. }


  39. void key_delay(int xms){  
  40.         u16 i, j;
  41.         for(i=0; i<xms; ++i)
  42.                 for(j=0; j<110; ++j)
  43.                         ;
  44. }



  45. void T0_Init(){  
  46.       
  47.         TMOD = 0x01;
  48.         TH0 = 0x3c;  
  49.         TL0 = 0xb0;         
  50.     EA = 1;  
  51.         ET0 = 1;     
  52.         TR0 = 1;   
  53. }


  54. void dataprosTemp(int temp)         
  55. {
  56.            float tp;  
  57.         if(temp< 0)                                
  58.           {
  59.                 DisplayDataTemp[0] = 0x40;           
  60.                
  61.                 temp=temp-1;
  62.                 temp=~temp;
  63.                 tp=temp;
  64.                 temp=tp*0.0625*100+0.5;      
  65.                
  66.                
  67.                

  68.           }
  69.         else
  70.           {                       
  71.                 DisplayDataTemp[0] = 0x00;
  72.                 tp=temp;
  73.                
  74.                 temp=tp*0.0625*100+0.5;      
  75.                
  76.                
  77.                
  78.         }
  79.         DisplayDataTemp[1] = smgduan[temp / 10000];
  80.         DisplayDataTemp[2] = smgduan[temp % 10000 / 1000];
  81.         DisplayDataTemp[3] = smgduan[temp % 1000 / 100] | 0x80;
  82.         DisplayDataTemp[4] = smgduan[temp % 100 / 10];
  83.         DisplayDataTemp[5] = smgduan[temp % 10];
  84. }



  85. void datapros()         
  86. {
  87.         DisplayData[0] = smgduan[miao_L];                              
  88.         DisplayData[1] = smgduan[miao_H];                                 
  89.         DisplayData[2] = 0x40;
  90.         DisplayData[3] = smgduan[fen_L];                              
  91.         DisplayData[4] = smgduan[fen_H];      
  92.         DisplayData[5] = 0x40;
  93.         DisplayData[6] = smgduan[shi_L];                              
  94.         DisplayData[7] = smgduan[shi_H];
  95. }


  96. void DigDisplayTemp()
  97. {
  98.         u8 j;
  99.         for(j=0;j<6;j++)
  100.         {
  101.                 switch(j)         
  102.                 {
  103.                         case(0):
  104.                                 LSA=0;LSB=0;LSC=0; break;
  105.                         case(1):
  106.                                 LSA=1;LSB=0;LSC=0; break;
  107.                         case(2):
  108.                                 LSA=0;LSB=1;LSC=0; break;
  109.                         case(3):
  110.                                 LSA=1;LSB=1;LSC=0; break;
  111.                         case(4):
  112.                                 LSA=0;LSB=0;LSC=1; break;
  113.                         case(5):
  114.                                 LSA=1;LSB=0;LSC=1; break;
  115.                 }
  116.                 P0=DisplayDataTemp[5-j];
  117.                 delay(100);
  118.                 P0=0x00;
  119.         }               
  120. }

  121. void DigDisplay()
  122. {
  123.         u8 i;
  124.         for(i=0;i<8;i++)
  125.         {
  126.                 switch(i)
  127.                 {
  128.                         case(0):
  129.                                 LSA=0;LSB=0;LSC=0; break;
  130.                         case(1):
  131.                                 LSA=1;LSB=0;LSC=0; break;
  132.                         case(2):
  133.                                 LSA=0;LSB=1;LSC=0; break;
  134.                         case(3):
  135.                                 LSA=1;LSB=1;LSC=0; break;
  136.                         case(4):
  137.                                 LSA=0;LSB=0;LSC=1; break;
  138.                         case(5):
  139.                                 LSA=1;LSB=0;LSC=1; break;
  140.                         case(6):
  141.                                 LSA=0;LSB=1;LSC=1; break;
  142.                         case(7):
  143.                                 LSA=1;LSB=1;LSC=1; break;
  144.                 }
  145.                 P0=DisplayData[i];
  146.                 delay(50);
  147.                 P0=0x00;
  148.         }               
  149. }



  150. void keyscan(){  

  151.         if(key_stop == 0){
  152.                 key_delay(20);
  153.                 if(key_stop == 0){
  154.                         EA = ~EA;  
  155.                         while(!key_stop);
  156.                 }
  157.         }
  158.       
  159.         if(key_star == 0){
  160.                 key_delay(20);
  161.                 if(key_star == 0){
  162.                         State = State+1;
  163.                         if(State==4)
  164.                         {
  165.                                 State=1;
  166.                         }                        
  167.                         while(!key_star);
  168.                 }
  169.         }
  170.       
  171.         if(key_fen == 0){
  172.                 key_delay(20);
  173.                 if(key_fen == 0){
  174.                         fen++;
  175.                         while(!key_fen);
  176.                 }
  177.         }
  178.       
  179.         if(key_shi == 0){
  180.                 key_delay(20);
  181.                 if(key_shi == 0){
  182.                         shi++;
  183.                         while(!key_shi);
  184.                 }
  185.         }
  186. }


  187. void dataweight()
  188. {
  189.         DisplayWeight[1]=smgduan[Weight_Shiwu/1000];
  190.         DisplayWeight[2]=smgduan[Weight_Shiwu%1000/100];
  191.         DisplayWeight[3]=smgduan[Weight_Shiwu%100/10];
  192.         DisplayWeight[4]=smgduan[Weight_Shiwu%10];
  193.         DisplayWeight[5]=0x6f;
  194. }

  195. void DigDisplayWeight()
  196. {
  197.         u8 j;
  198.         for(j=0;j<6;j++)
  199.         {
  200.                 switch(j)         
  201.                 {
  202.                         case(0):
  203.                                 LSA=0;LSB=0;LSC=0; break;
  204.                         case(1):
  205.                                 LSA=1;LSB=0;LSC=0; break;
  206.                         case(2):
  207.                                 LSA=0;LSB=1;LSC=0; break;
  208.                         case(3):
  209.                                 LSA=1;LSB=1;LSC=0; break;
  210.                         case(4):
  211.                                 LSA=0;LSB=0;LSC=1; break;
  212.                         case(5):
  213.                                 LSA=1;LSB=0;LSC=1; break;
  214.                 }
  215.                 P0=DisplayWeight[5-j];
  216.                 delay(50);
  217.                 P0=0x00;
  218.         }               
  219. }



  220. void Get_Weight()
  221. {
  222.         HX711_Buffer=HX711_Read();
  223.         HX711_Buffer=HX711_Buffer/100;
  224.         if(HX711_Buffer>Weight_Maopi)
  225.         {
  226.           Weight_Shiwu=HX711_Buffer;
  227.           Weight_Shiwu=Weight_Shiwu - Weight_Maopi;
  228.                 Weight_Shiwu=(unsigned int)((float)Weight_Shiwu/4.40+0.05);
  229.         }
  230. }

  231. void Get_Maopi()
  232. {
  233.         HX711_Buffer=HX711_Read();
  234.         Weight_Maopi=HX711_Buffer/100;
  235. }



  236. void main()
  237. {
  238.         char k=10;
  239.         T0_Init();
  240.         Send_Word("Welcome to use!\n");
  241.         Send_Word("Made by CZQ Group!\n");
  242.   Delay_ms(800);
  243.         Get_Maopi();
  244.         Delay_ms(1000);

  245.       
  246.       
  247. //        LcdWriteCom(0x80+0x40+6
  248. //        LcdWriteData(0x5c); ?e??·?
  249.       
  250. //        LcdWriteCom(0x80+0x40+15
  251. //        LcdWriteData(0x5c
  252.       
  253.           Get_Maopi();
  254.       
  255.         while(1)
  256.         {
  257.                 keyscan();
  258.                 dataprosTemp(Ds18b20ReadTemp());
  259.                 k--;
  260.                 if( Flag_OK==0)
  261.                 {
  262.                          if(k==0)
  263.                          {
  264.                                  Get_Weight();
  265.                                  k--;
  266.                          }
  267.                          if(k<0)
  268.                          {
  269.                                  k=10;  
  270.                          }
  271.                         
  272.                          Send_ASCII(Weight_Shiwu/1000+0x30);
  273.                          Send_ASCII(".");
  274.                          Send_ASCII(Weight_Shiwu%1000/100+0x30);
  275.                          Send_ASCII(Weight_Shiwu%100/10+0x30);
  276.                          Send_ASCII(Weight_Shiwu%10+0x30);
  277.                          Send_Word(" kg  \n");                 
  278.                 }
  279.                 if(State==3)
  280.                 {
  281.                   dataweight();
  282.                   DigDisplayWeight();
  283.                 }
  284.                 if(State==1)
  285.                 {
  286.                         DigDisplay();
  287.                         datapros();
  288.                 }
  289.                 if(State==2)
  290.                 {
  291.                         DigDisplayTemp();
  292.                 }
  293.         }
  294. }

  295. void timer0_Init() interrupt 1{  
  296.          
  297.          counter++;

  298.          if(counter == 20){
  299.                  counter = 0;  
  300.                  miao++;        

  301.                 if(miao == 60){
  302.                         miao = 0;  
  303.                         fen++;

  304.                         if(fen == 60){
  305.                                 fen = 0;  
  306.                                 shi++;

  307.                                 if(shi == 24){
  308.                                         shi = 0;
  309.                                         fen = 0;
  310.                                         miao = 0;
  311.                                 }
  312.                         }
  313.                 }

  314.                 miao_L = miao%10;  
  315.                 miao_H = miao/10;

  316.                 fen_L = fen%10;
  317.                 fen_H = fen/10;  

  318.                 shi_L = shi%10;  
  319.                 shi_H = shi/10;

  320.          }
  321. }
复制代码


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

使用道具 举报

沙发
ID:213173 发表于 2022-3-6 21:06 | 只看该作者
定时器中断没有重装初值
void timer0_Init() interrupt 1
{           
        TH0 = 0x3c;  
        TL0 = 0xb0;

        counter++;
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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