AD单通道&AD多通道----AD模数转换器

AD单通道

单次转换非扫描


void AD_Init(void)
{
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1,ENABLE);
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);
	
	RCC_ADCCLKConfig(RCC_PCLK2_Div6);  //12MHZ
	
	ADC_RegularChannelConfig(ADC1,ADC_Channel_0,1,ADC_SampleTime_55Cycles5);  //55.5+12.5=68
	
	GPIO_InitTypeDef GPIO_Init_Structure;
	//配置为模拟输入模式。在AIN模式下,GPIO是无效的,防止GPIO的输入输出对模拟电压的影响
	GPIO_Init_Structure.GPIO_Mode=GPIO_Mode_AIN;
	GPIO_Init_Structure.GPIO_Pin=GPIO_Pin_0;
	GPIO_Init_Structure.GPIO_Speed=GPIO_Speed_50MHz;
	GPIO_Init(GPIOA,&GPIO_Init_Structure);
	
	ADC_InitTypeDef ADC_InitStruct;
	ADC_InitStruct.ADC_ContinuousConvMode=DISABLE;
	ADC_InitStruct.ADC_ScanConvMode=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_Init(ADC1,&ADC_InitStruct);
	//使能啦
	ADC_Cmd(ADC1,ENABLE);
	
	//复位校准
	ADC_ResetCalibration(ADC1);
	while(ADC_GetResetCalibrationStatus(ADC1) == SET); //该位由软件设置并由硬件清除。在校准寄存器被初始化后该位将被清除
	ADC_StartCalibration(ADC1);
	while(ADC_GetCalibrationStatus(ADC1) == SET);
	
}

uint16_t AD_GetValue(void)
{
	//软件触发转换
	ADC_SoftwareStartConvCmd(ADC1,ENABLE);
	//不能用这个函数:由软件设置该位以启动转换,转换开始后硬件马上清除此位。
	//ADC_GetSoftwareStartConvStatus()
	
	//该位由硬件在(规则或注入)通道组转换结束时设置,由软件清除或由读取ADC_DR时清除0:转换未完成;1:转换完成。
	while(ADC_GetFlagStatus(ADC1,ADC_FLAG_EOC) ==RESET);
	
	return ADC_GetConversionValue(ADC1);
}

uint16_t advalue;
float voltage;
int main(void)
{
	OLED_Init();
	AD_Init();
	OLED_ShowString(1,1,"ADValue:");
	OLED_ShowString(3,1,"Voltage:0.00v");
	while(1)
	{
		
		advalue=AD_GetValue();
		voltage=(float)advalue / 4095 * 3.3; //找出AD值与电压的线性关系
		OLED_ShowNum(2,1,advalue,4);
		OLED_ShowNum(3,9,voltage,1);
		OLED_ShowNum(3,11,(uint16_t)(voltage * 100) % 100,2);
	}
}

连续转换非扫描

对于连续转换,将ADC_InitStruct.ADC_ContinuousConvMode=ENABLE;

只需要触发一次,将ADC_SoftwareStartConvCmd(ADC1,ENABLE);放在初始化函数里

数据寄存器会不断的刷新最新的结果所以也不需要判断结束标志,将while(ADC_GetFlagStatus(ADC1,ADC_FLAG_EOC) ==RESET);删除


 AD多通道

通过参数传递来选择ADC通道

uint16_t AD_GetValue(uint8_t ADC_Channel)
{
	ADC_RegularChannelConfig(ADC1,ADC_Channel,1,ADC_SampleTime_55Cycles5);  //55.5+12.5=68

	//软件触发转换
	ADC_SoftwareStartConvCmd(ADC1,ENABLE);
	while(ADC_GetFlagStatus(ADC1,ADC_FLAG_EOC) ==RESET);
	return ADC_GetConversionValue(ADC1);
}

int main(void)
{
	OLED_Init();
	AD_Init();
	OLED_ShowString(1,1,"AD0:");//电位器
	OLED_ShowString(2,1,"AD1:");//红外传感
	OLED_ShowString(3,1,"AD2:");//温度传感
	OLED_ShowString(4,1,"AD3:");//对射式红外传感

	while(1)
	{
		AD0=AD_GetValue(ADC_Channel_0);
		AD1=AD_GetValue(ADC_Channel_1);
		AD2=AD_GetValue(ADC_Channel_2);
		AD3=AD_GetValue(ADC_Channel_3);
		
		OLED_ShowNum(1,5,AD0,4);
		OLED_ShowNum(2,5,AD1,4);
		OLED_ShowNum(3,5,AD2,4);
		OLED_ShowNum(4,5,AD3,4);

	}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值