我是靠谱客的博主 危机朋友,最近开发中收集的这篇文章主要介绍日记 | STM32串口显示YL-69土壤湿度,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

目标

 

今天是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土壤湿度所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(74)

评论列表共有 0 条评论

立即
投稿
返回
顶部