ESP32-S3 吊坠设备固件,集成火山引擎 RTC 语音助手、蓝牙配网、 VEML7700 环境光传感器驱动及石头同频匹配交友功能。 VEML7700 驱动: - 基于 ESP-IDF i2c_master API 实现,复用项目 I2cDevice 基类 - 支持 ALS + White 双通道、自动量程、Vishay 非线性校正 - 3 次采样取中位数过滤偶发异常 石头同频匹配算法(双维度): - 维度1:光谱比值 ALS/White(石头固有光学特征,不随光照强度变化) - 维度2:亮度等级(5级对数划分,排除极端环境差异) - 比值阈值 15%,实测同石头姿势变化波动 1.6%~9.6%,安全余量充足 Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
100 lines
4.1 KiB
C
100 lines
4.1 KiB
C
#pragma once
|
|
|
|
#include "esp_lcd_panel_vendor.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @brief LCD panel initialization commands.
|
|
*
|
|
*/
|
|
typedef struct {
|
|
int cmd; /*<! The specific LCD command */
|
|
const void *data; /*<! Buffer that holds the command specific data */
|
|
size_t data_bytes; /*<! Size of `data` in memory, in bytes */
|
|
unsigned int delay_ms; /*<! Delay in milliseconds after this command */
|
|
} gc9d01n_lcd_init_cmd_t;
|
|
|
|
/**
|
|
* @brief LCD panel vendor configuration.
|
|
*
|
|
* @note This structure needs to be passed to the `vendor_config` field in `esp_lcd_panel_dev_config_t`.
|
|
*
|
|
*/
|
|
typedef struct {
|
|
const gc9d01n_lcd_init_cmd_t *init_cmds; /*!< Pointer to initialization commands array. Set to NULL if using default commands.
|
|
* The array should be declared as `static const` and positioned outside the function.
|
|
* Please refer to `vendor_specific_init_default` in source file.
|
|
*/
|
|
uint16_t init_cmds_size; /*<! Number of commands in above array */
|
|
} gc9d01n_vendor_config_t;
|
|
|
|
/**
|
|
* @brief Create LCD panel for model GC9D01N
|
|
*
|
|
* @note Vendor specific initialization can be different between manufacturers, should consult the LCD supplier for initialization sequence code.
|
|
*
|
|
* @param[in] io LCD panel IO handle
|
|
* @param[in] panel_dev_config general panel device configuration
|
|
* @param[out] ret_panel Returned LCD panel handle
|
|
* @return
|
|
* - ESP_ERR_INVALID_ARG if parameter is invalid
|
|
* - ESP_ERR_NO_MEM if out of memory
|
|
* - ESP_OK on success
|
|
*/
|
|
esp_err_t esp_lcd_new_panel_gc9d01n(const esp_lcd_panel_io_handle_t io, const esp_lcd_panel_dev_config_t *panel_dev_config, esp_lcd_panel_handle_t *ret_panel);
|
|
|
|
/**
|
|
* @brief LCD panel bus configuration structure
|
|
*
|
|
* @param[in] sclk SPI clock pin number
|
|
* @param[in] mosi SPI MOSI pin number
|
|
* @param[in] max_trans_sz Maximum transfer size in bytes
|
|
*
|
|
*/
|
|
#define GC9D01N_PANEL_BUS_SPI_CONFIG(sclk, mosi, max_trans_sz) \
|
|
{ \
|
|
.mosi_io_num = mosi, \
|
|
.miso_io_num = -1, \
|
|
.sclk_io_num = sclk, \
|
|
.quadwp_io_num = -1, \
|
|
.quadhd_io_num = -1, \
|
|
.data4_io_num = -1, \
|
|
.data5_io_num = -1, \
|
|
.data6_io_num = -1, \
|
|
.data7_io_num = -1, \
|
|
.max_transfer_sz = max_trans_sz, \
|
|
.flags = 0, \
|
|
.isr_cpu_id = ESP_INTR_CPU_AFFINITY_AUTO, \
|
|
.intr_flags = 0 \
|
|
}
|
|
|
|
/**
|
|
* @brief LCD panel IO configuration structure
|
|
*
|
|
* @param[in] cs SPI chip select pin number
|
|
* @param[in] dc SPI data/command pin number
|
|
* @param[in] cb Callback function when SPI transfer is done
|
|
* @param[in] cb_ctx Callback function context
|
|
*
|
|
*/
|
|
#define GC9D01N_PANEL_IO_SPI_CONFIG(cs, dc, callback, callback_ctx) \
|
|
{ \
|
|
.cs_gpio_num = cs, \
|
|
.dc_gpio_num = dc, \
|
|
.spi_mode = 0, \
|
|
.pclk_hz = 80 * 1000 * 1000, \
|
|
.trans_queue_depth = 10, \
|
|
.on_color_trans_done = callback, \
|
|
.user_ctx = callback_ctx, \
|
|
.lcd_cmd_bits = 8, \
|
|
.lcd_param_bits = 8, \
|
|
.flags = {} \
|
|
}
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|