CubeMX配置STM32的ADC
包含阻塞式和非阻塞式以及多通道ADC
1、单通道ADC
单通道的配置比较简单,需要注意的是需要中断的使能 ,因为在使用非阻塞式的函数时需要使用到中断。其它的设置默认就行
2、多通道ADC
多通道的CubeMX的配置稍复杂些
3、有关ADC的一些函数
阻塞式:
HAL_ADC_Start(ADC_HandleTypeDef* hadc);
HAL_ADC_Stop(ADC_HandleTypeDef* hadc);
HAL_ADC_PollForConversion(ADC_HandleTypeDef* hadc, uint32_t Timeout);
非阻塞式:
HAL_ADC_Start_IT(ADC_HandleTypeDef* hadc);
HAL_ADC_Stop_IT(ADC_HandleTypeDef* hadc);
HAL_ADC_ConvCpltCallback(ADC_HandleTypeDef* hadc);
1、单通道阻塞式
void ADC0_Get_Value()
{
HAL_ADC_Start(&hadc1);
if(HAL_ADC_PollForConversion(&hadc1,10)==HAL_OK)
{
ADC_Value = HAL_ADC_GetValue(&hadc1);
ADC_Volt = ADC_Value * 330 / 4096;
}
printf("采样值:%d,电压值%d.%d%dV\r\n",ADC_Value,ADC_Volt/100,(ADC_Volt%100)/10,ADC_Volt%10);
HAL_ADC_Stop(&hadc1);
}
函数的使用方法如上代码所示,我就不细说了,这里我是把它直接放在一个我自己写的函数里面的,放出来效果是一样的。 对了ADC的分辨率=量程/2的n次方 ,在STM32里面大部分是使用的12次方,所以是除以4096。
2、单通道非阻塞式
HAL_ADC_Start_IT(&hadc1);
重写回调函数
void HAL_ADC_ConvCpltCallback(ADC_HandleTypeDef* hadc)
{
if(hadc->Instance == ADC1)
{
ADC_Value = HAL_ADC_GetValue(&hadc1);
ADC_Volt = ADC_Value * 330 / 4096;
printf("采样值:%d,电压值%d.%d%dV\r\n",ADC_Value,ADC_Volt/100,(ADC_Volt%100)/10,ADC_Volt%10);
LED_OFF();
}
}
非阻塞式具体函数使用方法如上。
3、多通道阻塞式
值得注意的是在多通道里面,第一此启用一次ADC的转换是采的第一个通道的(我这里的第一个通道就是channel0);然后是第二个通道(channel1);第三次采就又回到了第一个通道(channel0)依次类推。 这里我写了个ADC各通道的转换,就是所以都采了一遍,然后用数组来存。
uint16_t adc1_value[30];
void ADC_channel(uint8_t num)
{
int i=0;
for(i=0;i<num;i++)
{
HAL_ADC_Start(&hadc1);
HAL_ADC_PollForConversion(&hadc1,50);
adc1_value[i]=HAL_ADC_GetValue(&hadc1);
printf("%d ", adc1_value[i]);
}
HAL_ADC_Stop(&hadc1);
printf("\r\n");
}
4、多通道非阻塞式
这个我也不知道怎么用,我写出来的全是有问题的,如果有哪位同学知道可以联系我教我一下。
如果有错误欢迎指正哦。 差点忘了我学习这个东西就是想用上买的一个游戏拓展板(JoyStick ShieldV1.A) ,但是商家没提供原理图,网上也没找到,就到处找资料自己花了一张图片(至少可以看出哪些对应哪个引脚了)。 还有,买这个千万别贪便宜,我贪便宜买回来这个摇杆的质量特别差,稍微碰一点点就变成0或者3.3V了。
|