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

相关文章

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

基于51单片机的自动转向修复系统的设计与实现

文章目录 前言资料获取设计介绍功能介绍设计清单具体实现截图参考文献设计获取 前言 💗博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师,一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP430/AVR等单片机设计 主要对象是咱们电子相关专业的大学生,希望您们都共创辉煌!✌💗 👇🏻 精彩专栏 推荐订阅👇🏻 单片机

SprinBoot+Vue网络商城海鲜市场的设计与实现

目录 1 项目介绍2 项目截图3 核心代码3.1 Controller3.2 Service3.3 Dao3.4 application.yml3.5 SpringbootApplication3.5 Vue 4 数据库表设计5 文档参考6 计算机毕设选题推荐7 源码获取 1 项目介绍 博主个人介绍:CSDN认证博客专家,CSDN平台Java领域优质创作者,全网30w+

lvgl8.3.6 控件垂直布局 label控件在image控件的下方显示

在使用 LVGL 8.3.6 创建一个垂直布局,其中 label 控件位于 image 控件下方,你可以使用 lv_obj_set_flex_flow 来设置布局为垂直,并确保 label 控件在 image 控件后添加。这里是如何步骤性地实现它的一个基本示例: 创建父容器:首先创建一个容器对象,该对象将作为布局的基础。设置容器为垂直布局:使用 lv_obj_set_flex_flow 设置容器