利用CubeMX和STM32H750VBT6配置ADC监测电压(新手教程)

本文详细描述了如何在STM32H750VBT6开发板上进行TIM1定时器配置,包括内部时钟源选择、PWM生成及参数设置,以及ADC的配置,涉及SYSTick、GPIO、DMA和NVIC的初始化,以及串口通信和ADC数据采集的处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

(一)开发板

我选择的开发板是STM32H750VBT6,直接在cubemx上找就可以:

(二)时钟配置

首先配置Timers里面的TIM1

(1)Clock Source设置为Internal  Clock

(2)Channel1设置为PWM Generation No Output

(3)下面Parameter如图:

(三)SySterm Core配置

(1)RCC(复位和时钟配置)

注意:Product revision选择rev.V

(2)关掉这个

3)GPIO

(4)DMA

(5)NVIC

(四)ADC配置

如图:配置IN5和Date Width

(五)串口通信配置

(六)板子效果

板子配置成这样之后可以回去看看(三)之中的部分了

(七)时钟配置

(八)文件配置

文件名不要包含中文

点击GENERATE CODE(右上角)

可能有点久,耐心等待(要先登录啊)

(九)代码配置

点击Open project

千万先配置这个,不然printf没输出

(1)整体效果

/* USER CODE BEGIN Header */
/**
  ******************************************************************************
  * @file           : main.c
  * @brief          : Main program body
  ******************************************************************************
  * @attention
  *
  * Copyright (c) 2024 STMicroelectronics.
  * All rights reserved.
  *
  * This software is licensed under terms that can be found in the LICENSE file
  * in the root directory of this software component.
  * If no LICENSE file comes with this software, it is provided AS-IS.
  *
  ******************************************************************************
  */
/* USER CODE END Header */
/* Includes ------------------------------------------------------------------*/
#include "main.h"
#include "adc.h"
#include "dma.h"
#include "tim.h"
#include "usart.h"
#include "gpio.h"

/* Private includes ----------------------------------------------------------*/
/* USER CODE BEGIN Includes */
#include "stdio.h"
#include "string.h"

/* USER CODE END Includes */

/* Private typedef -----------------------------------------------------------*/
/* USER CODE BEGIN PTD */
#define ADC_DATA_LENGHT 1000  //定义采集数据长度为1000
uint32_t adcl_datal[ADC_DATA_LENGHT];//定义adc采集存放数组
uint8_t adc_dma_complete_flag=0;//adc数据采集完成标志

/* USER CODE END PTD */

/* Private define ------------------------------------------------------------*/
/* USER CODE BEGIN PD */
// 重定向printf
int fputc(int ch, FILE *f){
	HAL_UART_Transmit(&huart4, (uint8_t *)&ch, 1, 1000);	
	return ch;
}

// 重定向getchar
int fgetc(FILE *f)
{
	int ch;
	while (__HAL_UART_GET_FLAG(&huart4, UART_FLAG_RXNE) == RESET);
	HAL_UART_Receive(&huart4, (uint8_t *)&ch, 1, 0xFFFF);
	return (ch);
}


/* USER CODE END PD */

/* Private macro -------------------------------------------------------------*/
/* USER CODE BEGIN PM */

/* USER CODE END PM */

/* Private variables ---------------------------------------------------------*/

/* USER CODE BEGIN PV */

/* USER CODE END PV */

/* Private function prototypes -----------------------------------------------*/
void SystemClock_Config(void);
/* USER CODE BEGIN PFP */

/* USER CODE END PFP */

/* Private user code ---------------------------------------------------------*/
/* USER CODE BEGIN 0 */
void HAL_ADC_ConvCpltCallback(ADC_HandleTypeDef *hadc)//ADC回调函数
{
   if(hadc->Instance==ADC1)
	 {
		 adc_dma_complete_flag=2;//采集完成标志
		
	 }

}



void HAL_ADC_ConvHalfCpltCallback(ADC_HandleTypeDef *hadc)//ADC回调函数
{
   if(hadc->Instance==ADC1)
	 {
		 adc_dma_complete_flag=1;//采集完成标志
	
	 }

}




/* USER CODE END 0 */

/**
  * @brief  The application entry point.
  * @retval int
  */
int main(void)
{
  /* USER CODE BEGIN 1 */

  /* USER CODE END 1 */

  /* MCU Configuration--------------------------------------------------------*/

  /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  HAL_Init();

  /* USER CODE BEGIN Init */

  /* USER CODE END Init */

  /* Configure the system clock */
  SystemClock_Config();

  /* USER CODE BEGIN SysInit */

  /* USER CODE END SysInit */

  /* Initialize all configured peripherals */
  MX_GPIO_Init();
  MX_DMA_Init();
  MX_ADC1_Init();
  MX_TIM1_Init();
  MX_UART4_Init();
  /* USER CODE BEGIN 2 */
	HAL_ADCEx_Calibration_Start(&hadc1,ADC_CALIB_OFFSET,ADC_SINGLE_ENDED);//校准函数
	HAL_TIM_Base_Start(&htim1);
HAL_ADC_Start_DMA(&hadc1,adcl_datal,ADC_DATA_LENGHT);//ADC的dma开始采集
  /* USER CODE END 2 */

  /* Infinite loop */
  /* USER CODE BEGIN WHILE */
  while (1)
  {
		
    /* USER CODE END WHILE */

    /* USER CODE BEGIN 3 */
		printf("hello");
    HAL_Delay(200);
		if(adc_dma_complete_flag==1)//半程采集后发送
		{ 
			 int i;
       for(i=0;i<1000;i++)
			{

				printf("%d\r\n",adcl_datal[i]&0x0000ffff);
			}
			adc_dma_complete_flag=0;
			memset(adcl_datal,0,ADC_DATA_LENGHT);
			
		}
		
			if(adc_dma_complete_flag==2)//全程采集后发送
		{ 
			 int i;
       for(i=0;i<1000;i++)
			{

				printf("%d\r\n",adcl_datal[i]&0x0000ffff);
			}
			adc_dma_complete_flag=0;
			memset(adcl_datal,0,ADC_DATA_LENGHT);//清空数组中数据
		
		}
		
		HAL_Delay(100);
  }
  /* USER CODE END 3 */
}

/**
  * @brief System Clock Configuration
  * @retval None
  */
void SystemClock_Config(void)
{
  RCC_OscInitTypeDef RCC_OscInitStruct = {0};
  RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};

  /** Supply configuration update enable
  */
  HAL_PWREx_ConfigSupply(PWR_LDO_SUPPLY);

  /** Configure the main internal regulator output voltage
  */
  __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1);

  while(!__HAL_PWR_GET_FLAG(PWR_FLAG_VOSRDY)) {}

  __HAL_RCC_SYSCFG_CLK_ENABLE();
  __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE0);

  while(!__HAL_PWR_GET_FLAG(PWR_FLAG_VOSRDY)) {}

  /** Initializes the RCC Oscillators according to the specified parameters
  * in the RCC_OscInitTypeDef structure.
  */
  RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;
  RCC_OscInitStruct.HSEState = RCC_HSE_ON;
  RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
  RCC_OscInitStruct.PLL.PLLM = 5;
  RCC_OscInitStruct.PLL.PLLN = 192;
  RCC_OscInitStruct.PLL.PLLP = 2;
  RCC_OscInitStruct.PLL.PLLQ = 2;
  RCC_OscInitStruct.PLL.PLLR = 2;
  RCC_OscInitStruct.PLL.PLLRGE = RCC_PLL1VCIRANGE_2;
  RCC_OscInitStruct.PLL.PLLVCOSEL = RCC_PLL1VCOWIDE;
  RCC_OscInitStruct.PLL.PLLFRACN = 0;
  if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
  {
    Error_Handler();
  }

  /** Initializes the CPU, AHB and APB buses clocks
  */
  RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
                              |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2
                              |RCC_CLOCKTYPE_D3PCLK1|RCC_CLOCKTYPE_D1PCLK1;
  RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  RCC_ClkInitStruct.SYSCLKDivider = RCC_SYSCLK_DIV1;
  RCC_ClkInitStruct.AHBCLKDivider = RCC_HCLK_DIV2;
  RCC_ClkInitStruct.APB3CLKDivider = RCC_APB3_DIV2;
  RCC_ClkInitStruct.APB1CLKDivider = RCC_APB1_DIV2;
  RCC_ClkInitStruct.APB2CLKDivider = RCC_APB2_DIV2;
  RCC_ClkInitStruct.APB4CLKDivider = RCC_APB4_DIV2;

  if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_4) != HAL_OK)
  {
    Error_Handler();
  }
}

/* USER CODE BEGIN 4 */

/* USER CODE END 4 */

/**
  * @brief  This function is executed in case of error occurrence.
  * @retval None
  */
void Error_Handler(void)
{
  /* USER CODE BEGIN Error_Handler_Debug */
  /* User can add his own implementation to report the HAL error return state */
  __disable_irq();
  while (1)
  {
  }
  /* USER CODE END Error_Handler_Debug */
}

#ifdef  USE_FULL_ASSERT
/**
  * @brief  Reports the name of the source file and the source line number
  *         where the assert_param error has occurred.
  * @param  file: pointer to the source file name
  * @param  line: assert_param error line source number
  * @retval None
  */
void assert_failed(uint8_t *file, uint32_t line)
{
  /* USER CODE BEGIN 6 */
  /* User can add his own implementation to report the file name and line number,
     ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
  /* USER CODE END 6 */
}
#endif /* USE_FULL_ASSERT */

### 微信小程序跳转链接的构造方式 在微信小程序开发中,通过不同的API可以实现多种类型的页面跳转功能。以下是关于如何构建微信小程序跳转链接的具体说明: #### 1. 构建小程序内部页面跳转 当需要从小程序的一个页面跳转到另一个页面时,可使用 `wx.navigateTo` 或其他类似的导航函数。其基本语法如下: ```javascript wx.navigateTo({ url: '/pages/index/index' }); ``` 这里的 `url` 参数指定了目标页面的路径,需以 `/` 开头并省略 `.js` 后缀[^1]。 如果需要传递参数,则可以在 URL 中附加查询字符串形式的数据: ```javascript wx.navigateTo({ url: '/pages/detail/detail?id=123&name=test' }); ``` #### 2. 跳转至外部网页 对于跳转到非小程序内的外部网页场景,目前官方并不支持直接打开外链地址。通常的做法是引导用户通过浏览器访问该网址。 #### 3. 实现跨小程序间的跳转 为了完成从当前小程序跳转至另一独立的小程序操作,应采用 `wx.navigateToMiniProgram` 方法。此方法要求提供被跳转小程序的应用 ID (`appId`) 及具体的目标页面路径(`path`)等必要信息。例如: ```javascript wx.navigateToMiniProgram({ appId: 'wx1234123123', path: 'pages/index/index?phone=' + wx.getStorageSync('phone'), envVersion: 'release', success(res) { console.log("跳转成功"); } }); ``` 上述代码片段展示了向指定小程序发送带有额外参数请求的过程[^4]。 #### 4. 特殊情况下的处理——调用微信内置服务页 除了普通的页面切换之外,有时还需要进入一些特定的服务界面,像地图查看器或者视频播放窗口之类的原生模块。这类需求可通过集成相应的组件或利用专门设计好的接口达成目的。 --- ### 示例代码展示 下面给出一段综合性的例子用于演示不同种类的跳转逻辑: ```javascript function navigateExample() { const phone = "123456789"; // 内部页面跳转 wx.navigateTo({ url: '/pages/user/profile' }); // 外部网站重定向 (仅限于H5嵌套模式下有效) /* 不推荐做法 */ /* wx.navigateTo({ url: 'https://www.example.com/' }); */ // 到达另一个小程序实例 wx.navigateToMiniProgram({ appId: 'wx1234123123', path: `pages/contact/contact?number=${encodeURIComponent(phone)}`, envVersion: 'develop', success() {} }); } ```
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值