写这个代码主要是记录学习过程不做任何用途
/*
打开时钟
配置GPIO为模拟输入
配置多路开关
配置ADC转换器
如果需要使用ADC中断
模拟看门狗配置
配置中断 和中断优先级
开关控制
ADC校准
*/
/*
用到的函数
RCC库函数
void RCC_ADCCLKConfig(uint32_t RCC_PCLK2);
配置ADCCLK分频器的
可以对APB2的72Mhz的时钟选择2,4,6,8分频,输出到ADCCLK
ADC库函数
void ADC_Init(ADC_TypeDef* ADCx, ADC_InitTypeDef* ADC_InitStruct);
配置ADC初始化
void ADC_StructInit(ADC_InitTypeDef* ADC_InitStruct);
配置ADC结构体初始化
void ADC_DeInit(ADC_TypeDef* ADCx);
恢复缺省配置
函数功能:该函数用于关闭ADC(模数转换器)并释放其资源。它将释放ADC控制器的所有寄存器和资源,将其恢复到初始状态
void ADC_Cmd(ADC_TypeDef* ADCx, FunctionalState NewState);
用于给ADC上电(使能)
void ADC_DMACmd(ADC_TypeDef* ADCx, FunctionalState NewState);
用于开启DMA输出信号
DMA转运数据
void ADC_ITConfig(ADC_TypeDef* ADCx, uint16_t ADC_IT, FunctionalState NewState);
中断输出控制
用于控制某个中断,能不能通往NVIC
void ADC_ResetCalibration(ADC_TypeDef* ADCx);
FlagStatus ADC_GetResetCalibrationStatus(ADC_TypeDef* ADCx);
void ADC_StartCalibration(ADC_TypeDef* ADCx);
FlagStatus ADC_GetCalibrationStatus(ADC_TypeDef* ADCx);
用于控制校准的函数分别为
复位校准 ,获取复位校准状态
开始校准 , 获取开始校准状态
(ADC初始化完成后调用)
void ADC_SoftwareStartConvCmd(ADC_TypeDef* ADCx, FunctionalState NewState);
用于ADC软件开始转换控制,就是软件触发ADC函数,调用一下就可以软件触发转换
FlagStatus ADC_GetSoftwareStartConvStatus(ADC_TypeDef* ADCx);
获取ADC软件开始转换状态(不可以用于判断转换是否完成)没啥大用
FlagStatus ADC_GetFlagStatus(ADC_TypeDef* ADCx, uint8_t ADC_FLAG);
获取标志位状态 参数给ECO的标志位,判断ECO是否置1了
转换完成EXO标志位置1;否则为0;
void ADC_ClearFlag(ADC_TypeDef* ADCx, uint8_t ADC_FLAG);
清除标志位
ITStatus ADC_GetITStatus(ADC_TypeDef* ADCx, uint16_t ADC_IT);
获取中断状态
void ADC_ClearITPendingBit(ADC_TypeDef* ADCx, uint16_t ADC_IT);
获取中断挂起位
void ADC_DiscModeChannelCountConfig(ADC_Typ eDef* ADCx, uint8_t Number);
void ADC_DiscModeCmd(ADC_TypeDef* ADCx, FunctionalState NewState);
用于配置间断模式
1 : 每隔几个通道间断一次
2 : 是不是启用间断模式
void ADC_RegularChannelConfig(ADC_TypeDef* ADCx, uint8_t ADC_Channel, uint8_t Rank, uint8_t ADC_SampleTime);
ADC规则组通道配置(重点)
参数2 : ADC_Channel ,你想指定的通道
参数3 : Rank, 序列几的位置
参数4 : ADC_SampleTime , 指定通道的采样时间
void ADC_ExternalTrigConvCmd(ADC_TypeDef* ADCx, FunctionalState NewState);
ADC外部触发转换控制 , 是否允许外部触发转换
uint16_t ADC_GetConversionValue(ADC_TypeDef* ADCx);
ADC获取转换值(重点)
uint32_t ADC_GetDualModeConversionValue(void);
ADC获取双模式转换值(双ADC模式)
void ADC_AutoInjectedConvCmd(ADC_TypeDef* ADCx, FunctionalState NewState);
void ADC_InjectedDiscModeCmd(ADC_TypeDef* ADCx, FunctionalState NewState);
void ADC_ExternalTrigInjectedConvConfig(ADC_TypeDef* ADCx, uint32_t ADC_ExternalTrigInjecConv);
void ADC_ExternalTrigInjectedConvCmd(ADC_TypeDef* ADCx, FunctionalState NewState);
void ADC_SoftwareStartInjectedConvCmd(ADC_TypeDef* ADCx, FunctionalState NewState);
FlagStatus ADC_GetSoftwareStartInjectedConvCmdStatus(ADC_TypeDef* ADCx);
void ADC_InjectedChannelConfig(ADC_TypeDef* ADCx, uint8_t ADC_Channel, uint8_t Rank, uint8_t ADC_SampleTime);
void ADC_InjectedSequencerLengthConfig(ADC_TypeDef* ADCx, uint8_t Length);
void ADC_SetInjectedOffset(ADC_TypeDef* ADCx, uint8_t ADC_InjectedChannel, uint16_t Offset);
uint16_t ADC_GetInjectedConversionValue(ADC_TypeDef* ADCx, uint8_t ADC_InjectedChannel);
这些函数用来配置注入组 里面都有Injected
void ADC_AnalogWatchdogCmd(ADC_TypeDef* ADCx, uint32_t ADC_AnalogWatchdog);
void ADC_AnalogWatchdogThresholdsConfig(ADC_TypeDef* ADCx, uint16_t HighThreshold, uint16_t LowThreshold);
void ADC_AnalogWatchdogSingleChannelConfig(ADC_TypeDef* ADCx, uint8_t ADC_Channel);
这些配置模拟看门狗
1: 是否启动看门狗
2: 配置高低阈值
3: 配置看门狗通道
void ADC_TempSensorVrefintCmd(FunctionalState NewState);
ADC通道温度传感器,内部电压参考配置
用于开启内部的两个通道的(不开读不到正确值)
ADC_InitStructure.ADC_Mode
#define ADC_Mode_Independent 独立模式
#define ADC_Mode_RegInjecSimult
#define ADC_Mode_RegSimult_AlterTrig
#define ADC_Mode_InjecSimult_FastInterl
#define ADC_Mode_InjecSimult_SlowInterl
#define ADC_Mode_InjecSimult
#define ADC_Mode_RegSimult
#define ADC_Mode_FastInterl
#define ADC_Mode_SlowInterl
#define ADC_Mode_AlterTrig
后面的和双ADC模式有关
//配置外部触发源
#define ADC_ExternalTrigConv_None 不使用外部触发使用内部触发就是软件触发
以是库函数详解
下面程序 ()
void AD_Init(void)
{
GPIO_InitTypeDef GPIO_InitStructure;//初始化采集ADC的脚
ADC_InitTypeDef ADC_InitStructure;//配置ADC结构体
RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1,ENABLE);//开启ADC时钟
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);//开启GPIOA时钟
//不要忘记配置ADCCLK时钟预分频
RCC_ADCCLKConfig(RCC_PCLK2_Div6);//配置ADC时钟预分频 ADCCLK=72Mhz/6=12Mhz
//配置模拟输入引脚
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;//配置成模拟输入模式
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0; //选择引脚
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;// 配置引脚速率
GPIO_Init(GPIOA,&GPIO_InitStructure);
//配置规则组
ADC_RegularChannelConfig(ADC1,ADC_Channel_0,1,ADC_SampleTime_55Cycles5);
//配置ADC结构体初始化
ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;//配置ADC模式是双通道模式还是单通道模式
ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;//数据对齐模式 右对齐
ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None ; //外部触发转换选择就是触发控制的触发源 , 使用内部触发(软件触发 )
ADC_InitStructure.ADC_ContinuousConvMode = DISABLE; //连续转换模式,可以选择是连续转换还是单次转换 DISABLE单次模式 ENABLE连续模式
ADC_InitStructure.ADC_NbrOfChannel = 1; //通道数目,在指定扫描模式下,总共会用到几个通道
ADC_InitStructure.ADC_ScanConvMode = DISABLE; //扫描转换模式,可以选择是扫描模式还是非扫描模式 DISABLE非扫描模式, ENABLE扫描模式
ADC_Init(ADC1,&ADC_InitStructure);
//开启ADC电源
ADC_Cmd(ADC1,ENABLE);
//开始ADC校准
ADC_ResetCalibration(ADC1); //开始复位校准 ,标志位置1硬件清零
while(ADC_GetCalibrationStatus(ADC1)==SET); //判断校准标志位置是否为 ,为0校准完成
ADC_StartCalibration(ADC1); //开始校准
while(ADC_GetCalibrationStatus(ADC1)==SET);//判断是否结束校准
}
uint16_t AD_GetValue(void)
{
ADC_SoftwareStartConvCmd(ADC1,ENABLE);//开始ADC转换
while(ADC_GetFlagStatus(ADC1,ADC_FLAG_EOC) == RESET);//判断标志位转换是否完成
return ADC_GetConversionValue(ADC1);//读取数据后会自动清除转换完成标志位
}