诸君: 使用STM32F429,选择ADC1 PA0作为输入。 所得结果都是大于4096,求解! 另外,试了下将结果与0x0fff,屏蔽最高4位,得出了正确结果,这个是什么道理? 程序都是按照 原子F407 的程序对照修改的。 |
盘古UE-STM32F407工控板原理图
STM32F407 定时器触发DMA 求助大神
【MCU实战经验】基于STM32F407的音频播放器设计
【STM32F429心得\疑问】+STM32F4之FSMC和FMC
STM32F429读取IO口传输的数据速率
STM32F407ZGT6 手摸芯片背部重启
STM32F4 SPI 动作时,软件片选信号被拉高,IO口程序逻辑失控
STM32F401RE NUCLEO求助,串口一直不能进中断
读取STM32F407内部温度传感器值错误
STM32F429多路内部ADC独立采集的办法
* @brief ADC1 Init
* @param None
* @retval None
*/
void stm32f4xx_ADC1_Init(void)
{
/*【Step 1:定义结构体】↓----------------------------------------------------*/
GPIO_InitTypeDef GPIO_InitStructure;
ADC_CommonInitTypeDef ADC_CommonInitStructure;
ADC_InitTypeDef ADC_InitStructure;
/*【Step 1:结束】↑---------------------------------------------------------*/
/*【Step 2:开启PA口时钟和ADC1时钟,设置PA0为模拟输入】↓----------------------*/
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA,ENABLE);
RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1,ENABLE);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AN;
GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL ;//不带上下拉
GPIO_Init(GPIOA, &GPIO_InitStructure);//初始化
/*【Step 2:结束】↑---------------------------------------------------------*/
/*【Step 3:ADC1复位】↓-----------------------------------------------------*/
RCC_APB2PeriphResetCmd(RCC_APB2Periph_ADC1,ENABLE);
RCC_APB2PeriphResetCmd(RCC_APB2Periph_ADC1,DISABLE);
/*【Step 3:结束】↑---------------------------------------------------------*/
/*【Step 4:设置ADC的CCR,配置ADC输入时钟分频,模式为独立模式等】↓------------*/
ADC_CommonInitStructure.ADC_Mode = ADC_Mode_Independent;
ADC_CommonInitStructure.ADC_Prescaler = ADC_Prescaler_Div4;
ADC_CommonInitStructure.ADC_DMAAccessMode = ADC_DMAAccessMode_Disabled;
ADC_CommonInitStructure.ADC_TwoSamplingDelay = ADC_TwoSamplingDelay_5Cycles;
ADC_CommonInit(&ADC_CommonInitStructure);
/*【Step 4:结束】↑---------------------------------------------------------*/
/*【Step 5:初始化ADC1参数,设置分辨率,转换方式,对齐方式,规则序列】↓-------*/
ADC_InitStructure.ADC_Resolution = ADC_Resolution_12b;//12位模式
ADC_InitStructure.ADC_ScanConvMode = DISABLE;
ADC_InitStructure.ADC_ContinuousConvMode = DISABLE;
ADC_InitStructure.ADC_ExternalTrigConvEdge = ADC_ExternalTrigConvEdge_None;
ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;//右对齐
ADC_InitStructure.ADC_NbrOfConversion = 1;//1个转换在规则序列中 也就是只转换规则序列1
ADC_Init(ADC1, &ADC_InitStructure);//ADC初始化
/*【Step 5:结束】↑---------------------------------------------------------*/
/*【Step 6:开启AD转换器】↓-------------------------------------------------*/
ADC_Cmd(ADC1, ENABLE);
/*【Step 6:结束】↑---------------------------------------------------------*/
}
/**
* @brief 获得ADC值
* @param ADC_Channel
* @retval ADC一次转换结果数据
*/
uint16_t Get_ADC(uint8_t ADC_Channel)
{
ADC_RegularChannelConfig(ADC1,ADC_Channel,1,ADC_SampleTime_480Cycles);
ADC_SoftwareStartConv(ADC1); //使能指定的ADC1的软件转换启动功能
while(!ADC_GetFlagStatus(ADC1,ADC_FLAG_EOC))//等待转换结束
{
}
return ADC_GetConversionValue(ADC1);//返回最近一次ADC1规则组的转换结果
}
/**
* @brief 获取通道ADC_Channel的转换值,取times次,然后平均
* @param ADC_Channel,times
* @retval 平均值
*/
uint16_t Get_ADC_Average(uint8_t ADC_Channel,uint8_t times)
{
uint32_t sum=0;
uint8_t n;
for(n=0;n<times;n++)
{
sum+=Get_ADC(ADC_Channel);
Delay_ms(5);
}
return sum/times;
}
在用429,ADC没发现你说的这个问题,方便的话可以把代码贴出看看!
谢谢,程序贴在9楼。
谢谢,程序贴在9楼。