想在进行AD转换时,ADC_Channel_0用规则通道1,ADC_Channel_1用规则通道2,通过这样的方式来
进行多通道的转换,可是转换的结果总是ADC_Channel_0的结果。
(没有用DMA)
主要的程序如下
void ADC_init()
{
ADC_InitTypeDef ADC_InitStructure;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1,ENABLE);
RCC_ADCCLKConfig(RCC_PCLK2_Div6);//配置ADC时钟分频
ADC_DeInit(ADC1);//ADC时钟复位
ADC_InitStructure.ADC_Mode=ADC_Mode_Independent;//设置ADC工作模式为独立模式
ADC_InitStructure.ADC_ScanConvMode=ENABLE;//
ADC_InitStructure.ADC_ContinuousConvMode=DISABLE;
ADC_InitStructure.ADC_ExternalTrigConv=ADC_ExternalTrigConv_None;//转换由软件触发启动而不是由外部触发启动
ADC_InitStructure.ADC_DataAlign=ADC_DataAlign_Right;//ADC数据右对齐
ADC_InitStructure.ADC_NbrOfChannel=2;//顺序进行规制转换的ADC通道的数目
ADC_Init(ADC1,&ADC_InitStructure);//根据指定的参数初始化外设ADC1
ADC_Cmd(ADC1,ENABLE);//使能指定的ADC
/*必须有这一部分,否则AD转换会不准确*/
ADC_ResetCalibration(ADC1);//执行复位校准
while(ADC_GetResetCalibrationStatus(ADC1));//等待复位校准的结束
ADC_StartCalibration(ADC1);//执行ADC校准
while(ADC_GetCalibrationStatus(ADC1));//等待校AD准结束
}
u16 getvalue1(u8 ch)
{
ADC_RegularChannelConfig(ADC1,ch,1,ADC_SampleTime_239Cycles5);
ADC_SoftwareStartConvCmd(ADC1,ENABLE);
while(!ADC_GetFlagStatus(ADC1,ADC_FLAG_EOC));
return ADC_GetConversionValue(ADC1);
}
u16 getvalue2(u8 ch)
{
ADC_RegularChannelConfig(ADC1,ch,2,ADC_SampleTime_239Cycles5);
ADC_SoftwareStartConvCmd(ADC1,ENABLE);
while(!ADC_GetFlagStatus(ADC1,ADC_FLAG_EOC));
return ADC_GetConversionValue(ADC1);
}
int main()
{
float value;
delay_init();
setgpio_init();
ADC_init();
usart_init(9600);
printf("\r\nThe AD_value is:-----------\r\n");
while(1)
{
value=3.3*getvalue1(ADC_Channel_0)/0x0fff;
printf("The channel_0 current VolValue=%.2fv\r\n",value);
value=3.3*getvalue2(ADC_Channel_1)/0x0fff;
printf("The channel_1 current VolValue=%.2fv\r\n",value);
delay_ms(1000);
delay_ms(1000);
delay_ms(1000);
}
}
|