电子发烧友App

硬声App

0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示
电子发烧友网>电子资料下载>接口技术>4*4矩阵键盘设计及源代码

4*4矩阵键盘设计及源代码

2010-02-08 | rar | 2 | 次下载 | 免费

资料介绍

4*4矩阵键盘设计及源代码

一 实验目的
1 学习使用4X4 扫描键盘的设计方法;
2 实践对比按键抖动对扫描键盘输出的影响
二 实验原理及说明
1、实验原理

信号(KEY)接到高电平,当没有键按时,行线与列线(KEYSCAN)是断开的,且行线都是高电平(1111),行信号作为FPGA的输入端、列信号作为FPGA的输出端。可以设置列线初始状态为低电平(0000)。信号为从上到下的顺序
当有键按下时,假如是K1按下,行信号与列信号接通,这时相应的行线(KEY0)变为低电平(01111),可以肯定第一行(K1,5,9,13)有键按下。
下面就要运用扫描的原理了:
1、因为只知道第一行有键按下,不知道是那个,可以设置列信号为0111,这时行信号变为(1111)(注:假设时钟周期很短,手还没松开,即键还在按下的状态)
2、设置列信号为1011,行信号也变成(1111)
3、设置列信号为1101,行信号也变成(1111)
4、设置列信号为1110,行信号也变成(0111),这时就可以肯定是第一个键按下。
关键的工作只要调整好时钟的频率就可以了。
2、实验说明
4X4扫描键盘只用8位数据线,可以提供16个不同的按键信号。这样做的好处是:1节省FPGA管脚资源;2 系统简单化减小电路规模;特别是在资源比较紧张,对成本要求严格的系统中这是一种非常流行的设计方法。在上面的实验中同学们已经见到了扫描数码显示器的实用性,4X4扫描键盘是输入设备,控制器来要稍微复杂一些。掌握这种程序设计方法在以后的学习工作中还是很有用武之地的。
因为一般的开关在大约20ms内信号不稳定,存在所谓的“开关抖动”,会产生多个脉冲影响电路正常工作。所以含开关输入的设计需要做防抖动处理,在本实验可以用20Hz的时钟采样实现防抖。
在设计程序时要注意时钟的的分配;要考虑一般用手把键按下的时间长度等问题。如果不去抖动可以把时钟加快,使按下键的时间内完成扫描处理。实际中操作与理论分析是有差别的,本实验的目的是要下载成功而不仅是仿真通过。
三 实验步骤
1、准备实验前查阅本实验相关的信息
2、构思程序设计方法
3、编写veilog代码同时做程序注释
4、编译仿真程序,与预想结果进行比较,修改程序
5、下载到实验平台上,观察结果
四 实验要求
1 输入verilog设计文件,编译调试通过
2 利用仿真手段进行测试
3 下载程序到实验板,由扫描数码管led输出按下的键盘码
4 对比抖动的效果
五 扩展性学习
上文已说明开关防抖的必要性,在这种简单的实际应用中做不做防抖处理没有什么区别,但是用按键开关作发送串行数据的开关时就有可能出现问题。所以下文将介绍一种较实用的开关去抖方案,请同学们参考
键一旦被按下,deDitherCounter计数开始。计数5ms(将主时钟分频为小于1ms的时钟)时将键盘编码值(处理前)赋给code,计数到15ms时比较当前的键盘码与10ms前的码是否相同:如果相同,输出keyPressed信号,如果不同不做任何处理,keyPressed信号在1ms后(计数到15)重新拉低。而输出的键盘码code在第5毫秒时就变为有效值,直到下一次按键后的5ms才会重新变为新的值,从而保证在keyPressed信号输出有效时code信号是有效的。
六 管脚映射
原理图见实验原理
管脚映射
扩展信号名称 PIN
Key0 Pin_44
Key1 Pin_43
Key2 Pin_45
Key3 Pin_48
Keyscan0 Pin_47
Keyscan1 Pin_64
Keyscan2 Pin_65

更多矩阵键盘知识请访问http://www.elecfans.com/zhuanti/20111025226587.html


Keyscan3 Pin_50

下载该资料的人也在下载 下载该资料的人还在阅读
更多 >

评论

查看更多

下载排行

本周

  1. 1ATmega8芯片中文手册
  2. 2.45 MB   |  3次下载  |  1 积分
  3. 2电源监控电路UC1544/2544/3544数据表
  4. 2.07MB   |  2次下载  |  免费
  5. 3开关式升压 3A 双节锂电充电管理E6483数据手册
  6. 0.26 MB   |  2次下载  |  免费
  7. 4100V、300mA 恒定导通时间同步降压/Fly-Buck™ 稳压器LM5018数据表
  8. 2.02MB   |  1次下载  |  免费
  9. 5BH6000蓄电池在线监测装置产品及系统介绍
  10. 1.57 MB   |  1次下载  |  免费
  11. 6650V 6A沟槽和场阻IGBT JJT6N65ST数据表
  12. 1.89 MB   |  1次下载  |  1 积分
  13. 7具有过压保护和阻断 FET控制功能的12V电子熔丝TPS25924x数据表
  14. 1.92MB   |  1次下载  |  免费
  15. 8稳压5V、300mA高效电荷泵DC-DC转换器TPS6013x数据表
  16. 1.5MB   |  1次下载  |  免费

本月

  1. 1电子元件基础知识介绍
  2. 8.76 MB   |  73次下载  |  2 积分
  3. 2DC-DC电路(Buck)的设计与仿真
  4. 0.60 MB   |  23次下载  |  2 积分
  5. 3UHD智能显示SoC VS680产品简介
  6. 0.46 MB   |  11次下载  |  免费
  7. 4多功能电源管理 SOC IP5306数据手册
  8. 0.20 MB   |  8次下载  |  免费
  9. 5ES9038PRO解码芯片的电路原理图介绍
  10. 0.25 MB   |  8次下载  |  5 积分
  11. 6东芝BiCD集成电路硅单片TB67S109AFNAG数据手册
  12. 1.93 MB   |  6次下载  |  免费
  13. 716A 输出电流,高可靠、高效率 同步降压转换器PCD3201产品手册
  14. 0.47 MB   |  6次下载  |  免费
  15. 8电池管理系统(BMS)软硬件介绍
  16. 0.23 MB   |  5次下载  |  2 积分

总榜

  1. 1matlab软件下载入口
  2. 未知  |  935085次下载  |  免费
  3. 2开源硬件-PMP21529.1-4 开关降压/升压双向直流/直流转换器 PCB layout 设计
  4. 1.48MB  |  420048次下载  |  免费
  5. 3Altium DXP2002下载入口
  6. 未知  |  233067次下载  |  免费
  7. 4电路仿真软件multisim 10.0免费下载
  8. 340992  |  191315次下载  |  免费
  9. 5十天学会AVR单片机与C语言视频教程 下载
  10. 158M  |  183315次下载  |  免费
  11. 6labview8.5下载
  12. 未知  |  81567次下载  |  免费
  13. 7Keil工具MDK-Arm免费下载
  14. 0.02 MB  |  73786次下载  |  免费
  15. 8NI LabVIEW中实现3D视觉的工具和技术
  16. 未知  |  70088次下载  |  免费