触摸按键控制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
相关推荐
421!6 小时前
ESP32学习笔记之GPIO
开发语言·笔记·单片机·嵌入式硬件·学习·算法·fpga开发
dMing`7 小时前
基于FPGA的简易数据采集系统
fpga开发·fpga·adc·dac
LCMICRO-1331084774611 小时前
长芯微LD9689完全P2P替代AD9689,是一款双通道、14位、2.0 GSPS/2.6 GSPS模数转换器(ADC)
网络·单片机·嵌入式硬件·网络协议·fpga开发·硬件工程·高速adc
萨文 摩尔杰21 小时前
GPS原理学习
学习·fpga开发
Huangichin1 天前
跟着Gemini学System Verilog
fpga开发
LCMICRO-133108477461 天前
长芯微LDC90810完全P2P替代ADC128D818,是一款八通道系统监控器,专为监控复杂系统状态而设计。
stm32·单片机·嵌入式硬件·fpga开发·硬件工程·模数转换芯片adc
s09071361 天前
保姆级教程十二:USB摄像头接入!ZYNQ+OpenCV+FPGA硬件加速图像处理实战(视觉终极篇)
图像处理·opencv·fpga开发·zynq·硬件加速
CoderIsArt1 天前
FPGA-based 量子电路仿真
fpga开发
碎碎思2 天前
升级版流水灯:用FPGA控制上千颗RGB LED
fpga开发
FPGA-ADDA2 天前
第二篇:Xilinx 7系列FPGA详解——从Spartan到Virtex
fpga开发·fpga·sdr·rfsoc