项目是Kevincoooool参加某个大赛开源的项目,原理图和代码开源。希望大家遵守开源协议,勿做商用或者售卖。
#include "lvgl.h" #include "stdio.h" #include #include #include "esp_system.h" #include "esp_vfs.h" #include "esp_spiffs.h" typedef struct { uint16_t min; uint16_t max; uint8_t bpp; uint8_t reserved[3]; } x_header_t; typedef struct { uint32_t pos; } x_table_t; typedef struct { uint8_t adv_w; uint8_t box_w; uint8_t box_h; int8_t ofs_x; int8_t ofs_y; uint8_t r; } glyph_dsc_t; static x_header_t __g_xbf_hd = { .min = 0x0020, .max = 0xff1a, .bpp = 4, }; char *Font_buff = NULL; // static uint8_t __g_font_buf[240]; //如bin文件存在SPI FLASH可使用此buff static void init_font(void) { FILE *ff = fopen("/spiffs/myFont.bin", "r"); if (ff == NULL) { printf("Failed to open file for reading"); return; } fseek(ff, 0, SEEK_END); long lSize = ftell(ff); rewind(ff); printf("Lsize %ld", lSize); static uint8_t first_in = 1; if (first_in == 1) { first_in = 0; Font_buff = (char *)malloc(sizeof(char) * lSize); } int br = fread(Font_buff, 1, lSize, ff); printf("Bytes read %d", br); fclose(ff); } static uint8_t *__user_font_getdata(int offset, int size) { //如字模保存在SPI FLASH, SPIFLASH_Read(__g_font_buf,offset,size); //如字模已加载到SDRAM,直接返回偏移地址即可如:return (uint8_t*)(sdram_fontddr+offset); static uint8_t first_in = 1; if (first_in == 1)//第一次进入的时候初始化外部字体 { first_in = 0; init_font(); } return (uint8_t*)(Font_buff+offset); // return __g_font_buf; } static const uint8_t *__user_font_get_bitmap(const lv_font_t *font, uint32_t unicode_letter) { if (unicode_letter > __g_xbf_hd.max || unicode_letter < __g_xbf_hd.min) { return NULL; } uint32_t unicode_offset = sizeof(x_header_t) + (unicode_letter - __g_xbf_hd.min) * 4; uint32_t *p_pos = (uint32_t *)__user_font_getdata(unicode_offset, 4); if (p_pos[0] != 0) { uint32_t pos = p_pos[0]; glyph_dsc_t *gdsc = (glyph_dsc_t *)__user_font_getdata(pos, sizeof(glyph_dsc_t)); return __user_font_getdata(pos + sizeof(glyph_dsc_t), gdsc->box_w * gdsc->box_h * __g_xbf_hd.bpp / 8); } return NULL; } static bool __user_font_get_glyph_dsc(const lv_font_t *font, lv_font_glyph_dsc_t *dsc_out, uint32_t unicode_letter, uint32_t unicode_letter_next) { if (unicode_letter > __g_xbf_hd.max || unicode_letter < __g_xbf_hd.min) { return NULL; } uint32_t unicode_offset = sizeof(x_header_t) + (unicode_letter - __g_xbf_hd.min) * 4; uint32_t *p_pos = (uint32_t *)__user_font_getdata(unicode_offset, 4); if (p_pos[0] != 0) { glyph_dsc_t *gdsc = (glyph_dsc_t *)__user_font_getdata(p_pos[0], sizeof(glyph_dsc_t)); dsc_out->adv_w = gdsc->adv_w; dsc_out->box_h = gdsc->box_h; dsc_out->box_w = gdsc->box_w; dsc_out->ofs_x = gdsc->ofs_x; dsc_out->ofs_y = gdsc->ofs_y; dsc_out->bpp = __g_xbf_hd.bpp; return true; } return false; } //AliHYAiHei-Beta,,-1 //字模高度:24 //XBF字体,外部bin文件 lv_font_t myFont = { .get_glyph_bitmap = __user_font_get_bitmap, .get_glyph_dsc = __user_font_get_glyph_dsc, .line_height = 24, .base_line = 0, }; LV_FONT_DECLARE(myFont); lv_obj_t *label = lv_label_create(obj, NULL); lv_obj_set_style_local_text_font(label, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, &myFont);
ESP32 芯片有34个物理GPIO管脚。每个GPIO管脚都可用作一个通用IO,或连接一个内部的外设信号。IO_MUX ¹、RTC IO MUX 和GPIO交换矩阵用于将信号从外设传输至GPIO管脚。
ESP32Encoder库是一个利用ESP32脉冲计数器硬件外设实现高效旋转编码器读取的软件库。
本文对比了几款适合物联网开发的盒子硬件参数,供大家参考。
乐动掌控采用掌控板作为主控,塑胶一体式外壳,侧面和底面开具多个乐高扩展孔位,兼容乐高积木,可完成多种创意应用。
在MicroPython的ESP32库中,NVS类用于管理非易失性存储,支持 32 位有符号整数和 二进制blob。
Arduino-ESP32项目提供的Preferences库是一个专为ESP32设计的非易失性存储解决方案,它替代了传统的Arduino EEPROM库,提供了更强大、更可靠的数据存储功能。
本方案是一个基于ESP32-CAM + 物联网的图像采集方案。
ESP32-CAM与MicroPython结合可实现摄像头图像采集、视频流传输等功能,不过Micropython官方没有支持ESP32-CAM的固件,需要烧录第三方的专有固件。
相信很多人都有把绿植给养死的经历,可能是浇水过多、忘记浇水、较长时间不在家不能浇水等,本文介绍一种可以灵活定制的智能浇花方案。
MicroPython 在 ESP32 上支持线程(Thread)功能,通过_thread模块实现。线程允许程序并发执行多个任务,适合处理需要同时运行的场景,例如传感器数据采集和网络通信。
专属教研服务系统,助您构建STEM课程体系,打造一站式教学环境。