《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > CPLD設計的數碼管驅動顯示電路
CPLD設計的數碼管驅動顯示電路
摘要: 八段數碼管每一段為一發光二極管,共有a~g以及小數點dp八個發光二極管。將八段數碼管中的每個二極管的陰極并聯在一起,組成公共陰極端。這樣把共陰極管腳接地,此時哪個管腳輸入高電平,對應發光二極管就被點亮。
關鍵詞: CPLD 數碼管 驅動
Abstract:
Key words :

 CPLD設計的數碼管驅動顯示電路

1.1 顯示原理:

八段數碼顯示管如圖1.1 所示,八段數碼管每一段為一發光二極管,共有a~g 以及小數點dp 八個發光二極管。將八段數碼管中的每個二極管的陰極并聯在一起,組成公共陰極端。這樣把共陰極管腳接地,此時哪個管腳輸入高電平,對應發光二極管就被點亮。

 


圖 1.1 八段數碼顯示管

CL5461AS 數碼管管腳圖如圖1.2 所示,它將四個數碼顯示管的a~g 及小數點dp 管腳并聯在一起,作為數碼管數據輸入端;分別引出各個數碼管的陰極A1~A4。

 


圖1.2 CL5461AS 數碼管管腳圖

只要在A1~A4 管腳上輪流加低電平其頻率大于40Hz,可實現四個數碼管同時被點亮的視覺效果。在點亮不同數碼管的同時輸入不同的數據,即可在數碼管上同時顯示四位不同的數字。例如:四個數碼管要顯示9876 數字。第一個數碼管A1 加低電平,其余A2、A3、 A4高電平,同時數碼管輸入和9 對應的數據;然后第二個數碼管A2 加低電平,其余A1、A3 、A4 高電平,同時數碼管輸入和8 對應的數據;然后第三個數碼管A3 加低電平,其余A1、A2 、A4 高電平,同時數碼管輸入和7 對應的數據;然后第四個數碼管A4 加低電平,其余A1、A2 、A3 高電平,同時數碼管輸入和6 對應的數據;周而復始重復上述過程,四個數碼管就顯示9876 數字。

1.2 驅動八位數碼管顯示電路框圖

用CPLD 設計一個驅動八位數碼管顯示電路。八位數碼管管腳圖如圖1.2 所示。

用兩個CL5461AS 數碼管接成一個八位數碼管顯示,將兩個CL5461AS 數碼管的a~g 及小數點dp 管腳并聯在一起,兩個CL5461AS 數碼管的陰極A1~A4 定義為Vss0、Vss1、Vss2、Vss3、Vss4、Vss5、Vss6、Vss7。

用CPLD 設計一個驅動八位數碼管顯示電路的框圖如圖1.4 所示。

 


圖1.4 驅動八位數碼管顯示電路框圖

時鐘脈沖計數器的輸出同時作為 3 線—8 線譯碼器、八選一數據選擇器地址碼的輸入。

時鐘脈沖計數器的輸出經過3 線—8 線譯碼器譯碼其輸出信號接到八位數碼管的陰極Vss0、Vss1、Vss2、Vss3、Vss4、Vss5、Vss6、Vss7 端。要顯示的數據信息A~H中哪一個,通過八選一數據選擇器的地址碼來選擇,選擇出的數據信息經七段譯碼器譯碼接數碼管的a~g 管腳。這樣八個數碼管就可以輪流顯示八個數字,如果時鐘脈沖頻率合適,可實現八個數碼管同時被點亮的視覺效果。

1.3 模塊及模塊功能:

1.3.1 時鐘脈沖計數器模塊

時鐘脈沖計數器模塊CN8 如圖1.5 所示。CN8 模塊輸入信號是時鐘脈沖clk,其頻率大于40Hz,每遇到一個時鐘脈沖clk 上升沿,內部累加器便加一,再把累加器所得結果以2進制數的形式輸出。要顯示八位數字,所以用3 位2 進制數作為輸出。輸出信號為cout[0..2]。

 


圖 1.5 時鐘脈沖計數器模塊CN8

library ieee;

use ieee.std_logic_1164.all;

use ieee.std_logic_unsigned.all;

entity cn8 is

port(clk:in std_logic;

cout:out std_logic_vector(2 downto 0));

end cn8;

architecture rtl of cn8 is

signal q: std_logic_vector(2 downto 0);

begin

process(clk)

begin

if (clk'event and clk='1' ) then

if (q=7) then

q<="000";

else

q<=q+1;

end if;

end if;

end process;

cout<=q;

end rtl;

1.3.2 3-8 線譯碼器模塊

3-8 線譯碼器模塊DECODER3_8 如圖1.6 所示。DECODER3_8 模塊的輸入端是A[2..0]接收時鐘脈沖計數器CN8 模塊的輸出信號,經過譯碼后輸出信號Q[7..0]分別接八個數碼管的陰極Vss7、Vss6、Vss5、Vss4、Vss3、Vss2、Vss1、Vss0,使對應的數碼管的陰極為低電平,對應的數碼管被點亮。要顯示八位數字,需要八個輸出端,所以做成3-8 線譯碼器。

 


圖 1.6 3-8 線譯碼器模塊DECODER3_8

library ieee;

use ieee.std_logic_1164.all;

entity decoder3_8 is

port(a:in std_logic_vector(2 downto 0);

q:out std_logic_vector(7 downto 0));

end decoder3_8;

architecture rtl of decoder3_8 is

begin

process(a)

begin

case a is

when "000"=>q<="11111110";

when "001"=>q<="11111101";

when "010"=>q<="11111011";

when "011"=>q<="11110111";

when "100"=>q<="11101111";

when "101"=>q<="11011111";

when "110"=>q<="10111111";

when thers=>q<="01111111";

end case;

end process;

end rtl;

1.3.3 八選一數據選擇模塊

八選一數據選擇模塊 SEL81 如圖1.7 所示。SEL81 模塊輸入信號一個是數據選擇器SEL81的地址碼SEL[2..0],另一部分是數據信息A[3..0] ~H[3..0]。地址碼SEL[2..0]來自時鐘脈沖計數器CN8,由地址碼SEL[2..0]決定輸出哪個輸入數據。輸出信號是Q[3..0]。

 


圖 1.7 八選一數據選擇模塊SEL81

library ieee;

use ieee.std_logic_1164.all;

entity sel81 is

port(sel:in std_logic_vector(2 downto 0);

a,b,c,d,e,f,g,h:in std_logic_vector(3 downto 0);

q:out std_logic_vector(3 downto 0));

end sel81;

architecture rtl of sel81 is

begin

process(a,b,c,d,e,f,g,h,sel)

variable cout: std_logic_vector(3 downto 0);

begin

case (sel) is

when "000"=>cout:=a;

when "001"=>cout:=b;

when "010"=>cout:=c;

when "011"=>cout:=d;

when "100"=>cout:=e;

when "101"=>cout:=f;

when "110"=>cout:=g;

when thers=>cout:=h;

end case;

q<=cout;

end process;

end rtl;

1.3.4 七段譯碼器模塊

七段譯碼器模塊 DISP 如圖1.8 所示。DISP 模塊是七段譯碼器,將輸入的4 位二進制數轉換為數碼顯示管所對應的數字。例如輸入為4 位二進制數0000 的時候,使數碼顯示管顯示0,則要七段譯碼器輸出為0111111,即g 段為0,g 段發光二極管不亮,其他發光二極管被點亮,顯示效果為0。DISP 模塊輸入信號D[3..0]接到八選一數據選擇模塊的輸出信號Q[3..0];七段譯碼器輸出信號Q[6..0]接數碼管的a~g 管腳。

 


圖 1.8 七段譯碼器模塊DISP

library ieee;

use ieee.std_logic_1164.all;

entity disp is

port(d:in std_logic_vector(3 downto 0);

q:out std_logic_vector(6 downto 0));

end disp;

architecture rtl of disp is

begin

process(d)

begin

case d is

when"0000"=>q<="0111111";

when"0001"=>q<="0000110";

when"0010"=>q<="1011011";

when"0011"=>q<="1001111";

when"0100"=>q<="1100110";

when"0101"=>q<="1101101";

when"0110"=>q<="1111101";

when"0111"=>q<="0100111";

when"1000"=>q<="1111111";

when thers=>q<="1101111";

end case;

end process;

end rtl;

1.3.5 驅動八位數碼管顯示的整體電路

將各個模塊連接起來構成整體電路圖如圖 1.9 所示,可以實現用CPLD 設計一個驅動八位數碼管顯示電路的功能。clk 是時鐘脈沖輸入信號,經過時鐘脈沖計數器CN8 模塊,將信號以3 位2 進制數的形式輸出,輸出信號是COUT[2..0]。時鐘脈沖計數器CN8 的輸出同時作為3 線—8 線譯碼器DECODER3_8 和八選一數據選擇器SEL81 地址碼SEL[2..0]的輸入。時鐘脈沖計數器CN8 的輸出經過3 線—8 線譯碼器DECODER3_8 譯碼其輸出信號Vss[7..0]接到八位數碼管的陰極Vss7、Vss6、Vss5、Vss4、Vss3、Vss2、Vss1、Vss0 端,決定點亮哪位數碼管。同時時鐘脈沖計數器CN8 模塊輸出的信號也進入數據選擇器SEL81 地址碼SEL[2..0]的輸入,進行輸出數據的選擇,其輸出是Q[3..0]。八選一數據選擇器SEL81 模塊的輸出是Q[3..0]再經過七段譯碼器DISP 模塊,將其翻譯成可以用數碼顯示管的數據。七段譯碼器DISP 模塊的輸出Q[6..0]分別經300 歐電阻接數碼顯示管的a~g 管腳。八選一數據選擇器模塊的輸入端,可根據具體需要進行設計。

 


圖 1.9 驅動八位數碼管顯示的整體電路

 

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲精品一区二区三区蜜桃久 | 美日韩免费视频| 亚洲一区日韩在线| 亚洲美女黄网| 亚洲精品视频二区| 亚洲黄色成人| 亚洲国产高清在线| 欧美在线国产| 性做久久久久久久久| 亚洲视频播放| 一区二区三区色| 一二三四社区欧美黄| 日韩亚洲欧美综合| 日韩一级片网址| 亚洲最新合集| 国产精品99久久久久久久vr| 一区二区三区|亚洲午夜| 一区二区三区欧美激情| 99国内精品久久| 一区二区三区欧美亚洲| 亚洲深夜福利在线| 亚洲线精品一区二区三区八戒| 一区二区三区国产在线观看| 中日韩午夜理伦电影免费| 在线亚洲伦理| 亚洲已满18点击进入久久| 亚洲欧美国产精品桃花| 午夜视频一区| 久久精品国产在热久久| 亚洲国产精品一区二区www在线| 亚洲国产小视频| 亚洲日本激情| 99riav1国产精品视频| 亚洲婷婷国产精品电影人久久| 亚洲午夜久久久久久久久电影网| 亚洲一区二区在线播放| 亚洲一区精品在线| 午夜国产精品视频| 久久精品中文| 男人天堂欧美日韩| 欧美精品在线一区| 久久精品一区四区| 亚洲区一区二区三区| 99精品国产99久久久久久福利| 亚洲特色特黄| 久久精品二区三区| 欧美国产免费| 国产精品女主播在线观看 | 国产精品免费一区豆花| 国语自产在线不卡| 亚洲国产电影| 中文日韩在线视频| 久久精品女人| 一本久久综合亚洲鲁鲁五月天 | 亚洲欧美视频一区| 久久人人九九| 欧美人妖在线观看| 国产拍揄自揄精品视频麻豆| 在线不卡中文字幕| 亚洲调教视频在线观看| 久久成人综合视频| 正在播放日韩| 久久精品成人欧美大片古装| 欧美大片在线观看一区| 国产精品sm| 在线播放视频一区| 亚洲午夜一区二区| 亚洲人成在线影院| 亚洲欧美一区二区三区久久| 裸体歌舞表演一区二区| 国产精品高潮视频| 在线观看亚洲一区| 亚洲一区二区三区色| 亚洲国产精品久久久久婷婷884| 亚洲视频免费在线观看| 久久亚洲私人国产精品va媚药| 欧美日本国产视频| 国产综合香蕉五月婷在线| 日韩视频一区二区在线观看 | 亚洲国产网站| 欧美制服丝袜第一页| 欧美屁股在线| 激情综合色丁香一区二区| 国产精品99久久久久久久女警 | 一本色道久久综合一区| 欧美私人网站| 精品99一区二区| 亚洲午夜成aⅴ人片| 亚洲精品一区二区三区婷婷月 | 欧美国产1区2区| 国产日产欧美a一级在线| 亚洲毛片在线观看| 久久av一区二区三区亚洲| 亚洲一区二区三区在线看 | 欧美麻豆久久久久久中文| 国产一区二区高清| 亚洲午夜精品17c| 99视频精品在线| 欧美成人日韩| 韩国精品一区二区三区| 亚洲午夜未删减在线观看| 一区二区三区蜜桃网| 欧美va亚洲va香蕉在线| 韩国女主播一区二区三区| 亚洲女人av| 亚洲免费视频一区二区| 欧美日韩1234| 亚洲三级电影全部在线观看高清| 久久精品国产视频| 久久久久久噜噜噜久久久精品| 国产精品人人爽人人做我的可爱| 亚洲欧洲精品一区二区| 亚洲国产一二三| 免费不卡在线观看| 韩国精品一区二区三区| 久久精品91| 欧美在线播放高清精品| 欧美人成在线视频| 亚洲欧洲一区二区三区久久| 亚洲激情视频| 欧美二区在线看| 亚洲高清久久| 亚洲激情在线激情| 欧美 日韩 国产 一区| 精品成人国产| 亚洲黄页视频免费观看| 美女黄色成人网| 伊人成年综合电影网| 亚洲高清成人| 麻豆国产精品777777在线| 激情成人中文字幕| 亚洲激情小视频| 欧美高清视频一区二区| 亚洲激情在线观看| 亚洲精品美女在线观看| 欧美激情亚洲国产| 亚洲精品三级| 亚洲免费视频网站| 国产精品一区一区三区| 亚洲美女黄色片| 欧美亚洲在线| 欧美日韩精品二区| 亚洲第一在线综合网站| 99热这里只有精品8| 狠狠久久亚洲欧美| 99在线|亚洲一区二区| 亚洲午夜电影网| 国产精品综合不卡av| 欧美亚洲一区二区三区| 久久视频在线看| 亚洲激情电影中文字幕| 中国日韩欧美久久久久久久久| 国产精品久久久91| 欧美影院精品一区| 蜜臀久久99精品久久久久久9| 亚洲人成在线播放| 亚洲女优在线| 一区在线视频观看| 一区二区高清视频在线观看| 国产精品美女www爽爽爽视频| 欧美在线免费视频| 欧美高清视频免费观看| 中日韩美女免费视频网站在线观看| 欧美亚洲系列| 亚洲成人在线免费| 亚洲视频导航| 韩国一区电影| 夜夜狂射影院欧美极品| 国产伦精品一区二区三区视频孕妇| 久久国产视频网| 欧美精品三区| 午夜一区二区三区不卡视频| 美女黄色成人网| 亚洲午夜一区二区三区| 久久综合九色99| 一区二区三区四区五区视频| 久久久精品国产一区二区三区 | 亚洲国内欧美| 欧美亚韩一区| 亚洲国产午夜| 国产免费一区二区三区香蕉精| 亚洲国产精品www| 国产精品嫩草久久久久| 亚洲激情影院| 国产乱码精品1区2区3区| 亚洲精品在线电影| 国产一区二区高清| 亚洲一区不卡| 亚洲高清在线观看一区| 性亚洲最疯狂xxxx高清| 亚洲黄网站在线观看| 在线综合亚洲| 亚洲最快最全在线视频| 久久婷婷国产综合尤物精品| 亚洲最新视频在线播放| 欧美69视频| 欧美专区在线观看| 国产精品久久久久久影视 | 亚洲美女黄网| 雨宫琴音一区二区在线|