STM32学习记录——光敏传感器的使用

文章介绍了通过STM32的ADC功能学习使用光敏传感器检测光线亮度,并根据检测结果在OLED屏幕上显示明亮或黑暗的过程。涉及到的硬件包括三线光敏传感器和OLED屏,软件部分主要为ADC初始化和光敏传感器的IO口配置。代码示例包括ADC和光敏传感器的初始化函数以及读取ADC平均值的函数。
摘要由CSDN通过智能技术生成

文章目录


前言

       只做学习记录,记录自己如何从零学会使用一个模块,仅仅只是会用,缺乏专业知识。如果需要了解更多原理,可以从我推荐的技术大佬的文章中获取。


一、学习目的

       我的学习目的就是通过STM32的ADC功能,学会使用光敏传感器,并在无光时用oled屏显示“黑暗”,在有光时用oled屏显示“明亮”。

二、模块介绍

       我使用的是三线光敏传感器,通过光敏电阻在不同光照环境下的不同阻值,从而影响电压,再通过ADC功能获取电压值。用途:光线亮度检测,光线亮度传感器,智能小车寻光模块。接线方面:vcc接3.3v,GND接地,DO引脚直接与单片机相连,通过单片机来检测高低电平,由此来检测环境的光线亮度改变。我定义的IO口是PA0(即模块的DO引脚接单片机的PA0)

三、代码记录

lsens.h(光敏传感器初始化)

#ifndef __LSENS_H
#define __LSENS_H	
#include "sys.h" 
#include "adc.h" 

void Lsens_Init(void); 		  //初始化光敏传感器
#endif 

lsens.c

#include "lsens.h"
#include "delay.h"

void Lsens_Init(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);
GPIO_InitStructure.GPIO_Pin =  GPIO_Pin_0;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; 
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;  
GPIO_Init(GPIOA, &GPIO_InitStructure); 
}

adc.h

#ifndef __ADC_H
#define __ADC_H	
#include "sys.h"

void Adc_Init(void);
u16  Get_Adc(u8 ch); 
u16 Get_Adc_Average(u8 ch,u8 times); 
 
#endif 

adc.c  

 #include "adc.h"
 #include "delay.h"
		   																   
void  Adc_Init(void)
{ 	
	ADC_InitTypeDef ADC_InitStructure; 
	GPIO_InitTypeDef GPIO_InitStructure;

	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA |RCC_APB2Periph_ADC1, ENABLE );	
 

	RCC_ADCCLKConfig(RCC_PCLK2_Div6); 
                        
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;	
	GPIO_Init(GPIOA, &GPIO_InitStructure);	

	ADC_DeInit(ADC1);
	ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;	
	ADC_InitStructure.ADC_ScanConvMode = DISABLE;
	ADC_InitStructure.ADC_ContinuousConvMode = DISABLE;	
	ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;	
	ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;
	ADC_InitStructure.ADC_NbrOfChannel = 1;	
	ADC_Init(ADC1, &ADC_InitStructure);	
  
	ADC_Cmd(ADC1, ENABLE);	
	
	ADC_ResetCalibration(ADC1);	
	 
	while(ADC_GetResetCalibrationStatus(ADC1));
	
	ADC_StartCalibration(ADC1);	
 
	while(ADC_GetCalibrationStatus(ADC1));
 
//	ADC_SoftwareStartConvCmd(ADC1, ENABLE);	

}				  

u16 Get_Adc(u8 ch)   
{
  	
	ADC_RegularChannelConfig(ADC1, ch, 1, ADC_SampleTime_239Cycles5 );			    
  
	ADC_SoftwareStartConvCmd(ADC1, ENABLE);	
	 
	while(!ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC ));

	return ADC_GetConversionValue(ADC1);	
}

u16 Get_Adc_Average(u8 ch,u8 times)
{
	u32 temp_val=0;
	u8 t;
	for(t=0;t<times;t++)
	{
		temp_val+=Get_Adc(ch);
		delay_ms(5);
	}
	return temp_val/times;
} 	 

       这里主要是初始化ADC,相信大家已经比较了解了。由于我的能力有限,我只作学习记录,如果需要了解相关知识,可以看看下面这篇文章。

STM32—ADC详解_stm32f103有几个adc_Aspirant-GQ的博客-CSDN博客

main.c

#include "delay.h"
#include "sys.h"
#include "usart.h"	 
#include "adc.h"
#include "oled.h"
#include "gui.h"
#include "lsens.h"
 
 int main(void)
 {	 
	delay_init();	    	
	NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
	uart_init(115200);	 	   
 	Adc_Init();		  	
	OLED_Init();			    
	OLED_Clear(0);         

 while(1)
	{
       if( GPIO_ReadInputDataBit(GPIOA, GPIO_Pin_0)==0)
		{
         GUI_ShowCHinese(20,0,16,"明亮",16);
        }
	   else
	    {
         GUI_ShowCHinese(20,0,16,"黑暗",16);
        }
        delay_ms(100);   
	}
 }

相关oled的汉字取模

"明",0x00,0x00,0x00,0xFC,0x7C,0x84,0x44,0x84,0x44,0x84,0x44,0xFC,0x7C,0x84,0x44,0x84,
0x44,0x84,0x44,0xFC,0x7C,0x84,0x44,0x84,0x01,0x04,0x01,0x04,0x02,0x14,0x04,0x08,
"亮",0x02,0x00,0x01,0x00,0x7F,0xFC,0x00,0x00,0x1F,0xF0,0x10,0x10,0x1F,0xF0,0x00,0x00,
0x7F,0xFE,0x40,0x02,0x8F,0xE4,0x08,0x20,0x08,0x20,0x10,0x22,0x20,0x22,0xC0,0x1E,

"黑",0x00,0x00,0x3F,0xF8,0x21,0x08,0x29,0x28,0x25,0x48,0x3F,0xF8,0x01,0x00,0x01,0x00,
0x3F,0xF8,0x01,0x00,0x01,0x00,0xFF,0xFE,0x00,0x00,0x48,0x88,0x44,0x44,0x84,0x44,
"暗",0x00,0x80,0x00,0x40,0x7B,0xFC,0x48,0x00,0x49,0x08,0x48,0x90,0x4F,0xFE,0x78,0x00,
0x49,0xF8,0x49,0x08,0x49,0x08,0x49,0xF8,0x79,0x08,0x49,0x08,0x01,0xF8,0x01,0x08,

总结

由于专业知识能力有限,仅仅只能做到会使用一个模块,并且可能会有些许错误。

STM32F103C8T6是一款基于ARM Cortex-M3内核的32位微控制器,光敏传感器则是一种可以检测光线强度的传感器。STM32F103C8T6可以通过使用GPIO(通用输入/输出)口连接到光敏传感器来读取光线强度的数据,从而实现光敏传感器的应用。 具体实现步骤如下: 1. 将光敏传感器的输出引脚连接到STM32F103C8T6的GPIO口上,如PA0口。 2. 配置PA0口为模拟输入模式,可以使用STM32的寄存器来实现,如: ``` RCC->APB2ENR |= RCC_APB2ENR_ADC1EN; // 使能ADC1时钟 GPIOA->CRL &= ~(0x0F<<0); // PA0口模式设置为模拟输入模式 GPIOA->CRL |= (0x08<<0); // PA0口模式设置为模拟输入模式 ADC1->CR2 |= ADC_CR2_ADON; // 使能ADC1模块 ``` 3. 配置STM32的ADC(模拟数字转换器)模块,使其能够读取光敏传感器输出的模拟信号。可以使用STM32的寄存器来实现,如: ``` ADC1->CR2 &= ~ADC_CR2_ALIGN; // 设置ADC1的数据对齐方式为右对齐 ADC1->CR2 &= ~ADC_CR2_EXTSEL; // 设置ADC1的转换触发源为软件触发 ADC1->CR2 |= ADC_CR2_ADSWSTART; // 开始ADC1的转换 ``` 4. 在程序中使用ADC1的寄存器来读取光敏传感器输出的模拟信号,并转换成数字信号。如: ``` while(!(ADC1->SR & ADC_SR_EOC)); // 等待ADC1的转换完成 uint16_t adc_value = ADC1->DR; // 读取ADC1的转换结果 ``` 5. 根据读取到的数字信号来计算出光线的强度值,如: ``` float light_value = adc_value * (3.3 / 4096); // 将ADC读取到的数字信号转换为电压值 light_value = light_value / 0.1; // 根据光敏传感器的灵敏度将电压值转换为光线的强度值 ``` 以上就是使用STM32F103C8T6读取光敏传感器的基本步骤,可以根据具体的应用场景进行修改和优化。
评论 14
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

KAIs32

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

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

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

打赏作者

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

抵扣说明:

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

余额充值