网站大量收购独家精品文档,联系QQ:2885784924

嵌入式键盘驱动课件.pptVIP

  1. 1、本文档共22页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
矩阵式键盘原理 矩阵式键盘一般适用于按键数量较多的场合,它由行线和列线组成,按键位于行、列的交叉点上。 如图所示,一个4×4的行、列结构可以构成一个有16个按键的键盘。 矩阵式键盘原理 按键设置在行、列交叉点上,行、列分别连接到按键开关的两端。行线通过上拉电阻接到十5 V上。 平时无按键动作时,行线处于高电平状态;而当有健按下时,行线电平状态将由通过此按键的列线电平决定:列线电平如果为低,行线电平为低;列线电平如果为高,则行线电平亦为高。这一点是识别矩阵式键盘是否被按下的关键所在。 矩阵式键盘原理 矩阵键盘按键的识别方法分两步进行: ①识别键盘哪一行的键被按下。让所有列线均为低电平,检查各行线电平是否为低。如果有行线为低,则说明该行有键被按下,否则说明无键被按下。 ②如果某行有键被按下,识别键盘哪一列的键被按下(亦称之为扫描法)。逐列置低电平,并置其余各列为高电平.检查各行线电平的变化。如果行电平变为低电平,则可确定此行此列交叉点处按键被按下。 S3C2410 的I/O 介绍 S3C2410 有117 个复用功能输入输出端口引脚,这些引脚是: PortA(GPA):32 个输入/输出端口 PortB(GPB):11 个输入/输出端口 PortC(GPC):16 个输入/输出端口 PortD(GPD):16 个输入/输出端口 PortE(GPE):16 个输入/输出端口 PortF(GPF):8 个输入/输出端口 PortG(GPG):16 个输入/输出端口 PortH(GPH):11 个输入/输出端口 S3C2410 的I/O 介绍 端口控制说明 端口配置寄存器(GPACON――GPHCON) 大部分的引脚是复用的,所以必须对于每个引脚要求定义一个功能,端口配置寄存器定义了每个引脚的功能。 端口数据寄存器(GPADAT――GPHDAT) 如果端口配置成输出端口,数据能够被写到端口数据寄存器的对应位,然后通过管脚输出。如果端口配置成输入端口,能从端口数据寄存器对应的位中读出管脚上的电平 端口上拉寄存器(GPBUP――GPHUP) 端口上拉寄存器控制着每个端口组的上拉寄存器的使能或禁止,当对应位为0,这个引脚的上拉寄存器是允许的,当为1 时,上拉寄存器是禁止的。 MIZI提供的S3C2410.H 使用一个32位的数来表示端口的使用情况。 模式 |上拉 |端口 | 端口引脚 MODE | PULLUP | PORT | OFS 不需要自己手动组合,通过宏定义以及SHIFT和MASK组合。见程序 MIZI提供的S3C2410.H 端口的表示 #define PORTA_OFS 0 #define PORTB_OFS 1 #define PORTC_OFS 2 #define PORTD_OFS 3 #define PORTE_OFS 4 #define PORTF_OFS 5 #define PORTG_OFS 6 #define PORTH_OFS 7 MIZI提供的S3C2410.H 端口引脚的表示 #define GPIO_A0 MAKE_GPIO_NUM(PORTA_OFS, 0) #define GPIO_A1 MAKE_GPIO_NUM(PORTA_OFS, 1) #define GPIO_A2 MAKE_GPIO_NUM(PORTA_OFS, 2) #define GPIO_A3 MAKE_GPIO_NUM(PORTA_OFS, 3) 。。。 #define MAKE_GPIO_NUM(p, o) ((p GPIO_PORT_SHIFTT) | (o GPIO_OFS_SHIFT)) MIZI提供的S3C2410.H set_gpio_ctrl(x)???? 功能:配置端口引脚的功能,设置IO口控制寄存器和上拉寄存器 用法:set_gpio_ctrl(模式|上拉?|IO脚) 模式|是否上拉|IO脚,在S3C2410.h中都有其定义好的名字。 set_gpio_ctrl(GPIO_E11 | GPIO_PULLUP_DIS |GPIO_MODE_OUT); MIZI提供的S3C2410.H write_gpio_bit(x, v) 功能:把端口 对应的端口数据寄存器x位设置为v write_gpio_bit(GPIO_E11, 0); read_gpio_bit(x)???? 功能:把端口数据寄存器x位的状态 读入,函数返回值既是其状态 read_gpio_bit(GPIO_G11); MIZI提供的S3C2410.H write_gpio_reg(x, v) 功能:把端口数据寄存器x 设置为v read_gpio_reg(x)????

文档评论(0)

qujim + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档