概述
目标
今天是2022年1月30日,毕业设计硬件部分有一个土壤湿度采集部分,土壤湿度传感器我这里使用的是YL-69。
实验目的是通过YL-69采取土壤湿度,并通过串口打印。
器材
正点原子F103ZET6最小系统板、YL-69土壤湿度传感器、杜邦线若干
硬件连接
AO接开发板PA1、VCC接5V、GND接GND
代码部分
参考例程【正点原子】STM32F103最小系统板实验14 ADC实验
adc.c
#include "adc.h"
#include "delay.h"
int shidu1;
void Adc_Init(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
ADC_InitTypeDef ADC_InitStruct;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_ADC1,ENABLE);
/*PA_1设置为模拟输入*/
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1; //
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN; //模拟输入
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; //IO口速度为50MHz
GPIO_Init(GPIOA, &GPIO_InitStructure);
RCC_ADCCLKConfig(RCC_PCLK2_Div6);//设置ADC分频因子
ADC_DeInit(ADC1);//复位ADC
//初始化ADC参数
ADC_InitStruct.ADC_ContinuousConvMode=DISABLE;
ADC_InitStruct.ADC_DataAlign=ADC_DataAlign_Right;
ADC_InitStruct.ADC_ExternalTrigConv=ADC_ExternalTrigConv_None;
ADC_InitStruct.ADC_Mode=ADC_Mode_Independent;
ADC_InitStruct.ADC_NbrOfChannel=1;
ADC_InitStruct.ADC_ScanConvMode=DISABLE;
ADC_Init(ADC1, &ADC_InitStruct);
ADC_Cmd(ADC1,ENABLE);//使能ADC1
ADC_ResetCalibration(ADC1); //使能复位校准
while(ADC_GetResetCalibrationStatus(ADC1)); //等待复位校准结束
ADC_StartCalibration(ADC1); //开启AD校准
while(ADC_GetCalibrationStatus(ADC1)); //等待校准结束
}
u16 Get_Adc(u8 ch) //获取ADC数据
{
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(1);
}
temp_avrg=temp_val/times;
shidu1=(4092-temp_avrg)/3292*100;
return shidu1;
}
adc.h
#ifndef __ADC_H
#define __ADC_H
#include "sys.h"
//正点原子的adc采集代码
void Adc_Init(void);
u16 Get_Adc(u8 ch);
u16 Get_Adc_Average(u8 ch,u8 times);
extern float temp_avrg;
extern int shidu;
#endif
main.c
#include "sys.h"
#include "delay.h"
#include "usart.h"
#include "stdio.h"
#include "adc.h"
int shidu;
float temp_avrg=0;
u8 buff[30]; //参数显示缓存数组
int main(void)
{
delay_init(); //延时函数初始化
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//设置中断优先级分组为组2:2位抢占优先级,2位响应优先级
Adc_Init();
uart_init(9600);
while(1)
{
shidu= Get_Adc_Average(1,10);
DHT11_Read_Data(&DHT11_Temp,&DHT11_Hum);
printf("土壤湿度:%drn", shidu);
delay_ms(100);
}
}
结果验证
验证方式:采用湿纸巾捂住土壤湿度传感器
未使用湿纸巾时串口数据如下:
使用湿纸巾捂住传感器后串口数据如下:
通过实验我们发现,在使用湿纸巾捂住土壤湿度传感器后我们可以明显看到数据的变化,并且在改变湿巾湿度时也能观察到数据变化,试验成功。
经验总结
1、建议实验在已有的工程基础上进行一些修改,这样可以最大化降低出错率,本次实验采用的是——例程【正点原子】STM32F103最小系统板实验14 ADC实验
2、本次实验属于ADC转换实验,要根据自己的开发板进行一些列调整,比如我这里是用的是正点原子F103最小系统板,在进行ADC实验时我们需要将UREF与3.3V进行连接,否则会出现串口数据一直为0的情况。
注意!!!!参考开发手册得知UREF不能接5V!!!!!
接线如下图所示,仅供参考:
最后
以上就是危机朋友为你收集整理的日记 | STM32串口显示YL-69土壤湿度的全部内容,希望文章能够帮你解决日记 | STM32串口显示YL-69土壤湿度所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复