首先进行ADC简要介绍,接下主要讲解ADC实验
ADC介绍:
ADC:模/数转换器,将连续变量的模拟信号转化为离散的数字信号的器件
DAC:数/模转换器,将离散的数字信号的器件转化为连续变量的模拟变量的器件
STM32F10x ADC主要特点:
1. 12位逐次逼近型的模拟数字转换器
2.ADC转换时间:最大转换速率 1us。(最大转换速度为1MHz,在ADCCLK=14M,采样周期为1.5个ADC时钟下得到)
3. 最多支持18个通道,可最多测量16个外部和2个内部信号源
4. 转换结果支持左对齐或右对齐方式存储在16位数据寄存器
5. ADC供电要求:2.4V-3.6V (测试或连接不要超过3.6V,易烧坏ADC)
规则中断:相当正常运行的程序
注入中断:相当于中断
STM32F1的ADC的各通道可以单次,连续,扫描或者间断模式执行。
单次转化:ADC只执行一次转换
连续转换:当前面的ADC转换一结束马上启动下一次ADC转换
扫描模式:用于扫描一组模拟通道
间断模式:规则和注入组转换结束时能产生中断,都有中断的独立使能位
ADC通道和引脚对应关系:
ADC框图:
常用函数:
- ADC初始化函数ADC_Init( )
- ADC使能函数 ADC_Cmd( )
- ADC使能软件转换函数 ADC_SoftwareStartConvCmd( )
- ADC 规则通道配置函数ADC_RegularChannelConfig( )
实验目的:ADC1的通道1(PA1)进行单次转化
1.开启PA口时钟和ADC1时钟,设置PA1为模拟输入 GPIO_Init(); APB2PeriphClockCmd()
2.复位ADC1,同时设置ADC1分频因子
RCC_ADCCLKConfig(RCC_PCLK2_Div6);ADC_DeInit(ADC1)
3. 初始化ADC1参数,设置ADC1的工作模式以及规则序列的相关信息
Void ADC_Init(ADC_TypeDef* ADCx, ADC_InitTypeDef* ADC_InitStruct)
4.使能ADC并校准。ADC_Cmd(ADC1, ENABLE)
5.配置规则通道参数: ADC_RegularChannelConfig()
6.开启软件转换:ADC_SoftwareStartConvCmd(ADC1)
7.等待转换完成,读取ADC值。 ADC_GetConversionValue(ADC1)
代码实现:
adc.c:
void Adc_Init(void)
{
ADC_InitTypeDef ADC_InitStructure;
GPIO_InitTypeDef GPIO_InitStructure;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA |RCC_APB2Periph_ADC1 , ENABLE ); //使能ADC1通道时钟
RCC_ADCCLKConfig(RCC_PCLK2_Div6); //设置ADC分频因子6 72M/6=12,ADC最大时间不能超过14M
//PA1 作为模拟通道输入引脚
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN; //模拟输入引脚
GPIO_Init(GPIOA, &GPIO_InitStructure);
ADC_DeInit(ADC1); //复位ADC1
ADC_InitStructure.ADC_Mode = ADC_Mode_Independent; //ADC工作模式:ADC1和ADC2工作在独立模式
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数据右对齐
ADC_InitStructure.ADC_NbrOfChannel = 1; //顺序进行规则转换的ADC通道的数目
ADC_Init(ADC1, &ADC_InitStructure); //根据ADC_InitStruct中指定的参数初始化外设ADCx的寄存器
ADC_Cmd(ADC1, ENABLE); //使能指定的ADC1
ADC_ResetCalibration(ADC1); //使能复位校准
while(ADC_GetResetCalibrationStatus(ADC1)); //等待复位校准结束
ADC_StartCalibration(ADC1); //开启AD校准
while(ADC_GetCalibrationStatus(ADC1)); //等待校准结束
// ADC_SoftwareStartConvCmd(ADC1, ENABLE); //使能指定的ADC1的软件转换启动功能
}
//获得ADC值
//ch:通道值 0~3
u16 Get_Adc(u8 ch)
{
//设置指定ADC的规则组通道,一个序列,采样时间
ADC_RegularChannelConfig(ADC1, ch, 1, ADC_SampleTime_239Cycles5 ); //ADC1,ADC通道,采样时间为239.5周期
ADC_SoftwareStartConvCmd(ADC1, ENABLE); //使能指定的ADC1的软件转换启动功能
while(!ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC ));//等待转换结束
return ADC_GetConversionValue(ADC1); //返回最近一次ADC1规则组的转换结果
}
main.c:
int main(void)
{
u16 adcx;
float temp;
delay_init(); //延时函数初始化
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//设置中断优先级分组为组2:2位抢占优先级,2位响应优先级
uart_init(115200); //串口初始化为115200
LCD_Init();
Adc_Init(); //ADC初始化
POINT_COLOR=RED;//设置字体为红色
LCD_ShowString(60,50,200,16,16,"WarShip STM32");
LCD_ShowString(60,70,200,16,16,"ADC TEST");
LCD_ShowString(60,90,200,16,16,"ATOM@ALIENTEK");
LCD_ShowString(60,110,200,16,16,"2015/1/14");
//显示提示信息
POINT_COLOR=BLUE;//设置字体为蓝色
LCD_ShowString(60,130,200,16,16,"ADC_CH0_VAL:");
LCD_ShowString(60,150,200,16,16,"ADC_CH0_VOL:0.000V");
while(1)
{
adcx=Get_Adc_Average(ADC_Channel_1,10);
LCD_ShowxNum(156,130,adcx,4,16,0);//显示ADC的值
temp=(float)adcx*(3.3/4096);
adcx=temp;
LCD_ShowxNum(156,150,adcx,1,16,0);//显示电压值
temp-=adcx;
temp*=1000;
LCD_ShowxNum(172,150,temp,3,16,0X80);
delay_ms(250);
}
}
实验效果:
PA1分别与GND和3.3V相接,注意不要解5V,容易将ADC烧坏。