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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

單片機188數碼管消影程序調試問題

  [復制鏈接]
跳轉到指定樓層
樓主
ID:531175 發(fā)表于 2022-2-12 15:03 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
10黑幣
大家好,請教一下,我在使用188數碼管時,遇到了一個消影問題,數碼管動態(tài)掃描,在刷新函數中,已經加入了消影語句,即各個引腳設置為高阻輸入,但是不應該亮的數碼管還是會有弱光,所以顯示并不清晰,當然消影函數還是有一定的作用,不加消影函數,幾乎無法分辨數字,請大家?guī)蛶兔Γ纯词悄睦镉袉栴}

硬件上:使用的是STC8G1K08系列,直接IO口驅動數碼管
程序是從 188數碼管顯示 這里幾乎不動的寫過來的,刷新函數在定時器中斷函數中每 4ms 刷新一次
  1. #include "188.h"
  2. #include "delay.h"
  3. #include "intrins.h"
  4. #include "stc8g.h"

  5. sbit PSEG_1 = P3^6;
  6. sbit PSEG_2 = P3^5;
  7. sbit PSEG_3 = P3^4;
  8. sbit PSEG_4 = P3^3;
  9. sbit PSEG_5 = P3^2;

  10. #define PIN1_IN() P3M1 |= 0x40;P3M0 &= 0xbf;                                                        //把單片機IO口配置為高阻輸入
  11. #define PIN2_IN() P3M1 |= 0x20;P3M0 &= 0xdf;
  12. #define PIN3_IN() P3M1 |= 0x10;P3M0 &= 0xef;
  13. #define PIN4_IN() P3M1 |= 0x08;P3M0 &= 0xf7;
  14. #define PIN5_IN() P3M1 |= 0x04;P3M0 &= 0xfb;

  15. #define PIN1_L() P3M0 |= 0x40;P3M1 &= 0xbf;PSEG_1 = 0;   //配置為推挽輸出,且拉低
  16. #define PIN2_L() P3M0 |= 0x20;P3M1 &= 0xdf;PSEG_2 = 0;
  17. #define PIN3_L() P3M0 |= 0x10;P3M1 &= 0xef;PSEG_3 = 0;
  18. #define PIN4_L() P3M0 |= 0x08;P3M1 &= 0xf7;PSEG_4 = 0;
  19. #define PIN5_L() P3M0 |= 0x04;P3M1 &= 0xfb;PSEG_5 = 0;

  20. #define PIN1_H() P3M0 |= 0x40;P3M1 &= 0xbf;PSEG_1 = 1;  //配置為推挽輸出,且拉高
  21. #define PIN2_H() P3M0 |= 0x20;P3M1 &= 0xdf;PSEG_2 = 1;
  22. #define PIN3_H() P3M0 |= 0x10;P3M1 &= 0xef;PSEG_3 = 1;
  23. #define PIN4_H() P3M0 |= 0x08;P3M1 &= 0xf7;PSEG_4 = 1;
  24. #define PIN5_H() P3M0 |= 0x04;P3M1 &= 0xfb;PSEG_5 = 1;


  25. /************************************************************************************/
  26. void LED_GPIO_Init(void)//初始化IO口
  27. {  
  28.         P3PU &= 0x83;                        //關閉上拉電阻
  29.         P3M1 &= 0x83;           //設置P3.2~P3.6為推挽輸出
  30.         P3M0 |= 0x7c;
  31. }
  32. /********************************熄滅所有數碼管***********************************/
  33. void Set_AllPin_INPUT(void)
  34. {
  35.         PIN1_IN();//把單片機IO口配置為輸入模式
  36.         PIN2_IN();
  37.         PIN3_IN();
  38.         PIN4_IN();
  39.         PIN5_IN();
  40. }

  41. unsigned char bai=0,shi=0,ge=0;//百位,十位,個位,
  42. unsigned short display_sram=0;
  43. unsigned short code Segment[3][11]={
  44.   {0x0000,0x0006,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000,0x0000},//百位
  45.   {0x0770,0x0420,0x0741,0x0661,0x0431,0x0271,0x0371,0x0460,0x0771,0x0671,0x0000},//十位
  46.   {0xE888,0x8080,0xD808,0xD880,0xB080,0x7880,0x7888,0x8880,0xF888,0xF880,0x0000} //個位
  47.         };

  48. void Display_Scan1(void)
  49. {
  50.           PIN1_L();        //拉低Pin1

  51.     if(display_sram&0x8000)        //取出最高位
  52.         PIN2_H();
  53.     if(display_sram&0x4000)
  54.         PIN3_H();
  55.     if(display_sram&0x2000)
  56.         PIN4_H();        
  57.     if(display_sram&0x1000)
  58.         PIN5_H();
  59. }
  60. void Display_Scan2(void)
  61. {
  62.           PIN2_L();        //拉低Pin2
  63.         
  64.     if(display_sram&0x0800)
  65.         PIN1_H();
  66.     if(display_sram&0x0400)
  67.         PIN3_H();               
  68.     if(display_sram&0x0200)
  69.         PIN4_H();
  70.     if(display_sram&0x0100)
  71.         PIN5_H();
  72. }
  73. void Display_Scan3(void)
  74. {
  75.           PIN3_L();        //拉低Pin3
  76.         
  77.     if(display_sram&0x0080)
  78.         PIN1_H();
  79.     if(display_sram&0x0040)
  80.         PIN2_H();;
  81.     if(display_sram&0x0020)
  82.         PIN4_H();
  83.     if(display_sram&0x0010)
  84.         PIN5_H();
  85. }
  86. void Display_Scan4(void)
  87. {
  88.           PIN4_L();        //拉低Pin4
  89.         
  90.     if(display_sram&0x0008)
  91.         PIN1_H();
  92.     if(display_sram&0x0004)
  93.         PIN2_H();
  94.     if(display_sram&0x0002)
  95.         PIN3_H();
  96.     if(display_sram&0x0001)
  97.         PIN5_H();
  98. }

  99. /****************************顯示函數***********************************/

  100. //放在定時器中斷函數,5ms運行一次,掃描一輪需要4*5ms=20ms,
  101. //也就是50Hz的刷新頻率,如果感覺閃爍,可以4ms運行。
  102. void Display_tube(void)
  103. {
  104.     static unsigned char case_cnt;//逐行掃描
  105.     Set_AllPin_INPUT();//消影作用
  106.     display_sram=0;
  107.     display_sram=Segment[0][bai] | Segment[1][shi] | Segment[2][ge];//顯示百位,十位,個位
  108.     switch(case_cnt)
  109.     {
  110.       case 0x00:Display_Scan1();case_cnt++;break;
  111.       case 0x01:Display_Scan2();case_cnt++;break;
  112.       case 0x02:Display_Scan3();case_cnt++;break;
  113.       case 0x03:Display_Scan4();case_cnt=0;break;
  114.       default:case_cnt=0;break;
  115.     }
  116. }

  117. void Dispaly_Dig(unsigned int dig)//拆分
  118. {        
  119.         bai = dig/100;
  120.         shi = (dig/10)%10;
  121.         ge = dig%10;
  122.         Display_tube();
  123. }
復制代碼

這是定時器中斷函數,4ms一次刷新
  1. void TM1_Isr() interrupt 3 //定時器1
  2. {
  3.         static unsigned char case_cnt;//定時中斷次數
  4.         case_cnt++;
  5.         if(case_cnt==4)
  6.         {
  7.                 case_cnt=0;
  8.                 Dispaly_Dig(12);//顯示數字12
  9.         }
  10. }
復制代碼

這是原理圖,直接連到了單片機引腳上



這是效果圖,圖一加有消影函數,圖二未添加,消影函數如圖三所示



拜托大家了

最佳答案

查看完整內容

采用查理復用IO驅動方式,掃描周期小于1.25ms,每次只需點亮一個筆段,分16次完成一輪,不必消隱。
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏6 分享淘帖 頂 踩
回復

使用道具 舉報

沙發(fā)
ID:213173 發(fā)表于 2022-2-12 15:03 | 只看該作者
采用查理復用IO驅動方式,掃描周期小于1.25ms,每次只需點亮一個筆段,分16次完成一輪,不必消隱。 查理復用IO驅動數碼管.docx (92.31 KB, 下載次數: 166)

回復

使用道具 舉報

板凳
ID:313048 發(fā)表于 2022-2-12 16:22 | 只看該作者
先顯示再消影,你先消影再顯示就相當于程序跑了一圈,然后你開頭滅一下 大部分時間都是亮的
回復

使用道具 舉報

地板
ID:962396 發(fā)表于 2022-2-12 22:37 | 只看該作者
wulin 發(fā)表于 2022-2-12 21:10
采用查理復用IO驅動方式,掃描周期小于1.25ms,每次只需點亮一個筆段,分16次完成一輪,不必消隱。

謝謝學習一下
回復

使用道具 舉報

5#
ID:575020 發(fā)表于 2022-2-13 23:40 | 只看該作者
以前還在糾結數碼管用573、595、還有TM、MAX系列到底那種方式好,今天看到這種5腳2位半數碼管又徹底傻眼了,想不通怎么會有如此怪異設計的數碼管。

1.jpg (63.78 KB, 下載次數: 150)

1.jpg
回復

使用道具 舉報

6#
ID:399179 發(fā)表于 2022-3-26 21:58 來自手機 | 只看該作者
哎呀!我也遇到這樣的問題了
回復

使用道具 舉報

7#
ID:1067504 發(fā)表于 2023-7-21 22:00 來自手機 | 只看該作者
能不能分享完整的源代碼,我想學習一下,謝謝!
回復

使用道具 舉報

8#
ID:1073939 發(fā)表于 2023-7-22 16:59 | 只看該作者
你這代碼就是查理復用。沙發(fā)的一次只點亮一個燈,亮度為你現在驅動的1/4,還沒你現在驅動好。
消隱后要先準備數據,再拉低相應腳,使需要亮的LED同時亮。
你代碼框架不好,整理了一下。

  1. #include "188.h"
  2. #include "delay.h"
  3. #include "intrins.h"
  4. #include "stc8g.h"

  5. sbit PSEG_1 = P3 ^ 6;
  6. sbit PSEG_2 = P3 ^ 5;
  7. sbit PSEG_3 = P3 ^ 4;
  8. sbit PSEG_4 = P3 ^ 3;
  9. sbit PSEG_5 = P3 ^ 2;

  10. #define PIN1_IN() \
  11.     P3M1 |= 0x40; \
  12.     P3M0 &= 0xbf; // 把單片機IO口配置為高阻輸入
  13. #define PIN2_IN() \
  14.     P3M1 |= 0x20; \
  15.     P3M0 &= 0xdf;
  16. #define PIN3_IN() \
  17.     P3M1 |= 0x10; \
  18.     P3M0 &= 0xef;
  19. #define PIN4_IN() \
  20.     P3M1 |= 0x08; \
  21.     P3M0 &= 0xf7;
  22. #define PIN5_IN() \
  23.     P3M1 |= 0x04; \
  24.     P3M0 &= 0xfb;

  25. #define PIN1_L()  \
  26.     P3M0 |= 0x40; \
  27.     P3M1 &= 0xbf; \
  28.     PSEG_1 = 0; // 配置為推挽輸出,且拉低
  29. #define PIN2_L()  \
  30.     P3M0 |= 0x20; \
  31.     P3M1 &= 0xdf; \
  32.     PSEG_2 = 0;
  33. #define PIN3_L()  \
  34.     P3M0 |= 0x10; \
  35.     P3M1 &= 0xef; \
  36.     PSEG_3 = 0;
  37. #define PIN4_L()  \
  38.     P3M0 |= 0x08; \
  39.     P3M1 &= 0xf7; \
  40.     PSEG_4 = 0;
  41. #define PIN5_L()  \
  42.     P3M0 |= 0x04; \
  43.     P3M1 &= 0xfb; \
  44.     PSEG_5 = 0;

  45. #define PIN1_H()  \
  46.     P3M0 |= 0x40; \
  47.     P3M1 &= 0xbf; \
  48.     PSEG_1 = 1; // 配置為推挽輸出,且拉高
  49. #define PIN2_H()  \
  50.     P3M0 |= 0x20; \
  51.     P3M1 &= 0xdf; \
  52.     PSEG_2 = 1;
  53. #define PIN3_H()  \
  54.     P3M0 |= 0x10; \
  55.     P3M1 &= 0xef; \
  56.     PSEG_3 = 1;
  57. #define PIN4_H()  \
  58.     P3M0 |= 0x08; \
  59.     P3M1 &= 0xf7; \
  60.     PSEG_4 = 1;
  61. #define PIN5_H()  \
  62.     P3M0 |= 0x04; \
  63.     P3M1 &= 0xfb; \
  64.     PSEG_5 = 1;

  65. /************************************************************************************/
  66. void LED_GPIO_Init(void) // 初始化IO口
  67. {
  68.     P3PU &= 0x83; // 關閉上拉電阻
  69.     P3M1 &= 0x83; // 設置P3.2~P3.6為推挽輸出
  70.     P3M0 |= 0x7c;
  71. }
  72. /********************************熄滅所有數碼管***********************************/
  73. void Set_AllPin_INPUT(void)
  74. {
  75.     PIN1_IN(); // 把單片機IO口配置為輸入模式
  76.     PIN2_IN();
  77.     PIN3_IN();
  78.     PIN4_IN();
  79.     PIN5_IN();
  80. }
  81. unsigned short display_sram = 0;
  82. void Display_Scan1(void)
  83. {
  84.     // PIN1_L(); // 拉低Pin1,放后面能保證4個燈同時亮
  85.     if (display_sram & 0x8000) // 取出最高位
  86.         PIN2_H();
  87.     if (display_sram & 0x4000)
  88.         PIN3_H();
  89.     if (display_sram & 0x2000)
  90.         PIN4_H();
  91.     if (display_sram & 0x1000)
  92.         PIN5_H();
  93.     PIN1_L(); // 拉低Pin1,放后面能保證4個燈同時亮
  94. }
  95. void Display_Scan2(void)
  96. {
  97.     if (display_sram & 0x0800)
  98.         PIN1_H();
  99.     if (display_sram & 0x0400)
  100.         PIN3_H();
  101.     if (display_sram & 0x0200)
  102.         PIN4_H();
  103.     if (display_sram & 0x0100)
  104.         PIN5_H();
  105.     PIN2_L(); // 拉低Pin2
  106. }
  107. void Display_Scan3(void)
  108. {
  109.     if (display_sram & 0x0080)
  110.         PIN1_H();
  111.     if (display_sram & 0x0040)
  112.         PIN2_H();
  113.     ;
  114.     if (display_sram & 0x0020)
  115.         PIN4_H();
  116.     if (display_sram & 0x0010)
  117.         PIN5_H();
  118.     PIN3_L(); // 拉低Pin3
  119. }
  120. void Display_Scan4(void)
  121. {
  122.     if (display_sram & 0x0008)
  123.         PIN1_H();
  124.     if (display_sram & 0x0004)
  125.         PIN2_H();
  126.     if (display_sram & 0x0002)
  127.         PIN3_H();
  128.     if (display_sram & 0x0001)
  129.         PIN5_H();
  130.     PIN4_L(); // 拉低Pin4
  131. }

  132. unsigned short code Segment[3][11] = {
  133.     {0x0000, 0x0006, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000}, // 百位
  134.     {0x0770, 0x0420, 0x0741, 0x0661, 0x0431, 0x0271, 0x0371, 0x0460, 0x0771, 0x0671, 0x0000}, // 十位
  135.     {0xE888, 0x8080, 0xD808, 0xD880, 0xB080, 0x7880, 0x7888, 0x8880, 0xF888, 0xF880, 0x0000}  // 個位
  136. };
  137. unsigned short g_display_sram = 0;
  138. void Dispaly_Dig(unsigned int dig) // 拆分
  139. {
  140.     unsigned char bai = dig / 100;
  141.     unsigned char shi = (dig / 10) % 10;
  142.     unsigned char ge = dig % 10;
  143.     unsigned short i16 = Segment[0][bai] | Segment[1][shi] | Segment[2][ge]; // 顯示百位,十位,個位
  144.     EA = 0;
  145.     // 改變g_display_sram不是原子操作,所以要關中斷。
  146.     // 增加全局變量g_display_sram,是為了盡量減少中斷的運算量
  147.     g_display_sram = i16;
  148.     EA = 1;
  149. }

  150. // 定時器中斷函數,5ms運行一次,掃描一輪需要4*5ms=20ms,
  151. // 也就是50Hz的刷新頻率,如果感覺閃爍,可以4ms運行。
  152. void TM1_Isr() interrupt 3 // 定時器1
  153. {
  154.     // static unsigned short display_sram = 0;
  155.     static unsigned char case_cnt = 0; // 逐行掃描
  156.     Set_AllPin_INPUT();                // 消影作用
  157.     switch (case_cnt)
  158.     {
  159.     case 0x00:
  160.         Display_Scan1();
  161.         case_cnt++;
  162.         break;
  163.     case 0x01:
  164.         Display_Scan2();
  165.         case_cnt++;
  166.         break;
  167.     case 0x02:
  168.         Display_Scan3();
  169.         case_cnt++;
  170.         break;
  171.     case 0x03:
  172.         Display_Scan4();
  173.         case_cnt = 0;
  174.         display_sram = g_display_sram; // 僅在此處改變display_sram
  175.         break;
  176.     default:
  177.         case_cnt = 0;
  178.         break;
  179.     }
  180. }
復制代碼


  1. /*
  2. 0~999循環(huán)顯示
  3. */
  4. void Dispaly_Dig_loop()
  5. {
  6.     unsigned short i16 = 0;
  7.     while (1)
  8.     {
  9.         Dispaly_Dig(i16++);
  10.         if (i16 == 1000)
  11.             i16 = 0;
  12.         delayMs(500);
  13.     }
  14. }
復制代碼

回復

使用道具 舉報

9#
ID:1067504 發(fā)表于 2023-7-22 20:03 來自手機 | 只看該作者
這個數組是怎么得來的?怎么取模的?
回復

使用道具 舉報

10#
ID:1073939 發(fā)表于 2023-7-24 10:24 | 只看該作者
螞蟻科技 發(fā)表于 2023-7-22 20:03
這個數組是怎么得來的?怎么取模的?

樓主文中有鏈接。

回復

使用道具 舉報

11#
ID:361594 發(fā)表于 2024-4-28 08:25 來自手機 | 只看該作者
我是CSDN的原創(chuàng)作者,評論區(qū)各位都是在瞎扯淡,這個代碼已經是用在量產產品了,根本沒有你們所說的問題,肯定是樓主單片機的寄存器沒有配置好,
回復

使用道具 舉報

12#
ID:1125252 發(fā)表于 2024-7-18 08:43 | 只看該作者
問下P3M1/P3M0分別指代什么?是分別指代共陽端和負極嗎?
回復

使用道具 舉報

13#
ID:619259 發(fā)表于 2024-7-18 12:51 | 只看該作者
關于188數碼管,經過研究與實踐,幾點總結:
1.單片機IO口要有推挽輸出和高阻輸入模式,我用的是STC32G單片機,在實踐中采用推挽輸出和高阻輸入兩種模式配合驅動。(使用準雙向和高阻模式時,亮度暗,不推薦)。
2.先測試各引腳的電平與字段的對應關系,得出引腳驅動電平關系表(紅色為高電平、藍色為低電平)。

3.根據驅動電平關系表配置IO口。
下圖為IO配置代碼表,本案例使用P1.3-P1.7驅動。

4.逐段驅動(總20段),動態(tài)掃描。
以第三位為例,掃描程序如下:

每掃描完成一個字段,都需要消隱,不然會出現鬼影。
顯示效果如下圖:

回復

使用道具 舉報

14#
ID:59202 發(fā)表于 2024-7-18 19:30 | 只看該作者
P3M1/P3M0是STC單片機的P3口配置寄存器,拿來設置I/O口工作模式的
回復

使用道具 舉報

15#
ID:828160 發(fā)表于 2024-7-18 20:46 | 只看該作者
這么簡單的數碼管,直接用帶LED串行點陣的單片機就可以驅動了,最多9個IO驅動64個LED,而且還能調亮度,不僅能調16級亮度,還可以讓同時亮的LED顯示兩種不同的亮度。

BF6612SCXXB-XJLK-MCU CN-Datasheet-V1.0-22-03-03.pdf (5.52 MB, 下載次數: 13)

回復

使用道具 舉報

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

本版積分規(guī)則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 中文成人在线 | 欧美成视频| 国产一区二区三区久久 | 毛片视频观看 | 91亚洲一区 | 亚洲视频在线一区 | 国产成人99久久亚洲综合精品 | 日韩成人在线免费观看 | 亚洲一区二区三区视频免费观看 | 四虎在线观看 | a在线观看| 亚洲精品自在在线观看 | 日本高清不卡视频 | 久久久久国产精品一区二区 | 日本a在线 | 日韩三| 香蕉视频91| 日韩高清国产一区在线 | 一区二区三区观看视频 | 欧美一区2区三区3区公司 | 91视频在线观看 | 国产在线精品一区 | 六月成人网 | 婷婷福利 | 黄一级| 欧美无乱码久久久免费午夜一区 | 日韩精品一区二区三区免费视频 | 欧美成年黄网站色视频 | 成人av高清 | 伊人看片 | 亚洲综合色 | 欧美片网站免费 | 国产日批| 欧美 日本 国产 | 久久成人一区 | 亚洲精品1 | 日本特黄a级高清免费大片 国产精品久久性 | 国产激情毛片 | 日本一区二区不卡 | 国产在视频一区二区三区吞精 | 欧美精品二区 |