標題: 比賽用的單片機秒表計數器仿真源碼 [打印本頁]

作者: 151615111    時間: 2018-9-26 10:30
標題: 比賽用的單片機秒表計數器仿真源碼
用做比賽用的秒表計數器,可以發(fā)出滴答聲
仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)


單片機源程序如下:
  1. #include <reg51.h>
  2. #include <intrins.h>
  3. #include <stdio.h>
  4. #include <string.h>

  5. #define u16 unsigned int
  6. #define u8  unsigned char
  7. sbit DX=P2^0;
  8. sbit WX=P2^1;
  9. sbit FM=P2^3;
  10. sbit K1=P3^2;
  11. sbit K2=P3^3;
  12. int n,k,x;

  13. void delay_ms(u16 x)//毫秒延時函數
  14. {u16 i,j;
  15. for(i=0;i<x;i++)
  16.     for(j=0;j<115;j++);
  17. }
  18. u8 code table[]={
  19. 0x3f,0x06,0x5b,0x4f,
  20. 0x66,0x6d,0x7d,0x07,
  21. 0x7f,0x6f,0x77,0x7c,
  22. 0x39,0x5e,0x79,0x71,0x00}; //共陰數碼管編碼

  23. void print_u16_LED(u16 n)//輸出16位無符號整數(0-65535)到6位數碼管
  24. {u8 t=0xdf,i=0,j;
  25. if(n<100)
  26. {
  27.    for(j=0;j<3;j++)

  28.   {        
  29.     P0=0xff; //消影
  30.         WX=1;//允許更新位碼
  31.         P0=t; //送位碼
  32.         WX=0;//鎖存位碼
  33.            
  34.         P0=0x00; //消影
  35.         DX=1;//允許更新段碼
  36.   //P0=table[n%10]; //送段碼

  37.         if(i==3) P0=table[n%10]|0x80;
  38.         else  P0=table[n%10];

  39.         DX=0;

  40.         n=n/10;
  41.         t=_cror_(t,1);
  42.         delay_ms(3);
  43.   }
  44. }

  45.   else
  46.   while(n)
  47.   {
  48.     P0=0xff; //消影
  49.         WX=1;//允許更新位碼
  50.         P0=t; //送位碼
  51.         WX=0;//鎖存位碼
  52.            
  53.         P0=0x00; //消影
  54.         DX=1;//允許更新段碼
  55.   //P0=table[n%10]; //送段碼

  56.         if(i==3) P0=table[n%10]|0x80;
  57.         else  P0=table[n%10];

  58.         DX=0;

  59.         n=n/10;
  60.         t=_cror_(t,1);
  61.         i++;
  62.         delay_ms(3);
  63.   }
  64. }

  65. void print_float_LED(float n,u8 x)
  66. {u8 temp;
  67. int i;
  68. char str[7];
  69. switch(x)
  70. {case 1:sprintf(str,"%.1f",n);break;
  71.   case 2:sprintf(str,"%.2f",n);break;
  72.   case 3:sprintf(str,"%.3f",n);break;
  73.   case 4:sprintf(str,"%.4f",n);break;
  74.   case 5:sprintf(str,"%.5f",n);break;
  75. }  
  76. i=strlen(str)-1;          //從最低位開始輸出
  77. temp=0xdf;
  78. while(i>=0)
  79.   {
  80.            P0=0XFF;          /*消除P0的值*/
  81.            WX=1;                 /*位選輸入有效*/
  82.            P0=temp;          /*輸出位選碼*/
  83.            WX=0;                 /*位選鎖存*/
  84.            P0=0;          /*消除P0的值*/
  85.            DX=1;         /*段選輸入有效*/
  86.        if(str[i]=='-') P0=0x40; //顯示‘-’
  87.        else   P0=table[str[i]-'0'];        //顯示數字
  88.            DX=0;                         /*段碼鎖存*/
  89.            temp=_cror_(temp,1);
  90.            i--;                                         
  91.            delay_ms(1);
  92.    }
  93. }

  94. void main()
  95. {u8 i,t;
  96. FM=1;
  97. TMOD=0x00;
  98. TL0=(8192-1000)%32;
  99. TH0=(8192-1000)/32;
  100. TL1=(8192-1000)%32;
  101. TH1=(8192-1000)/32;
  102. IT0=1;
  103. IT1=0;
  104. EX0=1;
  105. EX1=1;
  106. EA=1;
  107. ET0=1;
  108. ET1=1;
  109. TR1=1;
  110. while(1)
  111.    print_u16_LED(n);         
  112. }
  113. void intr0() interrupt 0
  114. {
  115. TR1=~TR1;
  116. }
  117. void intr1() interrupt 2
  118. {
  119. TR1=0;
  120. n=0;
  121. }
  122. void time0() interrupt 1
  123. {
  124. TL0=(8192-1000)%32;
  125. TH0=(8192-1000)/32;
  126. FM=~FM;
  127. k++;
  128. if(k==100) {k=0;TR0=0;}
  129. }
  130. void time1() interrupt 3
  131. {
  132. TL1=(8192-1000)%32;
  133. TH1=(8192-1000)/32;
  134. n++;

  135. if(n%1000==0) TR0=1;
  136. }
復制代碼

所有資料51hei提供下載:
秒表.zip (22.46 KB, 下載次數: 35)



作者: 95274396    時間: 2018-10-16 17:10
大神   厲害啊   
作者: 95274396    時間: 2018-10-16 17:11
我的大神 厲害啊
作者: 95274396    時間: 2018-10-16 17:12
厲害啊  大神

作者: CHENYICHUN    時間: 2021-8-29 23:42
你好,可以發(fā)一下kei5文件嗎

作者: 000111222333@    時間: 2021-12-24 10:05
下載了,怎么增大秒表的計數范圍呢?




歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1