<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁(yè) > 消費(fèi)電子 > 也談LED驅(qū)動(dòng)

          也談LED驅(qū)動(dòng)

          ——
          作者: 時(shí)間:2007-03-29 來(lái)源: 收藏
          (Lite Emit Diode)顯示是項(xiàng)目開(kāi)發(fā)中經(jīng)常遇到的一種顯示方法,其具有亮度高、全視角、使用壽命長(zhǎng)、驅(qū)動(dòng)簡(jiǎn)單等特點(diǎn),因而在一些高端和大型的器材和設(shè)備上使用較為廣泛。下面就常用的顯示及驅(qū)動(dòng)方法作一說(shuō)明: 
          :本文所說(shuō)的LED主要是指下列幾種:
          7-段數(shù)碼LED,分共陰和共陽(yáng)兩種,原理圖見(jiàn)1和2; 

          常用nxm LED點(diǎn)陣:如8x8 LED 點(diǎn)陣模塊、5x7 LED點(diǎn)陣模塊等,其也分為共陰和共陽(yáng)兩種; 
          單個(gè)LED管。
          所謂共陰極,即是將所有LED的陰極連接到一起,而共陽(yáng)極則相反,所有的陽(yáng)極被連接到了一起。但不管哪種結(jié)構(gòu),其顯示設(shè)計(jì)的原理基本相同,唯一的是其驅(qū)動(dòng)的電路的設(shè)計(jì)有所差異,一般共陰極采用推(Push)電流的方式來(lái)驅(qū)動(dòng),而共陽(yáng)極結(jié)構(gòu)則采用拉(Pull)電流的方式來(lái)驅(qū)動(dòng)。
          根據(jù)LED顯示的硬件設(shè)計(jì)方法的不同,LED顯示驅(qū)動(dòng)分為靜態(tài)法和動(dòng)態(tài)法兩大類(lèi),其具體的說(shuō)明和編程方法分述如下:
          1.靜態(tài)顯示驅(qū)動(dòng)法:
          所謂靜態(tài)顯示驅(qū)動(dòng)法,即是指每一個(gè)LED燈分別對(duì)應(yīng)一個(gè)獨(dú)立的IO驅(qū)動(dòng)口;其點(diǎn)亮和關(guān)閉由該IO來(lái)對(duì)其進(jìn)行控制,互不干擾,見(jiàn)圖3(注:對(duì)于IO驅(qū)動(dòng)能力弱的MCU,必須增加外部的驅(qū)動(dòng)芯片或驅(qū)動(dòng)三極管等器件)。此種設(shè)計(jì)一般應(yīng)用在對(duì)單個(gè)LED的驅(qū)動(dòng)或LED數(shù)量較少,且所選的MCU IO比較充裕的情況下。比如一些項(xiàng)目的LED指示燈、產(chǎn)品的設(shè)計(jì)中只有一個(gè)7-段LED碼需要顯示等。

          由于每一個(gè)LED均由獨(dú)立的IO口來(lái)控制,因此此種顯示驅(qū)動(dòng)的軟件設(shè)計(jì)比較簡(jiǎn)單明了,無(wú)需特別的處理,在需要點(diǎn)亮和關(guān)閉時(shí)設(shè)置相應(yīng)的IO輸出口的電平即可(即“0”或“1”,具體須根據(jù)驅(qū)動(dòng)電路的設(shè)計(jì)來(lái)決定)。
             

           圖 3

          優(yōu)點(diǎn):電路設(shè)計(jì)簡(jiǎn)單,編程簡(jiǎn)單,而且LED的亮度控制容易,只需在驅(qū)動(dòng)端增加相應(yīng)的電流調(diào)節(jié)電阻即可方便地實(shí)現(xiàn)亮度的調(diào)節(jié)(對(duì)于存在獨(dú)立驅(qū)動(dòng)的設(shè)計(jì),還可以通過(guò)調(diào)整驅(qū)動(dòng)電壓來(lái)達(dá)到亮度的調(diào)節(jié))。
          缺點(diǎn):由于每一個(gè)LED燈需要一個(gè)IO口,因此對(duì)IO口的需求較大,不易實(shí)現(xiàn)大數(shù)量的和顯示,擴(kuò)展性能差。


          2. 動(dòng)態(tài)的顯示驅(qū)動(dòng)法: 

              與靜態(tài)顯示方法不同,動(dòng)態(tài)LED顯示的設(shè)計(jì)方法是將不同LED模塊的所有的LED的驅(qū)動(dòng)端一對(duì)一地連接到一起,見(jiàn)圖4,而將其公共極(陰極或陽(yáng)極)分別由不同的IO口來(lái)驅(qū)動(dòng)(主要針對(duì)7-段碼和LED點(diǎn)陣模塊)。在此,我們稱(chēng)其公共極為掃描線(xiàn)或地址線(xiàn)(因此種連接方法類(lèi)似于存儲(chǔ)器的內(nèi)部連接,每個(gè)LED點(diǎn)相當(dāng)與Memory中的一個(gè)Bit),不同的LED模塊(類(lèi)似于Memory中的一個(gè)Byte)用不同的掃描線(xiàn)地址線(xiàn)來(lái)進(jìn)行選定。



          由于所有的LED模塊公用了驅(qū)動(dòng)端,因此LED的驅(qū)動(dòng)不再像靜態(tài)法一樣為每個(gè)LED所獨(dú)享,因此其驅(qū)動(dòng)的設(shè)計(jì)方法也與靜態(tài)法完全不同,需要采用分時(shí)掃描(也稱(chēng)動(dòng)態(tài)掃描)方法來(lái)實(shí)現(xiàn)對(duì)所有LED的顯示驅(qū)動(dòng),其原理如下(以圖4為例):

          a. 將A0設(shè)置為高電平,也即允許第一組LED顯示,同時(shí)將A2,A3,A4設(shè)置為低電平,也即關(guān)閉該陰極所對(duì)應(yīng)的LED組的顯示;


          b.在P0口輸出A0組對(duì)應(yīng)的顯示數(shù)據(jù)(也稱(chēng)為Pattern),如字符點(diǎn)陣數(shù)據(jù),7-段碼對(duì)應(yīng)的數(shù)字的數(shù)據(jù)等,該數(shù)據(jù)可以通過(guò)ROM表的形式來(lái)預(yù)先定義;


          c. 保持一定的時(shí)間T,該時(shí)間即為所設(shè)定定時(shí)器的中斷時(shí)間;


          d. 將A0口設(shè)置為低電平,關(guān)閉A0組LED的顯示;


          e.將A1設(shè)置為高電平,其他幾個(gè)設(shè)置為低電平,開(kāi)啟A1組對(duì)應(yīng)的LED的顯示;


          f. 在P0口輸出A1組對(duì)應(yīng)的顯示數(shù)據(jù)(也稱(chēng)為Pattern,意義同上);


          g.重復(fù)以上步驟,直到所有組被掃描一遍,然后又從A0組開(kāi)始下一個(gè)循環(huán),如此周而復(fù)始,實(shí)現(xiàn)所有LED的動(dòng)態(tài)顯示。


          該方法的原理利用了人眼對(duì)物體的視覺(jué)延遲來(lái)達(dá)到所有LED的同時(shí)顯示,實(shí)際上,在每一個(gè)時(shí)刻,只有一組LED是處于顯示的狀態(tài),而其他LED組均為關(guān)閉狀態(tài)。理論上,若兩次顯示之間的時(shí)間間隔小于32ms時(shí),人眼即無(wú)法分辨,因此,為了達(dá)到此要求,LED的掃描頻率一般可按照下式計(jì)算得出:
          f = 32 * N
          式中,

          f為掃描的頻率,對(duì)應(yīng)為定時(shí)器的定時(shí)時(shí)間(T=1/f);
          32 則是由32ms換算而來(lái),32ms對(duì)應(yīng)的頻率剛好為 32Hz;
          N則是總的LED的組數(shù)(此例中為N=4)。


          根據(jù)此式算出的掃描頻率f實(shí)際上是LED 驅(qū)動(dòng)掃描的最小頻率,若低于此頻率,則有可能導(dǎo)致LED的閃爍。當(dāng)然,f也不可能越高越好,掃描的頻率太高,相對(duì)而言,每一組LED的點(diǎn)亮的時(shí)間就越短,因此有可能導(dǎo)致LED的亮度不夠或顯示效果不理想等一些問(wèn)題。當(dāng)然提高LED的驅(qū)動(dòng)電壓也可以彌補(bǔ)由此造成的亮度不夠的問(wèn)題。
          此例中,由公式可知其掃描的頻率應(yīng)大于等于128Hz,則較為理想。


          2. MCU程序的實(shí)現(xiàn):


          a.模塊的劃分:


          在說(shuō)明其編程之前,先說(shuō)明一下模塊化編程思想在設(shè)計(jì)中的應(yīng)用。為了使程序的結(jié)構(gòu)清晰和維護(hù)的便利,特別是為了使程序的移植等變得可行,在程序的設(shè)計(jì)過(guò)程中應(yīng)盡可能地采用模塊化的設(shè)計(jì)思想,對(duì)于復(fù)雜的程序結(jié)構(gòu)和功能的實(shí)現(xiàn),更應(yīng)該在編程之前理順其相互之間的關(guān)系,劃分好各功能模塊所應(yīng)完成的功能,定義好各模塊之間的數(shù)據(jù)接口和相互關(guān)系。


          一般而言,顯示部分所涉及到的內(nèi)容和功能相對(duì)較廣,比如按鍵的變化、系統(tǒng)狀態(tài)的變化、數(shù)據(jù)的變化等均需在顯示的結(jié)果上表現(xiàn)出來(lái)。因此,為了保證不同的模塊之間的獨(dú)立性,我們將與LED顯示的有關(guān)的功能進(jìn)行如下的劃分:


          1. 掃描驅(qū)動(dòng)模塊:此模塊的功能只完成對(duì)所有LED的掃描,而不關(guān)心所顯示的數(shù)據(jù)的具體變化情況,其從固定的顯示緩沖其中提取每一掃描地址所對(duì)應(yīng)的數(shù)據(jù),該對(duì)應(yīng)關(guān)系是固定的,由程序設(shè)計(jì)時(shí)來(lái)設(shè)定。該實(shí)現(xiàn)的方法類(lèi)似與PC機(jī)中CRT的顯示驅(qū)動(dòng)和顯示緩沖;


          2.字符、點(diǎn)陣發(fā)生器:由于實(shí)際的數(shù)據(jù)與顯示的數(shù)據(jù)(Pattern)之間并非是相同的,因此,需要將實(shí)際的數(shù)據(jù)轉(zhuǎn)化成能夠顯示的數(shù)據(jù)。例如在MCU中的各種計(jì)算的數(shù)據(jù)是以BCD碼或二進(jìn)制碼的形式來(lái)表示的,需要將其轉(zhuǎn)化成7-段碼或nxn點(diǎn)陣的Pattern數(shù)據(jù)進(jìn)行顯示;


          3.顯示緩沖刷新和處理模塊:該模塊的功能是接受諸如按鍵、系統(tǒng)狀態(tài)變化、數(shù)據(jù)變化所引起的顯示數(shù)據(jù)的變化。其需要調(diào)用到字符、點(diǎn)陣發(fā)生器來(lái)完成顯示緩沖的刷新,其與按鍵、系統(tǒng)狀態(tài)變化等之間的接口是采用消息的機(jī)制來(lái)實(shí)現(xiàn)。該模塊一般需要根據(jù)不同的顯示內(nèi)容來(lái)進(jìn)行分類(lèi),比如在跑步機(jī)的設(shè)計(jì)中,可以劃分為如下的內(nèi)容:距離、速度、時(shí)間、能量消耗、心率及其他相關(guān)的數(shù)據(jù)。 

           




          b.程序架構(gòu)和實(shí)現(xiàn)


          1.掃描模塊的實(shí)現(xiàn):由于LED的掃描驅(qū)動(dòng)是一個(gè)重復(fù)的不間斷的過(guò)程,自然,定時(shí)中斷是最好的實(shí)現(xiàn)方法,其流程如圖6所示,其中BuffPt用于指向當(dāng)前的顯示緩沖區(qū),Ai則為當(dāng)前所需顯示的LED組的地址編號(hào),從0到N(N為總的LED組數(shù));


          2.刷新模塊的實(shí)現(xiàn):在MCU的程序設(shè)計(jì)中,一般將此模塊置于16Hz的定時(shí)中斷中(若主程序的循環(huán)周期不固定且最大的循環(huán)時(shí)間大于1/10秒時(shí),常采用此架構(gòu))或主程序循環(huán)體中(此種情況主要時(shí)針對(duì)MCU時(shí)鐘比較高的場(chǎng)合或不需考慮顯示延時(shí)的情況下),通過(guò)檢測(cè)對(duì)應(yīng)的消息來(lái)決定其是否需要執(zhí)行數(shù)據(jù)的刷新。以跑步機(jī)的設(shè)計(jì)為例,其功能流程如圖7所示;


          3.字符、點(diǎn)陣發(fā)生器:由于在一些實(shí)際的應(yīng)用中,可能的顯示內(nèi)容原則上是可預(yù)知的和有限的,特別是漢字的顯示,因此其主要是通過(guò)定義相應(yīng)的點(diǎn)陣來(lái)保存各種需要顯示數(shù)據(jù)。為了便于程序的設(shè)計(jì),一般需將其按照一定的排列規(guī)則來(lái)進(jìn)行定義,同時(shí)也需要為各個(gè)需要顯示的字符和圖符進(jìn)行編碼,編碼的規(guī)則必須有利于程序的設(shè)計(jì)和提高代碼的效率,以求能夠采用統(tǒng)一的查表指令來(lái)實(shí)現(xiàn)。 
            

          圖6


          注:上述的流程只是一個(gè)原理性的程序說(shuō)明,在實(shí)際的應(yīng)用中,需要根據(jù)MCU的特點(diǎn)及具體的硬件設(shè)計(jì)來(lái)進(jìn)行程序的設(shè)計(jì)與簡(jiǎn)化。比如:在實(shí)際的項(xiàng)目中有8x8(或小于8x8)個(gè)LED需要驅(qū)動(dòng),而且所選的MCU又是8位或16位的,則此時(shí)的地址線(xiàn)的掃描將變得非常的簡(jiǎn)單,只要建立字節(jié)變量Ai,其初始值為0x01,然后在每次中斷處理程序中需將Ai直接輸出到LED掃描線(xiàn)所對(duì)應(yīng)的IO口即可,隨后將Ai左移一位,對(duì)8x8 LED情況,當(dāng)Ai=0時(shí),表示一遍掃描完成,此時(shí)再將Ai設(shè)為0x01即可。對(duì)于顯示的緩沖區(qū)的分配,同樣可以根據(jù)實(shí)際的軟件設(shè)計(jì)來(lái)分配具體的RAM地址空間,以進(jìn)一步提高程序的執(zhí)行效率。記住,由于LED的掃描需要占用較多的MCU時(shí)間,因此在進(jìn)行掃描驅(qū)動(dòng)的程序設(shè)計(jì)時(shí),需要盡可能采用簡(jiǎn)潔高效的代碼,以便提高M(jìn)CU的工作效率。舉例來(lái)說(shuō),假如需驅(qū)動(dòng)8x8 LED,根據(jù)前面所講的要求,所需的定時(shí)器的中斷頻率必須是大于等于8x32,即256Hz,若在此驅(qū)動(dòng)代碼中多增加一條語(yǔ)句,則MCU每秒就需要多執(zhí)行256條代碼,由此可見(jiàn)高效的代碼對(duì)于程序來(lái)講是多么重要,特別是當(dāng)MCU的時(shí)鐘不夠快時(shí)!



          評(píng)論


          相關(guān)推薦

          技術(shù)專(zhuān)區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();