VHDL数码管显示控制器设计

2023-12-11 18:15

本文主要是介绍VHDL数码管显示控制器设计,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目要求:
初始状态,开关 K1 为低电平,6 个数码管上依次显示 1-6。当 K1 变为高电平时,数据管显示内容依次循环左移,当 K1 变为低电平时,保持当前显示内容。

参考资料:使用VHDL实现动态扫描八位七段数码管
我参考了他的计时器部分

我的代码:

library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_arith.all;
use ieee.std_logic_unsigned.all;entity Segment isport(key : in std_logic ;					-- point to press ;clk : in std_logic ;					-- the signal from clock ;hex5 : out std_logic_vector(0 to 7) ;hex4 : out std_logic_vector(0 to 7) ;hex3 : out std_logic_vector(0 to 7) ;hex2 : out std_logic_vector(0 to 7) ;hex1 : out std_logic_vector(0 to 7) ;hex0 : out std_logic_vector(0 to 7)	;	-- all of them are digital segmentshex6 : out std_logic_vector(0 to 7) ;hex7 : out std_logic_vector(0 to 7)		
) ;
end Segment ;architecture Display of Segment issignal clk_50MHZ : std_logic ;constant matrix_num : integer := 6 ;TYPE Light is array (0 to matrix_num) of std_logic_vector(0 to 7);signal initial : Light := (('1', '1', '1', '1', '1', '1', '1', '1'),('1', '0', '0', '1', '1', '1', '1', '1'),			-- 1('0', '0', '1', '0', '0', '1', '0', '1'),			-- 2('0', '0', '0', '0', '1', '1', '0', '1'),			-- 3('1', '0', '0', '1', '1', '0', '0', '1'),			-- 4('0', '1', '0', '0', '1', '0', '0', '1'),			-- 5('0', '1', '0', '0', '0', '0', '0', '1')				-- 6) ;signal temporary : Light := (('1', '1', '1', '1', '1', '1', '1', '1'),('1', '0', '0', '1', '1', '1', '1', '1'),			-- 1('0', '0', '1', '0', '0', '1', '0', '1'),			-- 2('0', '0', '0', '0', '1', '1', '0', '1'),			-- 3('1', '0', '0', '1', '1', '0', '0', '1'),			-- 4('0', '1', '0', '0', '1', '0', '0', '1'),			-- 5('0', '1', '0', '0', '0', '0', '0', '1')				-- 6) ;
beginprocess(clk)							-- this process is a timer ;variable count : integer := 0 ;beginif (clk'event and clk = '1') thenif (count = 50000000) thenclk_50MHZ <= '1' ;count := 0 ;elseclk_50MHZ <= '0' ;count := count + 1 ;end if ;end if ;end process ;process(key, clk_50MHZ)variable i : integer := 0 ;beginhex6 <= ('1', '1', '1', '1', '1', '1', '1', '1') ;		-- I don't want them to be lighthex7 <= ('1', '1', '1', '1', '1', '1', '1', '1') ;if (key = '1' and rising_edge(clk_50MHZ)) theni := (i+1) MOD 6 ;if (i = 0) thentemporary(1) <= initial(1) ;temporary(2) <= initial(2) ;temporary(3) <= initial(3) ;temporary(4) <= initial(4) ;temporary(5) <= initial(5) ;temporary(6) <= initial(6) ;elsif (i = 1) thentemporary(1) <= initial(2) ;temporary(2) <= initial(3) ;temporary(3) <= initial(4) ;temporary(4) <= initial(5) ;temporary(5) <= initial(6) ;temporary(6) <= initial(1) ;elsif (i = 2) thentemporary(1) <= initial(3) ;temporary(2) <= initial(4) ;temporary(3) <= initial(5) ;temporary(4) <= initial(6) ;temporary(5) <= initial(1) ;temporary(6) <= initial(2) ;elsif (i = 3) thentemporary(1) <= initial(4) ;temporary(2) <= initial(5) ;temporary(3) <= initial(6) ;temporary(4) <= initial(1) ;temporary(5) <= initial(2) ;temporary(6) <= initial(3) ;elsif (i = 4) thentemporary(1) <= initial(5) ;temporary(2) <= initial(6) ;temporary(3) <= initial(1) ;temporary(4) <= initial(2) ;temporary(5) <= initial(3) ;temporary(6) <= initial(4) ;elsif (i = 5) thentemporary(1) <= initial(6) ;temporary(2) <= initial(1) ;temporary(3) <= initial(2) ;temporary(4) <= initial(3) ;temporary(5) <= initial(4) ;temporary(6) <= initial(5) ;end if ;end if ;hex5 <= temporary(1) ;hex4 <= temporary(2) ;hex3 <= temporary(3) ;hex2 <= temporary(4) ;hex1 <= temporary(5) ;hex0 <= temporary(6) ;end process ;
end Display ;

在这里还是要解释一下:
在实体部分中,clk所对应的时钟信号为50MHZ;
第一个process是计时器
数码管显示的状态有6种,我用0-5表示:
123456、234561、345612、456123、561234、612345
第二个process中,整型变量i的值就表示数码管该显示上面6种情况中的哪一种。

这篇关于VHDL数码管显示控制器设计的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/481630

相关文章

Linux虚拟机不显示IP地址的解决方法(亲测有效)

《Linux虚拟机不显示IP地址的解决方法(亲测有效)》本文主要介绍了通过VMware新装的Linux系统没有IP地址的解决方法,主要步骤包括:关闭虚拟机、打开VM虚拟网络编辑器、还原VMnet8或修... 目录前言步骤0.问题情况1.关闭虚拟机2.China编程打开VM虚拟网络编辑器3.1 方法一:点击还原VM

CSS模拟 html 的 title 属性(鼠标悬浮显示提示文字效果)

《CSS模拟html的title属性(鼠标悬浮显示提示文字效果)》:本文主要介绍了如何使用CSS模拟HTML的title属性,通过鼠标悬浮显示提示文字效果,通过设置`.tipBox`和`.tipBox.tipContent`的样式,实现了提示内容的隐藏和显示,详细内容请阅读本文,希望能对你有所帮助... 效

如何设置vim永久显示行号

《如何设置vim永久显示行号》在Linux环境下,vim默认不显示行号,这在程序编译出错时定位错误语句非常不便,通过修改vim配置文件vimrc,可以在每次打开vim时永久显示行号... 目录设置vim永久显示行号1.临时显示行号2.永www.chinasem.cn久显示行号总结设置vim永久显示行号在li

Python中的可视化设计与UI界面实现

《Python中的可视化设计与UI界面实现》本文介绍了如何使用Python创建用户界面(UI),包括使用Tkinter、PyQt、Kivy等库进行基本窗口、动态图表和动画效果的实现,通过示例代码,展示... 目录从像素到界面:python带你玩转UI设计示例:使用Tkinter创建一个简单的窗口绘图魔法:用

电脑显示hdmi无信号怎么办? 电脑显示器无信号的终极解决指南

《电脑显示hdmi无信号怎么办?电脑显示器无信号的终极解决指南》HDMI无信号的问题却让人头疼不已,遇到这种情况该怎么办?针对这种情况,我们可以采取一系列步骤来逐一排查并解决问题,以下是详细的方法... 无论你是试图为笔记本电脑设置多个显示器还是使用外部显示器,都可能会弹出“无HDMI信号”错误。此消息可能

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

第10章 中断和动态时钟显示

第10章 中断和动态时钟显示 从本章开始,按照书籍的划分,第10章开始就进入保护模式(Protected Mode)部分了,感觉从这里开始难度突然就增加了。 书中介绍了为什么有中断(Interrupt)的设计,中断的几种方式:外部硬件中断、内部中断和软中断。通过中断做了一个会走的时钟和屏幕上输入字符的程序。 我自己理解中断的一些作用: 为了更好的利用处理器的性能。协同快速和慢速设备一起工作

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

怎么让1台电脑共享给7人同时流畅设计

在当今的创意设计与数字内容生产领域,图形工作站以其强大的计算能力、专业的图形处理能力和稳定的系统性能,成为了众多设计师、动画师、视频编辑师等创意工作者的必备工具。 设计团队面临资源有限,比如只有一台高性能电脑时,如何高效地让七人同时流畅地进行设计工作,便成为了一个亟待解决的问题。 一、硬件升级与配置 1.高性能处理器(CPU):选择多核、高线程的处理器,例如Intel的至强系列或AMD的Ry