key_beep按键控制蜂鸣器程序及流程图

1.试验任务:

使用按键控制蜂鸣器发声。 初始状态为蜂鸣器鸣叫,按下开关后蜂鸣器停
止鸣叫,再次按下开关,蜂鸣器重新鸣叫。

2. 按键消抖

在这里插入图片描述

3.程序设计

在这里插入图片描述

3.1消抖模块

// An highlighted block
module key_debounce(             //消抖模块 
    input sys_clk,               //时钟信号,50Mhz
	input sys_rst_n,             //复位信号         
	
	input key,                   //按键
	output reg key_flag,             //按键有效的标志 
	output reg key_value             //按键有效的值
);

reg key_reg;                     //key的寄存器,比对两个时钟时将值放在寄存器内
reg [19:0]delay_cnt;             //延时20ns的寄存器,20ms=20000000ns,20000000ns/20=1000000个时钟周期,位宽为20位

always @(posedge sys_clk or negedge sys_rst_n)begin
    if(!sys_rst_n)begin          //按下复位按键
	key_reg <= 1'b1;             //key_reg按键为低电平有效,所以拉高
	delay_cnt <= 20'd0;          //计数器清零
	end
	else begin
		key_reg <= key;          //将key的值存入寄存器中(注,key的值等到下一个边沿过来时,才会传递给key_reg,既key_reg的值和key的值相差一个时钟周期)
		if(key_reg!=key)               //上一个值是否和当前值相同,若按下按键则当前值和上一值不同,则进入该语句
			delay_cnt <= 32'd100_0000;      //把delay_cnt寄存器充满20ms     
		else if(key_reg==key)begin     //上一个值是否和当前值相同,若没有按按键则当前值和上一值相同,则进入该语句
			if(delay_cnt > 32'd0)
				delay_cnt <=delay_cnt-1'b1; //
			else
				delay_cnt <=delay_cnt;
		end
	end
end

always @(posedge sys_clk or negedge sys_rst_n)begin
    if(!sys_rst_n)begin 
		key_flag <= 1'b0;       //如果复位将flag清零
		key_value <= 1'b1;      //为低时才判定按键按下
	end
	else begin
		if(delay_cnt == 32'd1)begin
			key_flag <= 1'b1;
			key_value <= key; 
		end
		else begin
			key_flag <= 1'b0;
			key_value <= key_value;
		end
	end
end

endmodule

3.2消抖模块流程图

在这里插入图片描述
在这里插入图片描述

3.3 蜂鸣器驱动模块程序

// An highlighted block
module beep_control(             //消抖模块 
    input sys_clk,               //时钟信号,50Mhz
	input sys_rst_n,             //复位信号         
	
	input key_flag,             //按键有效的标志 
	input key_value,             //按键有效的值
	output reg beep
);

always @(posedge sys_clk or negedge sys_rst_n)begin
    if(!sys_rst_n)
		beep <= 1'b1;
	else if(key_flag&&(~key_value))
		beep <=~beep;
end

endmodule

3.4 顶层例化模块程序

// An highlighted block
module top_key_beep(              
    input sys_clk,               //时钟信号,50Mhz
	input sys_rst_n,             //复位信号         
	input key,        
	output beep
);

wire key_flag;
wire key_value;

key_debounce key_debounce_u(
	.sys_clk (sys_clk),
	.sys_rst_n (sys_rst_n),
	.key (key),
	.key_flag (key_flag),
    .key_value (key_value)
);

beep_control beep_control_u(
	.sys_clk (sys_clk),
	.sys_rst_n (sys_rst_n),
	.key_flag (key_flag),
	.key_value (key_value),
	.beep (beep)
);
endmodule

3.5 ucf模块

// An highlighted block
NET sys_clk             TNM_NET = sys_clk_pin;
TIMESPEC TS_sys_clk_pin = PERIOD sys_clk_pin 20ns HIGH 50%;

#------------------------------系统时钟和复位----------------------------------- 
NET sys_clk          LOC = N8  | IOSTANDARD = "LVCMOS33";   
NET sys_rst_n        LOC = G16 | IOSTANDARD = "LVCMOS33"; 

NET "key"            LOC = P5  | IOSTANDARD = "LVCMOS33";
NET beep             LOC = P4  | IOSTANDARD = "LVCMOS33";
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!要实现STM32按键控制蜂鸣器,可以按照以下步骤进行: 1. 首先需要在STM32上配置GPIO口,将按键和蜂鸣器连接到相应的GPIO口。 2. 在程序中配置GPIO口的输入输出模式和上下拉电阻。 3. 在程序中开启定时器中断,并且通过定时器中断控制蜂鸣器的响声。 4. 在程序中通过GPIO口读取按键的状态,并且根据按键的状态控制蜂鸣器的响声。 下面是一段示例代码,可以供您参考: ```c #include "stm32f10x.h" #define BEEP_GPIO_PORT GPIOA #define BEEP_GPIO_PIN GPIO_Pin_8 #define KEY_GPIO_PORT GPIOC #define KEY_GPIO_PIN GPIO_Pin_13 void GPIO_Configuration(void) { GPIO_InitTypeDef GPIO_InitStructure; // 配置蜂鸣器GPIO口为推挽输出模式 GPIO_InitStructure.GPIO_Pin = BEEP_GPIO_PIN; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(BEEP_GPIO_PORT, &GPIO_InitStructure); // 配置按键GPIO口为上拉输入模式 GPIO_InitStructure.GPIO_Pin = KEY_GPIO_PIN; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU; GPIO_Init(KEY_GPIO_PORT, &GPIO_InitStructure); } void TIM_Configuration(void) { TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure; // 配置定时器2为1KHz的频率 TIM_TimeBaseStructure.TIM_Period = 7199; TIM_TimeBaseStructure.TIM_Prescaler = 0; TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1; TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up; TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure); // 开启定时器2中断 TIM_ClearFlag(TIM2, TIM_FLAG_Update); TIM_ITConfig(TIM2, TIM_IT_Update, ENABLE); TIM_Cmd(TIM2, ENABLE); } void TIM2_IRQHandler(void) { static uint16_t beep_count = 0; if (TIM_GetITStatus(TIM2, TIM_IT_Update) != RESET) { TIM_ClearITPendingBit(TIM2, TIM_IT_Update); if (beep_count > 0) { GPIO_WriteBit(BEEP_GPIO_PORT, BEEP_GPIO_PIN, (BitAction)(1 - GPIO_ReadOutputDataBit(BEEP_GPIO_PORT, BEEP_GPIO_PIN))); beep_count--; } } } int main(void) { GPIO_Configuration(); TIM_Configuration(); while (1) { if (GPIO_ReadInputDataBit(KEY_GPIO_PORT, KEY_GPIO_PIN) == RESET) { beep_count = 100; // 按键按下时,蜂鸣器鸣叫100ms } } } ``` 以上代码中,通过配置定时器中断和GPIO口的读写状态,实现了按键控制蜂鸣器的功能。具体实现方法可能因为不同的STM32芯片型号和开发板而有所不同,需要根据具体的情况进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值