博客
关于我
单片机蜂鸣器发声,首先是让他一直响
阅读量:775 次
发布时间:2019-03-24

本文共 1456 字,大约阅读时间需要 4 分钟。

废弃的Keil项目看起来没有得到正式的整理,但让我试着重新组织这些材料,使其更易于阅读和理解。以下是一个优化后的版本:


开启Keil开发环境,并创建一个新的工程项目。将已有的程序文件添加到工程中开始工作。

本次项目,我们将使用单片机控制蜂鸣器发声。P3^6脚将作为蜂鸣器的输出引脚。

首先,我们需要定义蜂鸣器的引脚。在程序中,我们可以使用以下代码:

#include 
sbit FMQ36 = P3^6;

接下来,我们需要确保蜂鸣器能够持续发声。当蜂鸣器接收到高电平信号时,它会响鸣。我们可以使用以下代码实现循环输出:

#include 
sbit FMQ36 = P3^6; void main() { while(1) { FMQ36 = 0; // 低电平 for(i=0; i < 100; i++) { // 插入一个短暂的延时 } FMQ36 = 1; // 高电平 for(i=0; i < 300; i++) { // 插入一个短暂的延时 } }}

如果这个方法仍然不够理想,我们可以进一步优化代码。为此,我们可以引入循环控制结构中的更高级技术。例如,我们可以定义一个辅助函数来实现蜂鸣器的调制和输出。

#include 
sbit FMQ36 = P3^6; int i;void FMQ() { FMQ36 = 0; // 低电平 for(i=0; i < 100; i++) { // 保持低电平一小段时间 } FMQ36 = 1; // 高电平 for(i=1; i < 300; i++) { // 保持高电平一段更长的时间 }}void main() { while(1) { FMQ(); }}

或者,您可以直接在循环内部独立地设置蜂鸣器的输出:

#include 
sbit FMQ36 = P3^6; int i; void main() { while(1) { FMQ36 = 0; // 设置低电平 for(i=0; i < 100; i++) { // 保持低电平的时间 } FMQ36 = 1; // 设置高电平 for(i=0; i < 300; i++) { // 保持高电平的时间 } }}

在编译完成后,将代码下载到单片机中,测试蜂鸣器的响应是否符合预期。


当您第一次将代码上传并运行时,请注意以下几点:

  • 蜂鸣器的引脚定义:P3^6脚通常与蜂鸣器的数据引脚并联。请确保蜂鸣器与单片机的事例符号正确连接。

  • 延时和频率:循环中的计数器值(如100或300)决定了蜂鸣器保持电平的时间。您可以根据需要调整这些数值来确定蜂鸣器的声音频率和持续时间。

  • 循环优化:使用for循环的核心思想是利用单片机的内部计数器来实现延时功能,而不是依赖于外部中断或其他复杂机制。

  • 通过以上代码,您应该能够成功实现蜂鸣器的基本控制功能。如果您遇到任何问题,请仔细检查蜂鸣器的连接方式和单片机的配置设置。

    转载地址:http://xkdkk.baihongyu.com/

    你可能感兴趣的文章
    ngrok内网穿透可以实现资源共享吗?快解析更加简洁
    查看>>
    ngrok内网穿透可以实现资源共享吗?快解析更加简洁
    查看>>
    NHibernate动态添加表
    查看>>
    NHibernate学习[1]
    查看>>
    NHibernate异常:No persister for的解决办法
    查看>>
    Nhibernate的第一个实例
    查看>>
    NHibernate示例
    查看>>
    nid修改oracle11gR2数据库名
    查看>>
    NIFI1.21.0/NIFI1.22.0/NIFI1.24.0/NIFI1.26.0_2024-06-11最新版本安装_采用HTTP方式_搭建集群_实际操作---大数据之Nifi工作笔记0050
    查看>>
    NIFI1.21.0_java.net.SocketException:_Too many open files 打开的文件太多_实际操作---大数据之Nifi工作笔记0051
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_插入时如果目标表中已存在该数据则自动改为更新数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0058
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0_Postgresql和Mysql同时指定库_指定多表_全量同步到Mysql数据库以及Hbase数据库中---大数据之Nifi工作笔记0060
    查看>>
    NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
    查看>>
    NIFI1.21.0最新版本安装_配置使用HTTP登录_默认是用HTTPS登录的_Https登录需要输入用户名密码_HTTP不需要---大数据之Nifi工作笔记0051
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增加修改实时同步_使用JsonPath及自定义Python脚本_03---大数据之Nifi工作笔记0055
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
    查看>>