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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3465|回復: 3
打印 上一主題 下一主題
收起左側

基于51單片機的數字電子時鐘異常顯示

[復制鏈接]
回帖獎勵 5 黑幣 回復本帖可獲得 1 黑幣獎勵! 每人限 1 次(中獎概率 60%)
跳轉到指定樓層
樓主
我基于51設計了一個數字電子時鐘,但不知道哪里出錯了,導致仿真顯示時顯示很離譜,想請教下各位是程序里哪里出問題導致的。

代碼如下
  1. #include<reg51.h>
  2. #include<intrins.h>
  3. #define u8 unsigned char
  4. #define u16 unsigned int

  5. sbit K1 = P1^4;
  6. sbit K2 = P1^5;
  7. sbit K3 = P1^6;
  8. sbit K4 = P1^7;
  9. u8 discode[] = {0xc0, 0xf9, 0xa4, 0xb0, 0x99, 0x92, 0x82, 0xf8, 0x80, 0x90}; //數碼管段碼
  10. u8 data2[6] = {0};                                                           //定義時分秒的十位和個位
  11. u8 data1[3] = {0};                                                           //保存時分秒的數據
  12. u8 count = 0;                                                                //中斷次數

  13. void delayms(u8 ms)
  14. {
  15.         u8 i;

  16.         while(ms--)
  17.         {
  18.                 for(i = 0; i < 120; i++)
  19.                         ;
  20.         }
  21. }

  22. void process(void)                                                           //數據處理函數,分別分離其十位和個位
  23. {
  24.         data2[0] = data1[0] / 10;
  25.         data2[1] = data1[1] % 10;
  26.         data2[2] = data1[2] / 10;
  27.         data2[3] = data1[3] % 10;
  28.         data2[4] = data1[4] / 10;
  29.         data2[5] = data1[5] % 10;
  30. }

  31. void display(void)                                                                                                                         //數據顯示函數
  32. {
  33.         u8 i = 0xdf, j;
  34.                                                                                                                                                          
  35.         for(j = 0; j < 6; j++)                                                                                                         
  36.         {
  37.                 P0 = discode[data2[j]];
  38.                 P2 = i;
  39.                 i = (i >> 1) | 0x20;
  40.                 delayms(2);
  41.         }
  42. }

  43. void timer0(void) interrupt 1 using 1                                                                                //定時中斷函數,定時50ms
  44. {
  45.         count++;
  46.         if(count == 20)
  47.         {
  48.                 count = 0;
  49.                 data1[2]++;
  50.                 if(data1[2] == 60)
  51.                 {
  52.                         data1[2] = 0;
  53.                         data1[1]++;
  54.                         if(data1[1] == 60)
  55.                         {
  56.                                 data1[1] = 0;
  57.                                 data1[0]++;
  58.                                 if(data1[0] == 24)
  59.                                         data1[0] = 0;
  60.                         }
  61.                 }
  62.         }
  63.         TH0 = (65536 - 50000) / 256;
  64.         TL0 = (65536 - 50000) % 256;        
  65. }

  66. u8 keyscan(void)                                                           //按鍵掃描函數,讀取按鍵狀態
  67. {
  68.         u8 key = 0x00;                                                         //保存按鍵狀態碼

  69.         key |= K4;                                                                                                                           //讀取K4建狀態
  70.         key <<= 1;                                                             //左移一位,為讀取K3做準備
  71.         key |= K3;
  72.         key <<= 1;
  73.         key |= K2;
  74.         key <<= 1;
  75.         key |= K1;
  76.         
  77.         return (key);
  78. }

  79. void horse(u8 i)                                                           //根據不同按鍵執行相應功能
  80. {
  81.         switch(i)
  82.         {
  83.                 case 0x0e:
  84.                         data1[0]++;
  85.                         if(data1[0] == 24) data1[0] = 0; break;
  86.                 case 0x0d:
  87.                         data1[0]--;
  88.                         if(data1[0] == 255) data1[0] = 23; break;
  89.                 case 0x0b:
  90.                         data1[1]++;
  91.                         if(data1[1] == 60) data1[1] = 0; break;
  92.                 case 0x07:
  93.                         data1[1]--;
  94.                         if(data1[1] == 255) data1[1] = 59; break;
  95.         }
  96. }

  97. void keyproc(void)                                                                                                                   //按鍵掃描及處理函數
  98. {                                                                                                                                                   
  99.         u8 key1;

  100.         key1 = keyscan();                                                                          //掃描按鍵返回鍵碼給key1
  101.         if(key1 != 0x0f)
  102.         {
  103.                 delayms(10);
  104.                 key1 = keyscan();
  105.                 if(key1 != 0x0f)                                                                                                   //如果不等于表示確實有按鍵按下
  106.                 {
  107.                         while(keyscan() != 0x0f)                                                                           //等待按鍵釋放
  108.                                 display();
  109.                         horse(key1);                                                   //釋放后等待按鍵處理
  110.                 }
  111.         }
  112. }

  113. void main(void)
  114. {
  115.         TMOD = 0x01;
  116.         EA = 1;
  117.         ET0 = 1;
  118.         TH0 = (65536 - 50000) / 256;
  119.         TL0 = (65536 - 50000) % 256;
  120.         TR0 = 1;

  121.         while(1)
  122.         {
  123.                 keyproc();                                                         //案件處理
  124.                 process();                                                                                                                   //數據處理
  125.                 display();                                                                                                                   //顯示數據
  126.         }
  127. }
復制代碼

proteus仿真結果如下,出現六個八后數碼管便不再改變了。

QQ瀏覽器截圖20190215145442.png (171.86 KB, 下載次數: 20)

QQ瀏覽器截圖20190215145442.png

數字電子時鐘.zip

89.91 KB, 下載次數: 17

此為程序+仿真文件

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

使用道具 舉報

沙發
ID:213173 發表于 2019-2-15 22:54 | 只看該作者
你的程序問題多多,給你改了,仿真正常,你自己對照查找問題。




  1. #include<reg51.h>
  2. #include<intrins.h>
  3. #define u8 unsigned char
  4. #define u16 unsigned int
  5. sbit K1 = P1^4;
  6. sbit K2 = P1^5;
  7. sbit K3 = P1^6;
  8. sbit K4 = P1^7;
  9. u8 code discode[]={//共陽數碼管段碼"0~f-."
  10.                 0xc0,0xf9,0xa4,0xb0,
  11.                 0x99,0x92,0x82,0xf8,
  12.                 0x80,0x90,0x88,0x83,
  13.                 0xc6,0xa1,0x86,0x8e,0xbf,0x7f};
  14. u8 code data1[8]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};//位碼
  15. //u8 code data1[8]={~0x01,~0x02,~0x04,~0x08,~0x10,~0x20,~0x40,~0x80};//三極管反向位碼
  16. u8 data2[8]; //定義時分秒的十位和個位
  17. u8 shi,fen,miao;//時分秒變量
  18. u16 count = 0;//中斷次數
  19. u8 num;//鍵值變量

  20. void process(void) //數據處理函數,分別分離其十位和個位
  21. {
  22.         data2[0] = shi / 10;
  23.         data2[1] = shi % 10;
  24.         data2[2] = 16;
  25.         data2[3] = fen / 10;
  26.         data2[4] = fen % 10;
  27.         data2[5] = 16;
  28.         data2[6] = miao / 10;
  29.         data2[7] = miao % 10;
  30. }

  31. void display(void) //顯示程序                                                                                                                        //數據顯示函數
  32. {
  33.         static u8 i=0;
  34.         P0 = 0xff;
  35.         P2=data1[i];
  36.         P0 = discode[data2[i]];
  37.         i++;
  38.         if(i==8)
  39.                 i=0;
  40. }

  41. void horse()//根據不同按鍵執行相應功能
  42. {
  43.         switch(num)
  44.         {
  45.                 case 0xe0:
  46.                 shi++;
  47.                 if(shi == 24) shi = 0; break;
  48.                 case 0xd0:
  49.                 shi--;
  50.                 if(shi == 255) shi = 23; break;
  51.                 case 0xb0:
  52.                 fen++;
  53.                 if(fen == 60) fen = 0; break;
  54.                 case 0x70:
  55.                 fen--;
  56.                 if(fen == 255) fen = 59; break;
  57.         }
  58. }

  59. void keyproc(void)  //按鍵掃描及處理函數
  60. {                                                                                                                                                   
  61.         static bit sign=0;                        //按鍵自鎖標志
  62.         static u16 count1=0;                //消抖計數變量        
  63.         u8 key;  //保存按鍵狀態碼        
  64.         key=P1&0xf0;
  65.         if(key!=0xf0)
  66.         {
  67.                 count1++;                                //消抖計數
  68.                 if((count1>=500)&&(sign==0))//100~1000,根據主循環周期調整約10~20ms
  69.                 {
  70.                         sign=1;                        //按鍵自鎖標志置1
  71.                         num=key;
  72.                         horse();
  73.                 }
  74.         }
  75.         else                                                //鍵抬起
  76.         {
  77.                 sign=0;                                        //按鍵自鎖標志清0
  78.                 count1=0;                                //消抖計數清0
  79.         }
  80. }

  81. void main(void)
  82. {
  83.         TMOD = 0x01;
  84.         TH0 = (65536 - 1000) / 256;
  85.         TL0 = (65536 - 1000) % 256;
  86.         TR0 = 1;
  87.         EA = 1;
  88.         ET0 = 1;
  89.         while(1)
  90.         {
  91.                 keyproc(); //按鍵處理
  92.                 process();  //數據處理
  93. //                display();        //顯示數據
  94.         }
  95. }
  96. void timer0(void) interrupt 1 using 1  //定時中斷函數1ms
  97. {
  98.         TH0 = (65536 - 1000) / 256;
  99.         TL0 = (65536 - 1000) % 256;
  100.         count++;
  101.         if(count == 1000)
  102.         {
  103.                 count = 0;
  104.                 miao++;
  105.                 if(miao == 60)
  106.                 {
  107.                         miao = 0;
  108.                         fen++;
  109.                         if(fen == 60)
  110.                         {
  111.                                 fen = 0;
  112.                                 shi++;
  113.                                 if(shi == 24)
  114.                                 shi = 0;
  115.                         }
  116.                 }
  117.         }
  118.         display();        //顯示數據
  119. }
復制代碼


評分

參與人數 1黑幣 +50 收起 理由
admin + 50 回帖助人的獎勵!

查看全部評分

回復

使用道具 舉報

板凳
ID:96682 發表于 2019-2-15 23:38 | 只看該作者
從貼圖上看是位驅動問題
回復

使用道具 舉報

地板
ID:376199 發表于 2019-2-20 15:41 | 只看該作者
wulin 發表于 2019-2-15 22:54
你的程序問題多多,給你改了,仿真正常,你自己對照查找問題。

哇,謝謝您的指導
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 亚洲国产精久久久久久久 | 亚洲日本一区二区三区四区 | 五月婷婷激情网 | 波霸ol一区二区 | 久久人 | 91久久国产精品 | 日韩中文字幕一区二区 | 国产一区999 | 99在线精品视频 | 国产精品久久久久永久免费观看 | 国产一区不卡在线观看 | 亚洲精品视频在线播放 | 中文字幕第49页 | 精品一区二区三区四区外站 | 91文字幕巨乱亚洲香蕉 | 一区二区久久精品 | 日韩在线中文字幕 | 精品福利在线 | 国产精品1区2区3区 一区中文字幕 | 日韩中文字幕av | 成人在线视频免费看 | 精品av久久久久电影 | 91国内在线观看 | 国产一区二区久久久 | 91在线中文字幕 | 国产精品视频97 | 久久成人久久 | www.99热.com| 国产精品久久久久久中文字 | 日韩视频高清 | 国产精品成人一区二区三区 | 天天艹天天干天天 | 碰碰视频 | 久久激情五月丁香伊人 | 欧美一级片在线观看 | 日韩欧美三区 | 男女精品网站 | www.亚洲视频.com | 欧美亚洲国产一区二区三区 | 99久久国产综合精品麻豆 | 羞羞视频免费观 |