process(clk2)--数码管动态显示的程序
variable countx: integer range 0 to1024 :=0--计数值,用于添加闪烁
variable count0: integer range 0 to10 :=0--数码管显示个位数
variable count1: integer range 0 to10 :=0--数码管显示十位数
variable play: integer range 0 to 9:=0
variable countplay: integer range 0to 50 :=0
variable countplay1: integer range 0to 3 :=0
variable flash:integer range 0 to15:=0
begin
if(clk2' event and clk2= '1') then
countx := countx + 1
countplay := countplay + 1
if(countx = 1024) then
countx := 0
end if
if (T>=50) then --判断十位数的大小
count1:=5
elsif (T>=40) then
count1:=4
elsif (T>=30) then
count1:=3
elsif (T>=20) then
count1:=2
elsif (T>=10) then
count1:=1
else
count1:=0
end if
count0:=T-10*count1
if(countplay = 5) then
countplay := 0
countplay1 := countplay1 + 1
if(countplay1 = 3) then
countplay1 := 0
end if
end if
if (stop='1'and countx<=200 )then --闪烁信号所加的位置
wx<="11111111"
else
if(countplay1 = 0) then wx <="11111110"play:= count0--位选信号
end if
if (countplay1 = 1) then wx <="11111101"play:= count1
end if
end if
case play is--数码管段选信号
when 0 =>dx <="11000000"
when 1 =>dx <="11111001"
when 2 =>dx <="10100100"
when 3 =>dx <="10110000"
when 4 =>dx <= "10011001"
when 5 =>dx<="10010010"
when 6 =>dx <="10000010"
when 7 =>dx <="11111000"
when 8 =>dx <="10000000"
when 9 =>dx <="10010000"
--when others =>Y <="00000000"
end case
end if
end process
(这个程序里面一个闪烁的信号,你没用的话可以直接去掉,不影响其他部分)
你可以把4对分成两组,当按键按一下,就换一组显示,或者两个按键控制,按下哪个按键就显示哪个,,,给你一个特例程序分别是以上两种方法 的,你可以参考参考,,,port(input1,input2:in std_logic_vector(7 downto 0);--两组数据
key:in std_logic;--按键(应该是消抖后的)
output:out std_logic);
end entity;
architecture art of ... is
begin
process(input1,input2,key)
variable cnt:std_logic;;
begin
if key'event and key='1' then ---假设按键是高电平有效;
cnt:=not cnt;
if cnt='0' then
output<=input1;
else output<=input2;
end if;
end if;。
library ieeeuse ieee.std_logic_1164.all
use ieee.std_logic_unsigned.all
entity yima is
port(kin3,kin2,kin1,kin0,clk:in std_logic
sel2,sel1,sel0:in std_logic
q:out std_logic_vector(6 downto 0))
end yima
architecture a of yima is
signal a:std_logic_vector(3 downto 0)
signal b:std_logic_vector(2 downto 0)
signal p:std_logic_vector(6 downto 0)
signal m:std_logic_vector(6 downto 0)
begin
process(clk)
begin
if clk'event and clk='1'then
a<=kin3&kin2&kin1&kin0
b<=sel2&sel1&sel0
m<=b&a
case m is
when "0001110" =>p<="1111110"-----0 键显示 0
when "0011110" =>p<="0110000"-----1 键显示 1
when "0101110" =>p<="1101101"-----2 键显示 2
when "0111110" =>p<="1111001"-----3 键显示 3
when "1101110" =>p<="0110011"-----4 键显示 4
when "1111110" =>p<="1011011"-----5 键显示 5
when "0001101" =>p<="1011111"-----6 键显示 6
when "0011101" =>p<="1110000"-----7 键显示 7
when "1001101" =>p<="1111110"-----8 键显示 0
when "1011101" =>p<="0110000"-----9 键显示 1
when "1101101" =>p<="1101101"-----A 键显示 2
when "1111101" =>p<="1111001"-----B 键显示 3
when "0101011" =>p<="0110011"-----C 键显示 4
when "0111011" =>p<="1011011"-----D 键显示 5
when "1001011" =>p<="1011111"-----E 键显示 6
when "1011011" =>p<="1110000"-----F 键显示 7
when "0000111" =>p<="0000000"
when others =>p<=p
end case
end if
q<=p
end process
end a
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)