STM32 ADC数模转换实验

ADC

简介

  • ADC的作用:采集传感器的数据,测量输入电压
  • 量程:能测量的电压范围
  • 分辨率 ::ADC的分辨率通常以输出二进制数的位数表示,位数越多,分辨率越高,一般来说分辨率越高,转化时间越长。(在本实验中为12位,即4096)
  • 通道:

20210122212011

实验程序

C文件

# include "ADC.h"

void User_ADC_Init()
{
	//GPIO初始化
	GPIO_InitTypeDef GPIO_TypeDef_init;
	ADC_InitTypeDef ADC1_Init_TypeDef;
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1,ENABLE);
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);
	GPIO_TypeDef_init.GPIO_Mode  = GPIO_Mode_AIN; //模拟输入模式
	GPIO_TypeDef_init.GPIO_Pin   = GPIO_Pin_5;
	GPIO_TypeDef_init.GPIO_Speed = GPIO_Speed_50MHz;
	GPIO_Init(GPIOA,&GPIO_TypeDef_init);
	
	//ADC初始化
	ADC1_Init_TypeDef.ADC_ContinuousConvMode = DISABLE; //持续转换模式;
	ADC1_Init_TypeDef.ADC_DataAlign  = ADC_DataAlign_Right;//数据右对齐;
	ADC1_Init_TypeDef.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None; //外部触发转换;
	ADC1_Init_TypeDef.ADC_Mode = ADC_Mode_Independent; // 独立模式
	ADC1_Init_TypeDef.ADC_NbrOfChannel = 1 ; //通道数
	ADC1_Init_TypeDef.ADC_ScanConvMode = DISABLE; //扫描转换模式
	ADC_Init(ADC1,&ADC1_Init_TypeDef);
	//配置通道
	ADC_RegularChannelConfig(ADC1,ADC_Channel_5,1,ADC_SampleTime_239Cycles5); //ADC1 , 通道五,转换时间
	//ADC1启动
	ADC_Cmd(ADC1,ENABLE);
	//校准ADC1
	ADC_StartCalibration(ADC1);
	while(ADC_GetCalibrationStatus(ADC1));
	
}

uint8_t ADC_Get_Value()
{
	unsigned char ADC_Val = 0;
	//启动软件转换
	ADC_SoftwareStartConvCmd(ADC1,ENABLE);
	//等待转换完成
	while(ADC_GetFlagStatus(ADC1,ADC_FLAG_EOC) == RESET);
	ADC_Val = ADC_GetConversionValue(ADC1);
	//清空标志位
	ADC_ClearFlag(ADC1, ADC_FLAG_EOC);
	//关闭转换
	ADC_SoftwareStartConvCmd(ADC1, DISABLE);
	return ADC_Val;
}

h文件

# ifndef __ADC_C
# define __ADC_C
# include "stm32f10x.h"
# include "stm32f10x_gpio.h"
# include "stm32f10x_adc.h"
void User_ADC_Init();
uint8_t ADC_Get_Value();
# endif

main函数

x = ADC_Get_Value();
sprintf(ADC_Val_buf,"ADC_VAL:%.2f",3.3/4096.*x);
LCD_DisplayStringLine(Line4,ADC_Val_buf);

实验截图

20210122210628
2021012221065020210122210715

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个简单的实例代码,用于在STM32上进行DAC和ADC的数据采集和转换: ``` #include "stm32f10x.h" #include "stm32f10x_adc.h" #include "stm32f10x_dac.h" #include "stm32f10x_gpio.h" #include "stm32f10x_rcc.h" int main(void) { GPIO_InitTypeDef GPIO_InitStructure; ADC_InitTypeDef ADC_InitStructure; DAC_InitTypeDef DAC_InitStructure; // 开启GPIOA、ADC1、DAC通道1时钟 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_ADC1 | RCC_APB1Periph_DAC, ENABLE); // 配置DAC通道1的GPIO引脚PA4 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN; GPIO_Init(GPIOA, &GPIO_InitStructure); // 配置ADC1的GPIO引脚PA0 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN; GPIO_Init(GPIOA, &GPIO_InitStructure); // 配置DAC通道1 DAC_InitStructure.DAC_Trigger = DAC_Trigger_None; DAC_InitStructure.DAC_WaveGeneration = DAC_WaveGeneration_None; DAC_InitStructure.DAC_OutputBuffer = DAC_OutputBuffer_Enable; DAC_Init(DAC_Channel_1, &DAC_InitStructure); // 配置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); // 配置ADC1的通道0 ADC_RegularChannelConfig(ADC1, ADC_Channel_0, 1, ADC_SampleTime_55Cycles5); // 启动ADC1的转换器 ADC_Cmd(ADC1, ENABLE); // 启动DAC通道1 DAC_Cmd(DAC_Channel_1, ENABLE); // 等待DAC通道1的输出稳定 while (DAC_GetFlagStatus(DAC_Channel_1, DAC_FLAG_DMAUDR) == RESET); // 开始ADC1的转换 ADC_SoftwareStartConvCmd(ADC1, ENABLE); // 等待转换结束 while (ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC) == RESET); // 读取转换结果 uint16_t adc_value = ADC_GetConversionValue(ADC1); uint16_t dac_value = DAC_GetDataOutputValue(DAC_Channel_1); while (1); } ``` 此代码中,我们首先启用了GPIOA、ADC1和DAC通道1的时钟。然后,我们配置了PA4作为DAC通道1的引脚,PA0作为ADC1的引脚。接下来,我们配置了DAC通道1和ADC1,并将ADC通道0与ADC1关联起来。然后,我们启动了ADC1的转换器和DAC通道1,并等待DAC通道1的输出稳定。最后,我们开始ADC1的转换,并等待转换结束。我们读取了ADC和DAC的转换结果并停止程序的运行。 希望这个例子对你有帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值