触摸按键控制LED

  1. 触摸按键: 电阻式,电容式(主流),红外感应式,表面声波式
  2. 代码
    input: sys_clk, sys_rst_n, key
    output: led

    FPGA判断上升沿是通过将原信号延迟,再对比获取上升沿

src/touch_led.v

bash 复制代码
module touch_led(
	input 						sys_clk,
	input 						sys_rst_n,
	input 					 	touch_key,

	output 		reg		led		
);

reg touch_key_d0;
reg touch_key_d1;

wire pos_touch_key;
assign pos_touch_key = ~touch_key_d1 & touch_key_d0;//采上升沿

//打两拍,采集上升沿
always @(posedge sys_clk or negedge sys_rst_n) begin
	if(!sys_rst_n) begin
		touch_key_d0 <= 1'd0;
		touch_key_d1 <= 1'd0;
	end
	else begin
		touch_key_d0 <= touch_key; //打两拍
		touch_key_d1 <= touch_key_d0 ;
	end
end

//led信号反转
always @(posedge sys_clk or negedge sys_rst_n) begin
	if(!sys_rst_n) 
		led <= 1'd1;
	else if(pos_touch_key)//上升沿
		led <= ~led;
	else
		led <= led;
end
endmodule

3.仿真代码

sim/tb/tb_touch_led.v

bash 复制代码
`timescale 1ns/1ns

module tb_touch_led();
parameter CLK_PERIOD = 20;//时钟周期

reg 				sys_clk;//需要被赋值,所以定义为reg类型
reg 				sys_rst_n;
reg 	 			touch_key;

wire  			led; //不会被赋值,所以定义为wire型。注意:如果是assign连续赋值,则是对wire类型赋值

initial begin
	sys_clk <= 1'b0;
	sys_rst_n <= 1'b0;
	touch_key <= 1'b0;
	#200  //延时200ns
	sys_rst_n <= 1'b1;

	//模拟按键按下/释放
	#2000
	touch_key <= 1'b1;
	#2000
	touch_key <= 1'b0;
end

always #(CLK_PERIOD/2) sys_clk = ~sys_clk; //每隔10ns取反一次,时间周期20ns

touch_led u_touch_led(
	.sys_clk 				(sys_clk),
	.sys_rst_n 			(sys_rst_n),
	.touch_key 			(touch_key),
	.led 					(led))
endmodule
相关推荐
ThreeYear_s4 小时前
电力电子技术学习路径与FPGA/DSP技术结合方向(gemini生成)
学习·fpga开发
奋斗的牛马9 小时前
FPGA—ZYNQ学习spi(六)
单片机·嵌入式硬件·学习·fpga开发·信息与通信
GateWorld11 小时前
FPGA核心约束类型与语法
fpga开发
SKYDROID云卓小助手12 小时前
无人设备遥控器之数字图传技术
运维·服务器·单片机·嵌入式硬件·fpga开发
Topplyz13 小时前
在FPGA中实现频率计方案详解(等精度测量)
fpga开发·fpga·频率计
whik119415 小时前
如何测量FPGA管脚的好坏
fpga开发
XINVRY-FPGA15 小时前
XC7Z020-1CLG484I Xilinx AMD FPGA Zynq-7000 SoC
arm开发·嵌入式硬件·网络协议·fpga开发·硬件工程·信号处理·fpga
Js_cold1 天前
Verilog宏define
fpga开发·verilog
Shang180989357261 天前
T41LQ 一款高性能、低功耗的系统级芯片(SoC) 适用于各种AIoT应用智能安防、智能家居方案优选T41L
人工智能·驱动开发·嵌入式硬件·fpga开发·信息与通信·信号处理·t41lq
范纹杉想快点毕业1 天前
12个月嵌入式进阶计划ZYNQ 系列芯片嵌入式与硬件系统知识学习全计划(基于国内视频资源)
c语言·arm开发·单片机·嵌入式硬件·学习·fpga开发·音视频