STM32F103C8T6与雨滴传感器连接,并显示雨量大小,附代码

连线:VCC-3.3V,GNG-GND,DO-PA00, AO-PA01,雨量大小可以自己标定

下面附代码:water.h

#ifndef __WATER_H
#define __WATER_H 
 
 
#define gpio_readC  GPIO_ReadInputDataBit(GPIOA, GPIO_Pin_0)   //读取GPIOA的P0口电平(0/1)
 
void Water_Init(void);                                         //延时初始化函数
int Water_read(void);                                          //读取A0口
 
#endif

water.c

#include "delay.h"
#include "water.h"
#include "stm32f10x.h"                  // Device header  
 
 
void Water_Init(void)
{    	 
	
	RCC_APB2PeriphClockCmd( RCC_APB2Periph_GPIOC, ENABLE);		//使能GPIOA端口时钟
	
	GPIO_InitTypeDef GPIO_InitStructure;						//定义一个设置GPIO的结构体变量	
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;					//设置PC0
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;    	//设置PC0引脚为浮空输入
	GPIO_Init(GPIOC, &GPIO_InitStructure);            		 	//初始化GPIOC
	
}
 
int Water_read(void)
{
	if(gpio_readC == 1)
	{ 
		return 0;
	}
	else
	{		
		return 1;
	}
}

main.c

float yuliang;
u16 adcx;
Water_Init(); 
int result = Water_read();  
char buffer[20]; // 创建一个缓冲区来保存字符串  
sprintf(buffer, "我收到的雨水传感器数据是:%d\r\n", result); // 将整数值转换为字符串  
printf("%s", buffer); // 打印字符串 
Adc_Init();					 
adcx = Get_Adc_Average(ADC_Channel_1,10) ;
yuliang	=(float)adcx*(3.3/4096);				
printf("雨量信息是:%f\r\n",yuliang);  

adc.c

#include "stm32f10x.h"    //包含需要的头文件
#include "delay.h"	      //包含需要的头文件
   

void Adc_Init()
{
	GPIO_InitTypeDef GPIO_InitStructure;
	ADC_InitTypeDef ADC_InitStructure; 
	
	//1、开启时钟ADC1的时钟和GPIOA的时钟
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1,ENABLE );
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE );
	//2、配置分频,因为最大不能超过14MHz 72/6=12
	RCC_ADCCLKConfig(RCC_PCLK2_Div6);   //设置ADC分频因子6 72M/6=12,ADC最大时间不能超过14M
	//3、配置GPIOA和ADC结构体 PA1 作为模拟通道输入引脚                         
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;		//模拟输入引脚
	GPIO_Init(GPIOA, &GPIO_InitStructure);	
	
	ADC_DeInit(ADC1); //复位ADC1
	
	ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;	//ADC工作模式:ADC1和ADC2工作在独立模式
	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数据右对齐
	ADC_InitStructure.ADC_NbrOfChannel = 1;	//顺序进行规则转换的ADC通道的数目
	ADC_Init(ADC1, &ADC_InitStructure);	//根据ADC_InitStruct中指定的参数初始化外设ADCx的寄存器   
	//4、使能ADC1
	ADC_Cmd(ADC1, ENABLE);
	//5、校准并等待校准结束
	ADC_ResetCalibration(ADC1);	//使能复位校准  
	 
	while(ADC_GetResetCalibrationStatus(ADC1));	//等待复位校准结束
	
	ADC_StartCalibration(ADC1);	 //开启AD校准
 
	while(ADC_GetCalibrationStatus(ADC1));	 //等待校准结束
	
}

uint16_t AD_GetValue(u8 ch)
{
		//设置指定ADC的规则组通道,一个序列,采样时间
	ADC_RegularChannelConfig(ADC1, ch, 1, ADC_SampleTime_239Cycles5 );	//ADC1,ADC通道,采样时间为239.5周期	  		
	 
	ADC_SoftwareStartConvCmd(ADC1, ENABLE);		//使能指定的ADC1的软件转换启动功能	
	 
	while(!ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC ));//等待转换结束

	return ADC_GetConversionValue(ADC1);	//返回最近一次ADC1规则组的转换结果
}

//多获取几次数据求平均值更稳定
uint16_t Get_Adc_Average(u8 ch,u8 times)
{
	u32 temp_val=0;
	u8 t;
	for(t=0;t<times;t++)
	{
		temp_val+=AD_GetValue(ch);
		Delay_ms(5);
	}
	return temp_val/times;
} 	 

adc.h

#ifndef __adc_H
#define __adc_H 
 
 
 
void Adc_Init(void);                                   
uint16_t AD_GetValue(u8 ch);                                       
uint16_t Get_Adc_Average(u8 ch,u8 times);
 
#endif

 

 

 

  • 8
    点赞
  • 66
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值