找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索

單片機188數(shù)碼管消影程序調試問題

查看數(shù): 6487 | 評論數(shù): 14 | 收藏 6
關燈 | 提示:支持鍵盤翻頁<-左 右->
    組圖打開中,請稍候......
發(fā)布時間: 2022-2-12 15:03

正文摘要:

大家好,請教一下,我在使用188數(shù)碼管時,遇到了一個消影問題,數(shù)碼管動態(tài)掃描,在刷新函數(shù)中,已經加入了消影語句,即各個引腳設置為高阻輸入,但是不應該亮的數(shù)碼管還是會有弱光,所以顯示并不清晰,當然消影函數(shù) ...

回復

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

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

ID:59202 發(fā)表于 2024-7-18 19:30
P3M1/P3M0是STC單片機的P3口配置寄存器,拿來設置I/O口工作模式的
ID:619259 發(fā)表于 2024-7-18 12:51
關于188數(shù)碼管,經過研究與實踐,幾點總結:
1.單片機IO口要有推挽輸出和高阻輸入模式,我用的是STC32G單片機,在實踐中采用推挽輸出和高阻輸入兩種模式配合驅動。(使用準雙向和高阻模式時,亮度暗,不推薦)。
2.先測試各引腳的電平與字段的對應關系,得出引腳驅動電平關系表(紅色為高電平、藍色為低電平)。

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

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

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

ID:1125252 發(fā)表于 2024-7-18 08:43
問下P3M1/P3M0分別指代什么?是分別指代共陽端和負極嗎?
ID:361594 發(fā)表于 2024-4-28 08:25
我是CSDN的原創(chuàng)作者,評論區(qū)各位都是在瞎扯淡,這個代碼已經是用在量產產品了,根本沒有你們所說的問題,肯定是樓主單片機的寄存器沒有配置好,
ID:1073939 發(fā)表于 2023-7-24 10:24
螞蟻科技 發(fā)表于 2023-7-22 20:03
這個數(shù)組是怎么得來的?怎么取模的?

樓主文中有鏈接。

ID:1067504 發(fā)表于 2023-7-22 20:03
這個數(shù)組是怎么得來的?怎么取模的?
ID:1073939 發(fā)表于 2023-7-22 16:59
你這代碼就是查理復用。沙發(fā)的一次只點亮一個燈,亮度為你現(xiàn)在驅動的1/4,還沒你現(xiàn)在驅動好。
消隱后要先準備數(shù)據(jù),再拉低相應腳,使需要亮的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. /********************************熄滅所有數(shù)碼管***********************************/
  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. // 定時器中斷函數(shù),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. }
復制代碼

ID:1067504 發(fā)表于 2023-7-21 22:00
能不能分享完整的源代碼,我想學習一下,謝謝!
ID:399179 發(fā)表于 2022-3-26 21:58
哎呀!我也遇到這樣的問題了
ID:575020 發(fā)表于 2022-2-13 23:40
以前還在糾結數(shù)碼管用573、595、還有TM、MAX系列到底那種方式好,今天看到這種5腳2位半數(shù)碼管又徹底傻眼了,想不通怎么會有如此怪異設計的數(shù)碼管。

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

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

謝謝學習一下
ID:313048 發(fā)表于 2022-2-12 16:22
先顯示再消影,你先消影再顯示就相當于程序跑了一圈,然后你開頭滅一下 大部分時間都是亮的
ID:213173 發(fā)表于 2022-2-12 15:03
采用查理復用IO驅動方式,掃描周期小于1.25ms,每次只需點亮一個筆段,分16次完成一輪,不必消隱。 查理復用IO驅動數(shù)碼管.docx (92.31 KB, 下載次數(shù): 166)

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

Powered by 單片機教程網(wǎng)

快速回復 返回頂部 返回列表