DockerFluxDC/components/user_power_task/user_power_task.c

143 lines
3.8 KiB
C
Raw Normal View History

2025-11-28 10:38:40 +08:00
/**
* @file FluxButton.c
* @brief
*
*
*
* @author wang xiang en
* @date 2025-11-28
2025-11-28 10:38:40 +08:00
* @version
* @copyright (C)2025, YUWELL MEDTECH Co.ltd
*/
#include <stdio.h>
#include "user_power_task.h"
2025-11-28 10:38:40 +08:00
#include "driver/gpio.h"
2025-11-28 10:38:40 +08:00
/* 日志打印标签 */
static const char *S_BUTTON_TAG = "tag_user_button";
2025-11-28 10:38:40 +08:00
/**
* @brief
*
*
*
* @param[in] arg not used
* @param[in] data
*/
static void button_event_cb(void *arg, void *data)
{
/* 按键事件出发后发送日志信息到屏幕 */
ESP_LOGI(S_BUTTON_TAG, "Button event %d", (int)data);
switch ((int)data)
{
/* 电源按键按下事件 */
case BUTTON_CMD_POWER_ON:
POWER_ON;
break;
case BUTTON_CMD_POWER_OFF:
POWER_OFF;
2025-11-28 10:38:40 +08:00
break;
default:
break;
}
}
/**
* @brief
*
* IObutton_event_cb
*
* @param[in] button_num
*/
static void single_button_init(uint32_t button_num)
{
2025-11-28 10:38:40 +08:00
uint8_t activeLevel = BUTTON_POWERIN_ACTIVE_LEVEL;
/* 按键配置结构体初始化 */
button_config_t btn_cfg = {
.type = BUTTON_TYPE_GPIO,
.gpio_button_config = {
.gpio_num = button_num,
.active_level = activeLevel,
},
};
button_handle_t btn = iot_button_create(&btn_cfg);
assert(btn);
/* 注册按键事件处理函数 */
esp_err_t err = ESP_OK;
/* Turn off by double-clicking the power button */
err |= iot_button_register_cb(btn, BUTTON_DOUBLE_CLICK, button_event_cb, (void *)BUTTON_CMD_POWER_OFF);
/* Turn on by long-pressing the power button */
err |= iot_button_register_cb(btn, BUTTON_LONG_PRESS_HOLD, button_event_cb, (void *)BUTTON_CMD_POWER_ON);
ESP_ERROR_CHECK(err);
}
// 电源管理任务,初始化按键之后接收外部消息并处理
void power_manager_task(void* arg)
2025-11-28 10:38:40 +08:00
{
GeneralMsg_t received_msg;
2025-11-28 10:38:40 +08:00
gpio_reset_pin(BUTTON_POWER_OUT_IO_NUM);
gpio_set_direction(BUTTON_POWER_OUT_IO_NUM, GPIO_MODE_OUTPUT); // 将控制按键设置为输出
2025-11-28 10:38:40 +08:00
/* 初始化顶部的电源按键 */
single_button_init(BUTTON_POWER_IN_IO_NUM);
2025-11-28 10:38:40 +08:00
// 初始化背光调节LEDC
// Prepare and then apply the LEDC PWM timer configuration
ledc_timer_config_t ledc_timer = {
.speed_mode = LEDC_MODE,
.duty_resolution = LEDC_DUTY_RES,
.timer_num = LEDC_TIMER,
.freq_hz = LEDC_FREQUENCY, // Set output frequency at 4 kHz
.clk_cfg = LEDC_AUTO_CLK
};
ESP_ERROR_CHECK(ledc_timer_config(&ledc_timer));
// Prepare and then apply the LEDC PWM channel configuration
ledc_channel_config_t ledc_channel = {
.speed_mode = LEDC_MODE,
.channel = LEDC_CHANNEL,
.timer_sel = LEDC_TIMER,
.intr_type = LEDC_INTR_DISABLE,
.gpio_num = LEDC_OUTPUT_IO,
.duty = 0, // Set duty to 0%
.hpoint = 0
};
ESP_ERROR_CHECK(ledc_channel_config(&ledc_channel));
2025-11-28 10:38:40 +08:00
ESP_ERROR_CHECK(ledc_set_duty(LEDC_LOW_SPEED_MODE, LEDC_CHANNEL_0, 7222));
ESP_ERROR_CHECK(ledc_update_duty(LEDC_LOW_SPEED_MODE, LEDC_CHANNEL_0));
while (1)
{
if(xQueueReceive(xPowerTaskQueue, &received_msg, portMAX_DELAY)) //若没有消息接收则将任务设置为阻塞态
{
switch (received_msg.type)
{
case MSG_TYPE_POWER_OFF:
POWER_OFF;
break;
default:
break;
}
}
}
2025-11-28 10:38:40 +08:00
}