当前位置: 首页 > news >正文

深圳地址大全台州seo排名外包

深圳地址大全,台州seo排名外包,专业网站建设联系电话,海外seo是什么矩阵键盘介绍: 矩阵键盘是使用8个io口来进行16个按键的控制读取,用4条I/O线作为行线,4条I/O线作为列线组成的键盘。在行线和列线的每个交叉点上,设置一个按键。 如图所示: 矩阵键盘扫描的方式有两种: 1.行…

矩阵键盘介绍:

矩阵键盘是使用8个io口来进行16个按键的控制读取,用4条I/O线作为行线,4条I/O线作为列线组成的键盘。在行线和列线的每个交叉点上,设置一个按键。
如图所示:

矩阵键盘扫描的方式有两种: 1.行列扫描2.逐行/逐列扫描

行列扫描:

将P口的高四位(代表四个行)设置为高电平,将P口的低四位(代表四个列)设置为输入口;行扫描,等待按键被按下,读取P1口的低四位,检查哪一位从低电平变为高电平。列扫描:将P口的高四位(四个行)设置为低电平,将P口的低四位(四个列)设置为高电平。读取P口的低四位,检查哪一位从高电平变为低电平。将两次读取结果组合起来就可以得到当前按键的特征编码。

逐行/逐列扫描:

是给某一行/某一列,高电平,其余七个全部为底电平,这时候读取电平变换,有电平变高表示按键按下,结合给出的行列关系,即可读取按键数据。

实验目的:设计一个可以读取按键按下数据的矩阵键盘

(本实验用的是逐行/逐列扫描方式)

模块框图:

key4x4模块代码

module key4x4
(input wire clk_50Mhz          ,    //系统时钟50Mhzinput wire rst_n              ,    //全局复位input wire [3:0]data_in       ,    //输入逐行扫描信号output reg flag_data          ,    //flag_data为1时表示消抖后检测到按键被按下,维持一个时钟的高电平output reg [3:0]data          ,    //输出按键的特征编码output reg [3:0]data_out           //输出逐列扫描信号);//SUM_MAX> SUM_KEY_20MS               
parameter SUM_MAX =21'd1_999_999;            
parameter SUM_KEY_20MS =22'd999_999;      reg [20:0] num;
reg [19:0] num_10ms;reg [1:0] qs;//每隔40ms产生一次内部触发信号
always@(  posedge  clk_50Mhz or negedge rst_n) begin if (rst_n==1'b0) beginnum <= 22'd0;endelse if (num == SUM_MAX) beginnum <= 22'd0;endelse beginnum <= num +22'd1;end
end //产生逐列扫描信号
always@(  posedge  clk_50Mhz or negedge rst_n) begin if (rst_n==1'b0) beginqs <=2'd0; end      else if(num_10ms == SUM_KEY_20MS) beginqs <= qs ;end     else if(num == SUM_MAX) beginqs <= qs +2'd1;end       
end //输出逐列扫描信号
always @(posedge clk_50Mhz or negedge rst_n) begin  if(rst_n ==1'b0) begindata_out<= 4'b1111;endelse begincase (qs)2'b00:data_out<= 4'b0001; 2'b01:data_out<= 4'b0010; 2'b10:data_out<= 4'b0100; 2'b11:data_out<= 4'b1000; default:data_out<= 4'b1111;        endcase          end 
end//得到当前按键的特征编码    
always @(posedge clk_50Mhz or negedge rst_n) begin   if(rst_n==1'b0)begindata <=4'b0000;endelse begincase ({data_out,data_in})         8'b0001_0001 :          data <=4'b0000; //08'b0001_0010 :          data <=4'b0001; //18'b0001_0100 :          data <=4'b0010; //28'b0001_1000 :          data <=4'b0011; //38'b0010_0001 :          data <=4'b0100; //4                    8'b0010_0010 :          data <=4'b0101; //58'b0010_0100 :          data <=4'b0110; //68'b0010_1000 :          data <=4'b0111; //78'b0100_0001 :          data <=4'b1000; //88'b0100_0010 :          data <=4'b1001; //98'b0100_0100 :          data <=4'b1010; //108'b0100_1000 :          data <=4'b1011; //118'b1000_0001 :          data <=4'b1100; //128'b1000_0010 :          data <=4'b1101; //138'b1000_0100 :          data <=4'b1110; //148'b1000_1000 :          data <=4'b1111; //15default: data <= data; endcase     end
end  //消抖部分
always@(  posedge  clk_50Mhz or negedge rst_n) begin if (rst_n==1'b0) beginnum_10ms <=22'd0;end   else if (data_in== 4'b0000) beginnum_10ms <=22'd0;end   else if ((num_10ms == SUM_KEY_20MS)&&(data_in !=4'b0000)) beginnum_10ms <= num_10ms;endelse beginnum_10ms <= num_10ms+22'd1;end
end//flag_data,产生一个时钟的高电平
always@(  posedge  clk_50Mhz or negedge rst_n) begin if (rst_n==1'b0) beginflag_data <=1'd0;end   else if (num_10ms == SUM_KEY_20MS-1) beginflag_data <=1'd1;endelse beginflag_data <=1'd0; end
end 
endmodule

http://www.yayakq.cn/news/866251/

相关文章:

  • 西安制作网站公司哪家好潍坊专业果蔬清洗机
  • 买了一个域名怎么做网站微信wordpress小工具
  • 陕西住房和城乡建设厅网站电话html个人网站制作
  • 泰安网站建设个人工作室4网站免费建站
  • 用dw做的网站怎么发布到网上网站建设哪些字体没有版权
  • 浙江省住房和城乡建设厅网官方网站同城网站开发
  • 做网站记者的出路是什么网页版式设计案例
  • 公司网站开发费分录是世界球队实力排名
  • 原墨网站建设大连工程局
  • 网站建设费的账务处理网站项目计划书
  • 西安网站制作顶尖公营口建设工程质量监督站网站
  • 微网站与手机网站的区别校园论坛网站源码
  • 注册城乡规划师网站seo优化免
  • 网站建设改代码改哪些网站域名可以更改吗
  • 广州网站开发哪家强wordpress移动端底部广告
  • 中企做的网站太原哪个网站可以免费做国外
  • 建设网站必备的开发工具wordpress首页404伪静态
  • seo网站快排网站名称与备案名称不一致
  • 个人网站建设素材安徽网站排名优化公司
  • 网站开发工程师和前端原创代写文章平台
  • 在深圳市做一个网站多少钱建立第一个网站
  • 响应式网站建设对企业营销优化网站怎么做
  • 做网站图片多少钱企业网站建设方案撰写
  • 机械设备 东莞网站建设公司注册资金查询
  • 深圳网站关键词优化排名网站建设文化策划
  • 二级域名网站免费申请wordpress 买主题
  • 怎样用微信做购物网站口碑好网站建设报价
  • 齐河网站建设电话企业网站主页设计
  • 外国人在中国做视频网站网站建设和网络推广是干嘛
  • 可以做哪些有趣的网站首页模板