STM32基础11--模数转换(ADC)

目录

前言

ADC框图

ADC测量的硬件电路

功能需求

STM32CubeMx配置ADC

功能代码实现


前言


        在做51单片机项目时,如果需要对外围电路进行电压测量时,往往会在51单片机上面外挂一个ADC转换芯片(例如ADC0809)。但在STM32F407中,不再需要这么干了,因为在STM32的内部就已经集成了ADC电路。

        STM32中有3个最高分辨率为12 位 ADC 是逐次趋近型模数转换器。它具有多达 19 个复用通道,可测量来自 16 个外部 源、两个内部源和 VBAT 通道的信号。这些通道的 A/D 转换可在单次、连续、扫描或不连续 采样模式下进行。ADC 的结果存储在一个左对齐或右对齐的 16 位数据寄存器中。

       注:虽然有3个ADC,它们的引脚复用的。也就是它们有的IN脚有些是两个ADC或者3个ADC同时拥有的。下图查找ADC可以看到,并没有3*16 = 48个ADC输入引脚。

 

ADC框图

        框图中1部分是模式转换外部控制;

        框图中2部分是模拟输入通道;

        框图中3部分是模式转换;

        框图中4部分是与ADC转换相关的中断。

ADC测量的硬件电路

        ADC最高的测量电压为3.3V,不要ADC模拟输入端,不要接入超过3.3V的电压。否则可能会烧坏STM32芯片。

        PA5(ADC1或者ADC2的模拟通道5)连接到TPAD,上面的电压大概只有3V。

 

 

 

功能需求

        1)使用ADC1的模拟通道5,轮询的方式测量TPAD上的电压;

        2)测量的电压值通过串口发送到PC端

STM32CubeMx配置ADC

选择ADC与模拟通道

 

ADC参数设置

 

 

功能代码实现

 STM32CubeMx生成初始化代码

/* ADC1 init function */
void MX_ADC1_Init(void)
{

  /* USER CODE BEGIN ADC1_Init 0 */

  /* USER CODE END ADC1_Init 0 */

  ADC_ChannelConfTypeDef sConfig = {0};

  /* USER CODE BEGIN ADC1_Init 1 */

  /* USER CODE END ADC1_Init 1 */

  /** Configure the global features of the ADC (Clock, Resolution, Data Alignment and number of conversion)
  */
  hadc1.Instance = ADC1;
  hadc1.Init.ClockPrescaler = ADC_CLOCK_SYNC_PCLK_DIV4;
  hadc1.Init.Resolution = ADC_RESOLUTION_12B;
  hadc1.Init.ScanConvMode = DISABLE;
  hadc1.Init.ContinuousConvMode = DISABLE;
  hadc1.Init.DiscontinuousConvMode = DISABLE;
  hadc1.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;
  hadc1.Init.ExternalTrigConv = ADC_SOFTWARE_START;
  hadc1.Init.DataAlign = ADC_DATAALIGN_RIGHT;
  hadc1.Init.NbrOfConversion = 1;
  hadc1.Init.DMAContinuousRequests = DISABLE;
  hadc1.Init.EOCSelection = ADC_EOC_SINGLE_CONV;
  if (HAL_ADC_Init(&hadc1) != HAL_OK)
  {
    Error_Handler();
  }

  /** Configure for the selected ADC regular channel its corresponding rank in the sequencer and its sample time.
  */
  sConfig.Channel = ADC_CHANNEL_5;
  sConfig.Rank = 1;
  sConfig.SamplingTime = ADC_SAMPLETIME_3CYCLES;
  if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
  {
    Error_Handler();
  }
  /* USER CODE BEGIN ADC1_Init 2 */

  /* USER CODE END ADC1_Init 2 */

}

 

 自定义变量

 

  ADC测量代码

        //led_key_ctl();
       HAL_ADC_Start(&hadc1);  
       HAL_ADC_PollForConversion(&hadc1, 200);

       
       if(HAL_IS_BIT_SET(HAL_ADC_GetState(&hadc1), HAL_ADC_STATE_REG_EOC))

      {

          /*##-3- Get the converted value of regular channel  ######################*/

         AD_Value = HAL_ADC_GetValue(&hadc1);
         printf("AD_Value = %d \r\n",AD_Value);
         sprintf(str,"TAPD Voltag : %f \r\n",(float)((AD_Value*3.3)/4096));
         HAL_UART_Transmit(&huart1,(uint8_t *)str,strlen((const char *)str),100);

      }
    
      HAL_Delay(1000);

        注:

        1)该代码中有使用了printf函数,默认STM32是不可以通过printf发送数据到PC端的,需要将printf重定向才可以。如果想实现该功能可以参考 下面这篇文章的最后一部分,实现printf的重定向STM32基础9--串口通信(UART)icon-default.png?t=M3K6https://blog.csdn.net/qq_34343637/article/details/124529478

         2)本文例子中没有使用到中断,如果ADC检测完后触发中断,可以重写中断中的回调函数。

 

  • 4
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

颖川初尘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值