【Quartus 13.0】EP1C3144I7 部署4*6矩阵键盘

仿照 正点原子 的 Sample 修改
V2手册 P266
没有用这个

给出的手动按键控制的矩阵模块 为 4*6 矩阵键盘外接模块
每一个按键自带led,所以对应的接口是合并在一起的一个引脚
按下后 LED 亮,vice versa

底部 LED*8 目前不清楚有什么用
或许可以变成 16进制表示灯的位置
like 3 = 2^1 + 2^0, 16 = 2^4 相当于数码管的功能

代码参考

testbench 需要生成 vt 文件 再使用仿真验证
我抛出来的波形有点奇怪 因为没有做时序约束
在这里插入图片描述

按键定位思路:

  1. 矩阵键盘所有 行 信号 3.3V 上拉,4*6 信号全部接到 FPGA 引脚, 具体按键的检测只需要扫描其 行列 序号,
  2. 给出的分布引脚图中,矩阵信号从左到右也可以算是顺序编码:A1 B1 C1 D1,A2 B2 C2 D2…D6.etc
  3. 具体按钮x对应的 a 行 b 列 引脚,已知 a 行 & all rows 为高电平,设置 all cols 为低电平
  4. 当 x being pushed, a & b 导通,a变为低电平, 得到 row 端口;
  5. due to cols’ outputs are all in low level, scan col 端口,先scan 第一列( col0 ) , 将 col0 保持低电平, col1~3 拉高,看row端口值是否变化, if not, button 列序列号 为 1,else not. only & only if col端口为low时才能拉低其对应row 端口为低电平,else 继续扫描 next col,col2 = 0

代码描述:

module key4x4
//更改为4x6
#(parameter   CNT_MAX=16'd50_000
)
(input    wire           sys_clk     ,input    wire           sys_rst_n   ,input    wire    [6:0]  key_in      ,//此信号为从键盘传到FPGA开发板的信号output   reg     [6:0]  key_out     ,//此信号为从FPGA开发板传到键盘上的信号output   reg     [6:0]  led_out      //注意信号灯为低信号时会亮
);reg     [23:0]      cnt         ;
reg                 cnt_clk     ;
reg     [1:0]       q           ;always @ (posedge sys_clk or negedge sys_rst_n)if(sys_rst_n==1'b0)cnt<=24'd0;else if (cnt==CNT_MAX)cnt<=24'd0;else  cnt<=cnt+24'd1;always @ (posedge sys_clk or negedge sys_rst_n)if(sys_rst_n==1'b0)cnt_clk<=1'b0;else if (cnt==CNT_MAX-24'd1)cnt_clk<=1'b1;else  cnt_clk<=1'd0;always @ (posedge cnt_clk or negedge sys_rst_n)if(sys_rst_n==1'b0)beginq<=3'd0;key_out<=6'b111110;led_out<=6'b111111;endelsebeginq<=q+3'd1;case(q)//分别对每一行row输入扫描信号3'd0:key_out<=6'b111110;3'd1:key_out<=6'b111101;3'd2:key_out<=6'b111011;3'd3:key_out<=6'b110111;3'd4:key_out<=6'b101111;3'd5:key_out<=6'b011111;default:key_out<=6'b000000;endcasecase ({key_out,key_in})
//    //按下第1个按键后则全灭,000000 -> 111111,按下第24个按键后全部的灯亮,111111 -> 000000。
//    //每一行扫描信号,对应的扫描信号灯输出//4'b1111......这些还没有修改 应该改为按键旁边对应的led灯10'b111110_1110:begin led_out<=4'b1111;  end10'b111110_1101:begin led_out<=4'b1110;  end10'b111110_1011:begin led_out<=4'b1101;  end10'b111110_0111:begin led_out<=4'b1100;  end10'b111101_1110:begin led_out<=4'b1011;  end10'b111101_1101:begin led_out<=4'b1010;  end10'b111101_1011:begin led_out<=4'b1001;  end10'b111101_0111:begin led_out<=4'b1000;  end10'b111011_1110:begin led_out<=4'b0111;  end10'b111011_1101:begin led_out<=4'b0110;  end10'b111011_1011:begin led_out<=4'b0101;  end10'b111011_0111:begin led_out<=4'b0100;  end10'b110111_1110:begin led_out<=4'b0011;  end10'b110111_1101:begin led_out<=4'b0010;  end10'b110111_1011:begin led_out<=4'b0001;  end10'b110111_0111:begin led_out<=4'b0000;  end10'b110111_1110:begin led_out<=4'b0011;  end10'b110111_1101:begin led_out<=4'b0010;  end10'b110111_1011:begin led_out<=4'b0001;  end10'b110111_0111:begin led_out<=4'b0000;  end10'b110111_1110:begin led_out<=4'b0011;  end10'b110111_1101:begin led_out<=4'b0010;  end10'b110111_1011:begin led_out<=4'b0001;  end10'b110111_0111:begin led_out<=4'b0000;  end10'b000000_1111:begin led_out<=4'b1111;  enddefault:     begin led_out<=4'b1111;  endendcaseendendmodule

消抖模块思路:
“按键的值先打一拍(key_reg <=key row),然后检测当前时钟下按键的状态和上一个时钟的状态是否一致,如果不一致则将计数器 delay cnt赋初值 100万,如果一致则计数器从初值开始作减法计数,直到计数器计数到“1”,说明按键的状态一直稳定了 100 万个时钟周期,此时我们认为是一次有效的按键 触发,这时我们就可以拉高消抖完成标志key flag row(注意只拉高一个时钟)”

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/29146.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

外链跳转到小程序原生的企业客服

备注&#xff1a; 在外链中&#xff0c;不能直接调起小程序原生客服&#xff08;wx.openCustomerServiceChat&#xff09;。 解决方法&#xff1a; 小程序里新增一个原生的过渡页面。外链跳转到过渡页面&#xff0c;在过渡页面添加点击事件&#xff0c;打开原生客服 在外链中…

Swift Combine — Publisher、Operator、Subscriber概念介绍

Combine框架介绍 Combine框架提供了一个声明式Swift API&#xff0c;用于处理随时间变化的值。这些值可以表示多种异步事件。Combine声明发布者公开发布可能随时间变化的值&#xff0c;并声明订阅者从发布者接收这些值。 Combine框架为应用程序如何处理事件提供了一种声明式的…

《Cloud Native Data Center Networking》(云原生数据中心网络设计)读书笔记 -- 02 Clos拓扑

本章回答以下问题&#xff1a; 什么是 Clos 拓扑&#xff0c;它与“接入 - 汇聚 - 核心”拓扑有何不同?Clos 拓扑的特征是什么?Clos 拓扑对数据中心网络的影响是什么? Clos拓扑 云原生数据中心基础设施的先行者们想要构建一种支持大规模水平扩展网络。 基本的Clos拓扑如图…

检查HIVE分区是否连续

检查HIVE分区是否连续 场景描述分区连续性检查语句 我们经常可能会有这样的诉求&#xff0c;需要对一张目标表进行分区检查&#xff0c;查看是否存在不连续的情况&#xff0c;该诉求频繁且重要&#xff0c;因此以下语句可以实现我们的诉求 场景描述 我们有一张表&#xff0c;…

精准营销是一种利用大数据和人工智能技术来定位目标客户的方法

精准营销是一种利用大数据和人工智能技术来定位目标客户的方法。下面是涉及到的用户类型和业务流程,以及开发难度评估: 用户类型: 活跃用户:经常使用产品或服务的用户。潜在用户:尚未使用产品或服务,但可能对其感兴趣的用户。流失用户:曾经使用过产品或服务,但已经停止使用或…

在Gradle中优雅地统一管理依赖

前言 不知大家在使用 Gradle 的时候是如何统一管理整个项目所需依赖的版本呢&#xff1f;尤其是在有多个模块的情况下。 曾经我写过 一篇文章 来介绍如何在 buildSrc 中使用常量来管理版本&#xff0c;但是实际上那种做法并不怎么优雅&#xff0c;甚至有些邪道。 当然&#…

记录一下 Chrome浏览器打印时崩溃问题

问题描述&#xff1a; 为了查看页面内存占用情况&#xff0c;按F2,打开Memory chrome浏览器点击“打印”按钮&#xff0c;或Ctrl P 时出现如下页面 一直以为是页面问题&#xff0c;每次打印的时候遇到这种 崩溃现象 就是重新刷新页面 但今天刚开一个页面&#xff0c;内存 …

【2024最新精简版】RabbitMQ面试篇

文章目录 Kafka和RabbitMQ什么区别惰性队列&#xff08;Lazy Queues&#xff09;是怎么实现的&#xff1f;RabbitMQ工作模式有哪些 ?你们项目中哪里用到了RabbitMQ ?为什么会选择使用RabbitMQ ? 有什么好处 ?使用RabbitMQ如何保证消息不丢失 ?消息的重复消费问题如何解决的…

Unity中使用UI组件实现场景切换——6.18山大软院项目实训

设置场景切换 在Unity项目中&#xff0c;首先需要准备几个场景&#xff0c;并在项目的“Build Settings”中添加这些场景&#xff0c;以确保SceneManager可以加载它们。本例中&#xff0c;我们假设已有几个场景编号依次为1到5。 脚本概述 我们创建了一个SwitchScene类&#…

在IDEA 2024.1.3 (Community Edition)中创建Maven项目

本篇博客承继自博客Windows系统Maven下载安装-CSDN博客 Maven版本&#xff1a;maven-3.9.5 修改设置&#xff1a; 首先先对Idea的Maven依赖进行设置&#xff1b;打开Idea&#xff0c;选择“Costomize”&#xff0c;选择最下边的"All settings" 之后找到Maven选项&…

利用LabVIEW项目管理和组织LabVIEW应用程序

如何利用LabVIEW项目管理和组织LabVIEW应用程序&#xff0c;提供了关于文件定义、磁盘上的文件组织、LabVIEW项目浏览器、交叉链接和相关资源的建议。这些推荐在开发前就应建立&#xff0c;以确保应用程序能扩展到大量VIs并适应多开发者环境。 目录 定义和识别应用程序文件 磁…

黑龙江等保测评与企业安全:携手共筑数字时代坚固防线

在数字化转型的浪潮中&#xff0c;黑龙江的企业正以前所未有的速度拥抱新技术&#xff0c;推动业务创新与增长。然而&#xff0c;随着信息技术的深入应用&#xff0c;网络安全风险也随之增加&#xff0c;尤其是对个人信息与敏感数据的保护成为企业不容忽视的重大课题。信息安全…

【运维项目经历|032】Hadoop大数据处理与分析平台构建项目

🍁博主简介: 🏅云计算领域优质创作者 🏅2022年CSDN新星计划python赛道第一名 🏅2022年CSDN原力计划优质作者 🏅阿里云ACE认证高级工程师 🏅阿里云开发者社区专家博主 💊交流社区:CSDN云计算交流社区欢迎您的加入! 目…

List, Set, Map, Queue介绍

Java集合框架是一组接口和实现这些接口的类的集合&#xff0c;它提供了对数据集合的高效率存储和操作。以下是Java集合框架中一些核心接口的介绍&#xff1a; 1.List&#xff1a; List是一个有序的集合&#xff0c;允许包含重复的元素。它提供了按插入顺序访问元素的方法&…

leetcode56 合并区间

题目 以数组 intervals 表示若干个区间的集合&#xff0c;其中单个区间为 intervals[i] [starti, endi] 。请你合并所有重叠的区间&#xff0c;并返回 一个不重叠的区间数组&#xff0c;该数组需恰好覆盖输入中的所有区间 。 示例 输入&#xff1a;intervals [[1,3],[2,6]…

6、 垃圾回收 浏览器事件循环

垃圾回收 & 浏览器事件循环 垃圾回收引用计数算法标记清除&#xff08;mark-sweep&#xff09;算法标记整理&#xff08;Mark-Compact&#xff09;算法 内存管理浏览器事件循环宏任务微任务整体流程 垃圾回收 垃圾回收&#xff0c;又称为&#xff1a;GC&#xff08;garbag…

华火新能源集成灶评测:创新与品质的融合

在厨房电器的不断推陈出新中&#xff0c;华火新能源集成灶以其独特的魅力进入了人们的视野。今天&#xff0c;我们就来深入评测这款备受关注的产品——华火新能源集成灶 一、华火新能源集成灶的创新与环保 首先&#xff0c;我们先来探讨新能源集成灶的整体表现。华火新能源集成…

【面试干货】Hashtable 与 HashMap 的区别

【面试干货】Hashtable 与 HashMap 的区别 1、线程安全性2、对null值的处理3、遍历方式4、遍历示例5、总结 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&#x1f496; 在Java中&#xff0c;Hashtable和HashMap都是基于哈希表实现的Map接口。然而&#…

ERP、CRM、SRM、PLM、HRM、OA……都是啥意思?

经常会听说一些奇怪的系统或平台名称&#xff0c;例如ERP、CRM、SRM、PLM、HRM、OA等。 这些系统&#xff0c;都是干啥用的&#xff1f; █ ERP&#xff08;企业资源计划&#xff09; 英文全称&#xff1a;Enterprise Resource Planning 定义&#xff1a;由美国Gartner Gro…

网络安全复习笔记

概述 要素 CIA&#xff1a;可用性&#xff1b;完整性&#xff1b;保密性。 可控性&#xff1b;不可否认性&#xff1b;可审查性。 攻击 被动&#xff1a;窃听 - 保密性&#xff1b;监听 - 保密性主动&#xff1a;假冒 - 完整性&#xff1b;重放 - 完整性&#xff1b;改写 -…