当前位置: 首页 > news >正文

STM32(十一):ADC数模转换器实验

AD单通道:

1.RCC开启GPIO和ADC时钟。配置ADCCLK分频器。

2.配置GPIO,把GPIO配置成模拟输入的模式。

3.配置多路开关,把左面通道接入到右面规则组列表里。

4.配置ADC转换器, 包括AD转换器和AD数据寄存器。单次转换,连续转换;扫描、非扫描;有几个通道,触发源是什么,数据对齐是左对齐还是右对齐。

5.ADC_CMD 开启ADC。

void RCC_ADCCLKConfig(uint32_t RCC_PCLK2); 配置ADC分频器,对APB2的时钟进行分频。

void ADC_ITConfig(ADC_TypeDef* ADCx, uint16_t ADC_IT, FunctionalState NewState);中断输出配置

void ADC_ResetCalibration(ADC_TypeDef* ADCx); 复位校准

FlagStatus ADC_GetResetCalibrationStatus(ADC_TypeDef* ADCx);获取复位校准

ITStatus ADC_GetITStatus(ADC_TypeDef* ADCx, uint16_t ADC_IT);获取标志位状态

void ADC_DiscModeChannelCountConfig(ADC_TypeDef* ADCx, uint8_t Number);配置间断模式,每隔几个通道间断一次

void ADC_DiscModeCmd(ADC_TypeDef* ADCx, FunctionalState NewState); 是否启用间断模式

void ADC_RegularChannelConfig(ADC_TypeDef* ADCx, uint8_t ADC_Channel, uint8_t Rank, uint8_t ADC_SampleTime);规则组通道配置,配置点菜菜单。

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);配置看门的通道

GPIO选择AIN,GPIO口是无效的,断开GPIO,防止GPIO口输入输出对我模拟电压造成干扰。AIN模式就是ADC的专属模式。

#include "stm32f10x.h"                  // Device headervoid AD_Init(void){RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1,ENABLE);RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);RCC_ADCCLKConfig(RCC_PCLK2_Div6);GPIO_InitTypeDef GPIO_InitStructure;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_InitTypeDef ADC_InitStruct;ADC_InitStruct.ADC_Mode=ADC_Mode_Independent;//ADC独立模式,其他选择参数都是双ADC模式了,先不学习ADC_InitStruct.ADC_DataAlign=ADC_DataAlign_Right;//数据对齐ADC_InitStruct.ADC_ContinuousConvMode=DISABLE;ADC_InitStruct.ADC_ExternalTrigConv=ADC_ExternalTrigConv_None;ADC_InitStruct.ADC_NbrOfChannel=1;//扫描模式下,会用到几个通道数目ADC_InitStruct.ADC_ScanConvMode=DISABLE;ADC_Init(ADC1,&ADC_InitStruct);ADC_Cmd(ADC1,ENABLE);//校准ADCADC_ResetCalibration(ADC1);while( ADC_GetResetCalibrationStatus(ADC1));ADC_StartCalibration(ADC1);while(ADC_GetCalibrationStatus(ADC1));}uint16_t AD_GetValue(void){ADC_SoftwareStartConvCmd(ADC1,ENABLE);while(!ADC_GetFlagStatus(ADC1,ADC_FLAG_EOC));return ADC_GetConversionValue(ADC1);}


http://www.mrgr.cn/news/22015.html

相关文章:

  • QML入门之基本元素
  • 【iOS】Masnory的简单学习
  • 业务资源管理模式语言10
  • C++ linux下的cmake
  • JAVA基础:值传递和址传递
  • anaconda3下的python编程练习-csv翻译器相关
  • STM32内部闪存FLASH(内部ROM)、IAP
  • 【牛站 / USACO2007】
  • WSL 下的 CentOS 装 Docker
  • 指针与一维数组
  • C++音视频开发笔记目录
  • 【系统架构设计师】隐式调用(事件驱动)架构
  • 从量化交易角度看,股市能做行业长期趋势的标志吗
  • 录屏新秀Top3 VS班迪录屏 ,谁更胜一筹?
  • C++——stack、queue的实现及deque的介绍
  • 【数据结构】堆——堆排序与海量TopK问题
  • 跨平台电商数据整合:item_get API在电商大数据平台中的角色
  • 魔术方法介绍
  • js window.addEventListener 是什么?
  • MVVM 基础