OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4252|回复: 7

[XILINX] 关于按键控制蜂鸣器例程的改编

[复制链接]

18

主题

51

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
231
金钱
231
注册时间
2022-10-7
在线时间
70 小时
发表于 2022-10-10 09:07:55 | 显示全部楼层 |阅读模式
2金钱
看完 按键控制蜂鸣器的视频后,想自己改写一个两个按键共同控制蜂鸣器的程序 (key1 按下切换蜂鸣器状态,key2 按下后蜂鸣器响松开后蜂鸣器关),但是设计程序的时候提示一个端口不能用两个信号同时驱动,请问要怎么设计才能实现?

最佳答案

查看完整内容[请看2#楼]

你可以先参考下按键控制LED灯的程序,和你这个比较类似,同样是实现多个按键控制同一个外设的例子
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

3

主题

2013

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
5618
金钱
5618
注册时间
2018-10-21
在线时间
1591 小时
发表于 2022-10-10 09:07:56 | 显示全部楼层
你可以先参考下按键控制LED灯的程序,和你这个比较类似,同样是实现多个按键控制同一个外设的例子
回复

使用道具 举报

14

主题

821

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2034
金钱
2034
注册时间
2021-7-17
在线时间
635 小时
发表于 2022-10-10 09:46:10 | 显示全部楼层
按理是可以的,分开来写按键的程序就行
回复

使用道具 举报

3

主题

2013

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
5618
金钱
5618
注册时间
2018-10-21
在线时间
1591 小时
发表于 2022-10-10 10:14:23 | 显示全部楼层
信号连接到端口,做个切换就行
回复

使用道具 举报

18

主题

51

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
231
金钱
231
注册时间
2022-10-7
在线时间
70 小时
 楼主| 发表于 2022-10-10 11:11:32 | 显示全部楼层
  1. `timescale 1ns / 1ps
  2. module top_key_beep(
  3.         input  sys_clk,
  4.         input  sys_rst_n,
  5.         input   [1:0] key,
  6.         output beep
  7. );
  8. //四根连接线(无实际意义)
  9. wire key_value;       
  10. wire key_flag;
  11. wire key_value_2;
  12. wire key_flag_2;

  13. //子模块例化
  14. //第一个按键
  15. key_debounce u_key_debounce(
  16.         .sys_clk                (sys_clk),
  17.         .sys_rst_n                (sys_rst_n),
  18.         .key                        (key[0]),
  19.         .key_value                (key_value),//单比特
  20.         .key_flag                (key_flag)
  21. );
  22. beep_control u_beep_control(
  23.         .sys_clk            (sys_clk),
  24.         .sys_rst_n            (sys_rst_n),
  25.         .key_value            (key_value),
  26.         .key_flag            (key_flag),
  27.         .beep                (beep)
  28. );
  29. //第二个按键
  30. key_debounce u_key_debounce_2(
  31.         .sys_clk                (sys_clk),
  32.         .sys_rst_n                (sys_rst_n),
  33.         .key                        (key[1]),
  34.         .key_value            (key_value_2),//单比特
  35.         .key_flag                (key_flag_2)
  36. );
  37. beep_control_2 u_beep_control_2(
  38.         .sys_clk            (sys_clk),
  39.         .sys_rst_n            (sys_rst_n),
  40.         .key_value_2    (key_value_2),
  41.         .key_flag_2            (key_value_2),
  42.         .beep                (beep)
  43. );

  44. endmodule
复制代码
回复

使用道具 举报

18

主题

51

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
231
金钱
231
注册时间
2022-10-7
在线时间
70 小时
 楼主| 发表于 2022-10-10 11:12:34 | 显示全部楼层
QinQZ 发表于 2022-10-10 10:14
信号连接到端口,做个切换就行

你好,下面是我的代码,key_debounce是按键消抖的作用,我应该怎么去修改呢, 能给点建议吗
回复

使用道具 举报

18

主题

51

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
231
金钱
231
注册时间
2022-10-7
在线时间
70 小时
 楼主| 发表于 2022-10-10 11:13:04 | 显示全部楼层
ChenRyan 发表于 2022-10-10 09:46
按理是可以的,分开来写按键的程序就行

你好,下面是我的代码,key_debounce是按键消抖的作用,我应该怎么去修改呢, 能给点建议吗
回复

使用道具 举报

18

主题

51

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
231
金钱
231
注册时间
2022-10-7
在线时间
70 小时
 楼主| 发表于 2022-10-10 12:38:38 | 显示全部楼层
QinQZ 发表于 2022-10-10 11:53
你可以先参考下按键控制LED灯的程序,和你这个比较类似,同样是实现多个按键控制同一个外设的例子

好的谢谢
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-23 09:30

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表