基于hal库与硬石stm32f1开发板实现光敏传感器控制led亮度

工程所用到的开发板为硬石的YS_F1Pro型号,芯片是stm32f103zet6

思路:通过adc读取光敏传感器的阻值,利用pwm进行亮度调节

根据原理图,光敏传感器接PC1(板子上已用跳线帽连接),led1接PB0

 

 

首先使用CubeMX配置工程,重点讲adc与pwm部分。

将PC1引脚设置成ADC1_IN11,打开Continuous Conversion Mode,adc设置完成

 PB0设置成TIM3_CH3, 通道3选择pwm模式,设置预分频系数为72,即pwm频率为72MHz(时钟周期)/72=1MHz,计数周期设置成500,计数值Pluse暂时设置为0,根据Pluse的大小可以改变led的亮度,pwm占空比为计数周期/Pluse,Pluse越大灯越亮,最大值为计数周期500

生成代码后再main函数里打开pwm,使用 

HAL_TIM_PWM_Start(&htim3, TIM_CHANNEL_3);

打开adc并读取adc转换出来的值

HAL_ADC_Start(&hadc1);
adc_vol = HAL_ADC_GetValue(&hadc1);

将adc读出的值赋值给pwm,除5是因为最大计数周期为500,前面通过串口打印发现光敏电阻值在0~2500之间变化,故缩小成1/5

__HAL_TIM_SetCompare(&htim3, TIM_CHANNEL_3, (adc_vol/5));

相关完整代码如下

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_USART1_UART_Init();
  MX_TIM3_Init();
  MX_ADC1_Init();
  /* USER CODE BEGIN 2 */
	HAL_TIM_PWM_Start(&htim3, TIM_CHANNEL_3);
	printf("running\r\n");
  /* USER CODE END 2 */

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

    /* USER CODE BEGIN 3 */
	  Get_ADC_Sample();
	  __HAL_TIM_SetCompare(&htim3, TIM_CHANNEL_3, (adc_vol/5));
	  HAL_Delay(500);
  }
  /* USER CODE END 3 */
}
uint16_t adc_vol=0;

void Get_ADC_Sample(void)
{
	HAL_ADC_Start(&hadc1);
	if(HAL_ADC_PollForConversion(&hadc1,10) == HAL_OK)
	{
		adc_vol = HAL_ADC_GetValue(&hadc1);
	}
	printf("%d\r\n", adc_vol);
	HAL_ADC_Stop(&hadc1);
}

实验现象为:随着光照的加强,电阻值变小,led亮度减弱,反之则亮度增强

当然可以!要实现光敏电阻控制LED亮灭的程序,你需要按照以下步骤进行: 1. 首先,你需要连接STM32F103C8T6开发板上的光敏电阻和LED。将光敏电阻的一个引脚连接到STM32F103C8T6开发板上的一个模拟输入引脚(比如PA0),将LED的一个引脚连接到STM32F103C8T6开发板上的一个数字输出引脚(比如PB0)。 2. 接下来,你需要在STM32CubeIDE或者其他适合的开发环境中创建一个新的工程,并配置好相关的引脚。 3. 在代码中,你需要初始化光敏电阻所连接的模拟输入引脚和LED所连接的数字输出引脚。 4. 然后,你需要编写一个循环,不断读取光敏电阻的值,并根据光敏电阻的值来控制LED的亮灭。可以通过比较光敏电阻的值一个阈值来判断是否需要点亮LED。 5. 最后,你可以根据需要调整阈值和LED亮灭的逻辑,以满足你的实际需求。 下面是一个简单的示例代码: ```c #include "stm32f1xx_hal.h" ADC_HandleTypeDef hadc; GPIO_InitTypeDef GPIO_InitStruct; void SystemClock_Config(void); static void MX_GPIO_Init(void); static void MX_ADC1_Init(void); int main(void) { HAL_Init(); SystemClock_Config(); MX_GPIO_Init(); MX_ADC1_Init(); uint16_t adc_value = 0; uint16_t threshold = 1000; // 设置阈值 while (1) { HAL_ADC_Start(&hadc); if (HAL_ADC_PollForConversion(&hadc, 10) == HAL_OK) { adc_value = HAL_ADC_GetValue(&hadc); if (adc_value > threshold) { HAL_GPIO_WritePin(GPIOB, GPIO_PIN_0, GPIO_PIN_SET); // 点亮LED } else { HAL_GPIO_WritePin(GPIOB, GPIO_PIN_0, GPIO_PIN_RESET); // 关闭LED } } HAL_ADC_Stop(&hadc); HAL_Delay(100); // 延时一段时间再进行下一次读取 } } void SystemClock_Config(void) { RCC_OscInitTypeDef RCC_OscInitStruct; RCC_ClkInitTypeDef RCC_ClkInitStruct; __HAL_RCC_PWR_CLK_ENABLE(); __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1); 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.PLLMUL = RCC_PLL_MUL9; RCC_OscInitStruct.PLL.PREDIV = RCC_PREDIV_DIV1; if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK) { Error_Handler(); } RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_SYSCLK | RCC_CLOCKTYPE_PCLK1 | RCC_CLOCKTYPE_PCLK2; RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK; RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1; RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2; RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1; if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK) { Error_Handler(); } } static void MX_ADC1_Init(void) { ADC_ChannelConfTypeDef sConfig; __HAL_RCC_ADC1_CLK_ENABLE(); hadc.Instance = ADC1; hadc.Init.ScanConvMode = ADC_SCAN_DISABLE; hadc.Init.ContinuousConvMode = DISABLE; hadc.Init.DiscontinuousConvMode = DISABLE; hadc.Init.ExternalTrigConv = ADC_SOFTWARE_START; hadc.Init.DataAlign = ADC_DATAALIGN_RIGHT; hadc.Init.NbrOfConversion = 1; if (HAL_ADC_Init(&hadc) != HAL_OK) { Error_Handler(); } sConfig.Channel = ADC_CHANNEL_0; // 设置模拟输入引脚 sConfig.Rank = ADC_REGULAR_RANK_1; sConfig.SamplingTime = ADC_SAMPLETIME_13CYCLES_5; if (HAL_ADC_ConfigChannel(&hadc, &sConfig) != HAL_OK) { Error_Handler(); } } static void MX_GPIO_Init(void) { __HAL_RCC_GPIOB_CLK_ENABLE(); GPIO_InitStruct.Pin = GPIO_PIN_0; // 设置数字输出引脚 GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW; HAL_GPIO_Init(GPIOB, &GPIO_InitStruct); } ``` 请注意,以上代码仅供参考,具体的实现可能需要根据你的件连接和需求进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值