STM32入门教程-2023版【3-4】光敏传感器控制蜂鸣器

关注 +点赞    不错过精彩内容

图片

大家好,我是硬核王同学,最近在做免费的嵌入式知识分享,帮助对嵌入式感兴趣的同学学习嵌入式、做项目、找工作! 

这篇文章以项目代码的形式实现GPIO输入

二、光敏传感器控制蜂鸣器

(1)搭建面包板电路

接线图接线,这里接了两个模块,左边是蜂鸣器,VCC、GND接正负极,控制脚接PB12号口,右边接的就是光敏传感器模块,VCC、GND接正负极,DO数字输出端接PB13号口,当我们遮住光线时,输出指示灯灭,代表输出高电平,松手时,输出指示灯亮,代表输出低电平,这个电位器可以调节高低电平的判断闯值

图片

(2)新建工程

打开工程文件夹,复制一下按键控制LED工程的代码,改个名字叫 3-5 光敏传感器控制蜂鸣器

图片

打开工程文件,光敏传感器控制蜂鸣器程序还是比较简单的,我们主要步骤还是驱动程序的封装

图片

(3)封装蜂鸣器代码

我们先封装一下蜂鸣器,在Hardware目录处右键,添加新的蜂鸣器C文件,名字起Buzzer

图片

再在Hardware目录处右键,添加新的蜂鸣器.h头文件,名字也起Buzzer

图片

继续在Buzzer.c文件中右键,include一个stm32f10x的头文件

图片

在在Buzzer.h文件中添加防止头文件重复包含的代码

图片

在C文件中,也需要一些函数来驱动蜂鸣器,这个逻辑跟LED差不多,所以可以写成以下形式

图片

 
#include "stm32f10x.h"                  // Device headervoid BUZZER_Init(void){        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE);        GPIO_InitTypeDef GPIO_InitStructure;        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_12;        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;        GPIO_Init(GPIOB, &GPIO_InitStructure);                GPIO_SetBits(GPIOB, GPIO_Pin_12);} void BUZZER_ON(void){        GPIO_ResetBits(GPIOB, GPIO_Pin_12);} void BUZZER_OFF(void){        GPIO_SetBits(GPIOB, GPIO_Pin_12);}void BUZZER_Turn(void){        if (GPIO_ReadOutputDataBit(GPIOB, GPIO_Pin_12) == 0)//读取当前端口输出状态        {         GPIO_SetBits(GPIOB, GPIO_Pin_12);        }        else GPIO_ResetBits(GPIOB, GPIO_Pin_12);}//实现了端口的电平反转

当然也不要忘了在Buzzer.h头文件中声明一下这几个函数

图片

 
#ifndef __BUZZER_H#define __BUZZER_H void BUZZER_Init(void);void BUZZER_ON(void);void BUZZER_OFF(void);void BUZZER_Turn(void); #endif

最后可以在main主函数中验证一下

#include "stm32f10x.h"                  // Device header#include "BUZZER.h"#include "LIGHTSENSOR.h" int main(void){                BUZZER_Init();                while(1)        {                                        BUZZER_ON();                Delay_ms(500);                BUZZER_OFF();                Delay_ms(500);                BUZZER_Turn();                Delay_ms(500);                BUZZER_Turn();                Delay_ms(500);        } }

可以听到蜂鸣器在响,证明蜂鸣器驱动没有问题

图片

(4)封装光敏传感器代码

接着再来封装一下光敏传感器的模块,和其他驱动一样,也需要添加新的光敏传感器.c文件、.h头文件,名字为LightSensor

图片

继续在LightSensor.c文件中右键,include一个stm32f10x的头文件,在LightSensor.h文件中添加防止头文件重复包含的代码

图片

在C文件中,也需要一些函数来驱动光敏传感器,所以可以写成以下形式

图片

#include "stm32f10x.h"                  // Device headervoid LIGHTSENSOR_Init(void){        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE);        GPIO_InitTypeDef GPIO_InitStructure;        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;//这里选择上拉输入,如果这个模块始终都连接在端口上,也可以选择浮空输入,只要保证引脚不会悬空即可        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_13;        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;        GPIO_Init(GPIOB, &GPIO_InitStructure);}//读取端口的函数uint8_t LIGHT_GET(void){        return GPIO_ReadInputDataBit(GPIOB, GPIO_Pin_13);}

不要忘了声明一下这几个函数

图片

 
#ifndef __LIGHTSENSOR_H#define __LIGHTSENSOR_H#include "stdint.h" void LIGHTSENSOR_Init(void);uint8_t LIGHT_GET(void);#endif

最后在主函数中验证一下,可以写成这样,当光熄灭时,蜂鸣器报警,当有光照时,蜂鸣器关闭

图片

 
#include "stm32f10x.h"                  // Device header                 #include "BUZZER.h"#include "LIGHTSENSOR.h" int main(void){                BUZZER_Init();        LIGHTSENSOR_Init();        while(1)        {                        if( LIGHT_GET() == 1 ){                BUZZER_ON();                }                else BUZZER_OFF();        } }

遮住光敏电阻,蜂鸣器报警,反之蜂鸣器就不响了

图片

作 者 :硬核王同学

------- END ------

关注公众号回复“加群”按规则加入技术交流群  回复“1024”查看更多内容

图片

  • 45
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
STM32指南者开发板中,可以使用光敏传感器控制蜂鸣器的代码如下: ```c #include "stm32f4xx.h" void ADC_Configuration(void) { ADC_InitTypeDef ADC_InitStructure; GPIO_InitTypeDef GPIO_InitStructure; // 开启 ADC1 时钟 RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE); // 开启 GPIOA 时钟 RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE); // 配置 ADC1 通道1 对应的 GPIOA 引脚为模拟输入 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AN; GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL; GPIO_Init(GPIOA, &GPIO_InitStructure); // ADC1 配置 ADC_InitStructure.ADC_Resolution = ADC_Resolution_12b; ADC_InitStructure.ADC_ScanConvMode = DISABLE; ADC_InitStructure.ADC_ContinuousConvMode = DISABLE; ADC_InitStructure.ADC_ExternalTrigConvEdge = ADC_ExternalTrigConvEdge_None; ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right; ADC_InitStructure.ADC_NbrOfConversion = 1; ADC_Init(ADC1, &ADC_InitStructure); // 配置 ADC1 触发源为软件触发 ADC_ExternalTrigConvCmd(ADC1, DISABLE); } void Buzzer_Configuration(void) { GPIO_InitTypeDef GPIO_InitStructure; // 开启 GPIOB 时钟 RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOB, ENABLE); // 配置 GPIOB 引脚为推挽输出 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT; GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz; GPIO_Init(GPIOB, &GPIO_InitStructure); } uint16_t ReadLightSensorValue(void) { uint16_t adc_value; // 配置 ADC1 通道1 ADC_RegularChannelConfig(ADC1, ADC_Channel_1, 1, ADC_SampleTime_3Cycles); // 启动 ADC1 转换 ADC_Cmd(ADC1, ENABLE); // 等待转换完成 while (ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC) == RESET); // 读取转换结果 adc_value = ADC_GetConversionValue(ADC1); // 关闭 ADC1 ADC_Cmd(ADC1, DISABLE); return adc_value; } int main(void) { // 初始化 ADC ADC_Configuration(); // 初始化蜂鸣器 Buzzer_Configuration(); while (1) { // 读取光敏电阻传感器的模拟值 uint16_t light_value = ReadLightSensorValue(); // 判断光照强度是否超过阈值 if (light_value > 1000) { // 触发蜂鸣器 GPIO_SetBits(GPIOB, GPIO_Pin_8); } else { // 关闭蜂鸣器 GPIO_ResetBits(GPIOB, GPIO_Pin_8); } } } ``` 在上述代码中,首先通过配置GPIO和ADC初始化函数来设置ADC和蜂鸣器的引脚和参数。然后,在`ReadLightSensorValue`函数中,通过配置ADC的通道和采样时间,启动和等待ADC转换完成,并读取转换结果。在主函数中,使用`ReadLightSensorValue`函数读取光敏电阻传感器的模拟值,并根据阈值判断是否触发蜂鸣器。 请注意,此代码仅为示例,具体的配置和使用方法可能会因STM32型号和使用的开发环境而有所不同。在实际应用中,请参考相关的STM32文档和示例代码进行适当的修改和调整。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

硬核王同学

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值