/* * SPDX-FileCopyrightText: 2010-2022 Espressif Systems (Shanghai) CO LTD * * SPDX-License-Identifier: CC0-1.0 */ #include #include #include "sdkconfig.h" #include "freertos/FreeRTOS.h" #include "freertos/task.h" #include "freertos/timers.h" #include "esp_chip_info.h" #include "esp_flash.h" #include "esp_system.h" #include "esp_spiffs.h" #include "esp_log.h" #include "esp_timer.h" #include #include #include #include // 关键:包含 DIR 相关定义 #include // 错误码定义 #include // 时间相关函数 #include "spiffs.h" #include "spi.h" #include "lcd.h" #include "e11.h" #include "lv_conf.h" #include "lvgl/lvgl.h" #include "lv_port_disp.h" #include "lv_port_fs.h" #include "lv_log_to_esp.h" #include "lv_apps/helloworld/lv_helloworld.h" static const char *TAG = "SYS"; // 自定义 tick 获取函数 static uint32_t custom_tick_get(void) { // 返回从启动到现在的毫秒数 // 使用64位中间变量避免溢出,采用乘以1.024的倒数近似值 uint64_t time_us = esp_timer_get_time(); return (uint32_t)((time_us * 1073) >> 20); // 1073/2^20 ≈ 1/1000 //return (uint32_t)(esp_timer_get_time() / 1000); } esp_timer_handle_t timer_handle; static void lv_tick_timer_callback(void* arg) { lv_tick_inc(1); } void init_lvgl_tick_timer(void) { // 创建定时器参数 const esp_timer_create_args_t timer_args = { .callback = &lv_tick_timer_callback, .arg = NULL, .dispatch_method = ESP_TIMER_TASK, .name = "lv_tick_timer" }; // 创建定时器 ESP_ERROR_CHECK(esp_timer_create(&timer_args, &timer_handle)); // 启动周期性定时器(1ms = 1000us) ESP_ERROR_CHECK(esp_timer_start_periodic(timer_handle, 1000)); } void app_main(void) { ESP_LOGI(TAG, "Hello world!"); /* Print chip information */ esp_chip_info_t chip_info; uint32_t flash_size; esp_chip_info(&chip_info); ESP_LOGI(TAG, "This is %s chip with %d CPU core(s), %s%s%s%s, ", CONFIG_IDF_TARGET, chip_info.cores, (chip_info.features & CHIP_FEATURE_WIFI_BGN) ? "WiFi/" : "", (chip_info.features & CHIP_FEATURE_BT) ? "BT" : "", (chip_info.features & CHIP_FEATURE_BLE) ? "BLE" : "", (chip_info.features & CHIP_FEATURE_IEEE802154) ? ", 802.15.4 (Zigbee/Thread)" : ""); unsigned major_rev = chip_info.revision / 100; unsigned minor_rev = chip_info.revision % 100; ESP_LOGI(TAG, "silicon revision v%d.%d, ", major_rev, minor_rev); if (esp_flash_get_size(NULL, &flash_size) != ESP_OK) { ESP_LOGI(TAG, "Get flash size failed"); return; } ESP_LOGI(TAG, "%" PRIu32 "MB %s flash", flash_size / (uint32_t)(1024 * 1024), (chip_info.features & CHIP_FEATURE_EMB_FLASH) ? "embedded" : "external"); ESP_LOGI(TAG, "Minimum free heap size: %" PRIu32 " bytes", esp_get_minimum_free_heap_size()); ESP_LOGI(TAG, "sizeof(int) ==%d", sizeof(int)); ESP_LOGI(TAG, "LVGL version: %s", lv_version_info()); ESP_LOGI(TAG, "LVGL memory size: %u bytes", LV_MEM_SIZE); ESP_LOGI(TAG, "LVGL color depth: %d bits", LV_COLOR_DEPTH); // 1. 初始化 SPIFFS const char *spiffs_base_path = "/spiffs"; esp_err_t ret = spiffs_init(spiffs_base_path); if (ret != ESP_OK) { ESP_LOGE(TAG, "SPIFFS 初始化失败"); } else { ESP_LOGI(TAG, "SPIFFS 初始化OK"); list_spiffs_files_safe(spiffs_base_path); } e11_init(); spi_init(); lcd_init(); lv_init(); //lv_tick_set_cb(custom_tick_get); init_lvgl_tick_timer(); lv_log_to_esp_init(); lv_port_disp_init(); lv_port_fs_init(); lv_example_get_started_1(); while (1) { // lcd_clear_buf(rand()); // lcd_send_full_buf(); // t = custom_tick_get(); // ESP_LOGI(TAG, "NOW is%lu", t); //this_work_loop(); lv_task_handler(); vTaskDelay(1); // 必须让出CPU } }