当前位置: 首页 > article >正文

LVGL Table实战:手把手教你打造一个带合并单元格和自定义样式的嵌入式UI数据表格

LVGL Table实战手把手教你打造一个带合并单元格和自定义样式的嵌入式UI数据表格在嵌入式设备上展示复杂数据时表格是最直观的呈现方式之一。但默认的LVGL Table控件往往显得单调难以满足专业级UI的需求。本文将带你深入探索LVGL Table的高级功能从单元格合并到条件样式定制打造一个既美观又实用的数据表格。1. 基础准备与环境搭建在开始高级功能之前我们需要确保开发环境已经正确配置。假设你已经完成了LVGL库的移植和基本显示功能的验证。以下是创建基础表格的代码示例lv_obj_t* table lv_table_create(lv_scr_act()); lv_table_set_col_cnt(table, 4); // 设置4列 lv_table_set_row_cnt(table, 10); // 设置10行 lv_obj_set_size(table, 320, 240); // 设置表格尺寸基础表格创建后我们可以通过以下方式填充数据lv_table_set_cell_value(table, 0, 0, ID); lv_table_set_cell_value(table, 0, 1, Name); lv_table_set_cell_value(table, 0, 2, Status); lv_table_set_cell_value(table, 0, 3, Value);注意LVGL的表格索引从0开始第一个参数是行号第二个是列号。2. 单元格合并与布局优化在实际应用中我们经常需要合并单元格来创建更复杂的布局。LVGL提供了LV_TABLE_CELL_CTRL_MERGE_RIGHT控制位来实现这一功能。2.1 基本合并操作要实现单元格向右合并可以使用以下代码// 合并第1行第1列和第2列 lv_table_add_cell_ctrl(table, 1, 1, LV_TABLE_CELL_CTRL_MERGE_RIGHT);合并后第一个单元格的内容会占据合并后的所有空间后续单元格的内容将被忽略。2.2 多列合并技巧对于需要合并多列的情况可以连续设置多个单元格的合并属性// 合并3列 lv_table_add_cell_ctrl(table, 2, 1, LV_TABLE_CELL_CTRL_MERGE_RIGHT); lv_table_add_cell_ctrl(table, 2, 2, LV_TABLE_CELL_CTRL_MERGE_RIGHT);2.3 合并单元格的样式调整合并后的单元格可能需要特殊样式处理。我们可以通过事件回调来实现static void table_event_cb(lv_event_t* e) { lv_obj_draw_part_dsc_t* dsc lv_event_get_param(e); if(dsc-part LV_PART_ITEMS) { uint32_t row dsc-id / lv_table_get_col_cnt(table); uint32_t col dsc-id % lv_table_get_col_cnt(table); if(lv_table_has_cell_ctrl(table, row, col, LV_TABLE_CELL_CTRL_MERGE_RIGHT)) { dsc-rect_dsc-bg_color lv_color_hex(0x3498db); // 设置合并单元格背景色 } } } lv_obj_add_event_cb(table, table_event_cb, LV_EVENT_DRAW_PART_BEGIN, NULL);3. 高级样式定制技巧LVGL的强大之处在于其灵活的样式系统。我们可以通过多种方式定制表格的外观。3.1 表头样式定制表头通常需要与数据行区分开来。我们可以通过判断行号来实现static void table_event_cb(lv_event_t* e) { lv_obj_draw_part_dsc_t* dsc lv_event_get_param(e); if(dsc-part LV_PART_ITEMS) { uint32_t row dsc-id / lv_table_get_col_cnt(table); if(row 0) { // 表头行 dsc-rect_dsc-bg_color lv_color_hex(0x2c3e50); dsc-label_dsc-color lv_color_white(); dsc-label_dsc-font lv_font_montserrat_16; } } }3.2 斑马线效果交替行颜色可以提高表格的可读性static void table_event_cb(lv_event_t* e) { lv_obj_draw_part_dsc_t* dsc lv_event_get_param(e); if(dsc-part LV_PART_ITEMS) { uint32_t row dsc-id / lv_table_get_col_cnt(table); if(row 0) { // 跳过表头 if(row % 2 0) { dsc-rect_dsc-bg_color lv_color_hex(0xf8f9fa); } else { dsc-rect_dsc-bg_color lv_color_hex(0xe9ecef); } } } }3.3 条件样式根据单元格内容动态改变样式static void table_event_cb(lv_event_t* e) { lv_obj_draw_part_dsc_t* dsc lv_event_get_param(e); if(dsc-part LV_PART_ITEMS) { uint32_t row dsc-id / lv_table_get_col_cnt(table); uint32_t col dsc-id % lv_table_get_col_cnt(table); const char* value lv_table_get_cell_value(table, row, col); if(col 2 strcmp(value, Error) 0) { dsc-rect_dsc-bg_color lv_color_hex(0xff6b6b); dsc-label_dsc-color lv_color_white(); } } }4. 性能优化与实战技巧在资源受限的嵌入式设备上表格性能优化尤为重要。4.1 减少重绘区域对于大型表格可以通过设置局部重绘来提高性能lv_obj_set_style_bg_opa(table, LV_OPA_TRANSP, LV_PART_MAIN); lv_obj_set_style_border_width(table, 0, LV_PART_MAIN);4.2 虚拟滚动技术对于超长表格可以实现虚拟滚动来节省内存lv_obj_set_height(table, 200); // 固定高度 lv_obj_set_scroll_dir(table, LV_DIR_VER); // 允许垂直滚动4.3 动态加载数据结合事件系统实现按需加载static void scroll_event_cb(lv_event_t* e) { lv_obj_t* obj lv_event_get_target(e); lv_coord_t scroll_y lv_obj_get_scroll_y(obj); lv_coord_t height lv_obj_get_height(obj); // 计算当前可见行范围 uint16_t start_row scroll_y / ROW_HEIGHT; uint16_t end_row (scroll_y height) / ROW_HEIGHT 1; // 动态加载可见行数据 load_table_data(table, start_row, end_row); } lv_obj_add_event_cb(table, scroll_event_cb, LV_EVENT_SCROLL, NULL);5. 综合案例仪表盘数据表格让我们将这些技术应用到一个实际的仪表盘案例中。5.1 表格结构设计lv_table_set_col_width(table, 0, 60); // ID列 lv_table_set_col_width(table, 1, 120); // 名称列 lv_table_set_col_width(table, 2, 80); // 状态列 lv_table_set_col_width(table, 3, 60); // 值列 // 设置表头 lv_table_set_cell_value(table, 0, 0, ID); lv_table_set_cell_value(table, 0, 1, Sensor); lv_table_set_cell_value(table, 0, 2, Status); lv_table_set_cell_value(table, 0, 3, Value); // 合并状态和值列的表头 lv_table_set_cell_value(table, 0, 2, Status/Value); lv_table_add_cell_ctrl(table, 0, 2, LV_TABLE_CELL_CTRL_MERGE_RIGHT);5.2 数据可视化增强static void table_event_cb(lv_event_t* e) { lv_obj_draw_part_dsc_t* dsc lv_event_get_param(e); if(dsc-part LV_PART_ITEMS) { uint32_t row dsc-id / lv_table_get_col_cnt(table); uint32_t col dsc-id % lv_table_get_col_cnt(table); if(col 3 row 0) { // 值列 const char* value_str lv_table_get_cell_value(table, row, col); float value atof(value_str); // 根据值大小设置颜色渐变 if(value 80) { dsc-rect_dsc-bg_color lv_color_hex(0xff6b6b); } else if(value 50) { dsc-rect_dsc-bg_color lv_color_hex(0xffd166); } else { dsc-rect_dsc-bg_color lv_color_hex(0x06d6a0); } } } }5.3 交互增强添加点击事件处理static void table_click_cb(lv_event_t* e) { lv_obj_t* obj lv_event_get_target(e); uint16_t row, col; lv_table_get_selected_cell(obj, row, col); if(row 0) { // 跳过表头 const char* name lv_table_get_cell_value(obj, row, 1); const char* value lv_table_get_cell_value(obj, row, 3); // 显示详细信息 show_detail_popup(name, value); } } lv_obj_add_event_cb(table, table_click_cb, LV_EVENT_CLICKED, NULL);

相关文章:

LVGL Table实战:手把手教你打造一个带合并单元格和自定义样式的嵌入式UI数据表格

LVGL Table实战:手把手教你打造一个带合并单元格和自定义样式的嵌入式UI数据表格 在嵌入式设备上展示复杂数据时,表格是最直观的呈现方式之一。但默认的LVGL Table控件往往显得单调,难以满足专业级UI的需求。本文将带你深入探索LVGL Table的…...

B站缓存视频解锁指南:3分钟无损转换m4s为MP4的完整方案

B站缓存视频解锁指南:3分钟无损转换m4s为MP4的完整方案 【免费下载链接】m4s-converter 一个跨平台小工具,将bilibili缓存的m4s格式音视频文件合并成mp4 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 你是否曾在B站缓存了珍贵的视…...

避坑指南:YOLOv8转ONNX时遇到‘silu算子不支持’报错?手把手教你修改PyTorch源码解决

YOLOv8模型转ONNX实战:解决silu算子不支持报错的深度优化方案 当我们将YOLOv8模型从PyTorch格式转换为ONNX时,经常会遇到一个令人头疼的错误:"Exporting the operator silu to ONNX opset version 12 is not supported"。这个错误…...

超越数据手册:用S32K324的BCTU与注入触发构建高响应实时控制系统

超越数据手册:用S32K324的BCTU与注入触发构建高响应实时控制系统 在工业自动化与电力电子领域,实时控制系统的响应速度往往决定着整个设备的性能上限。当电机控制遇到突发过流,或电源管理检测到电压瞬变时,传统基于软件轮询的ADC采…...

FDA认证C代码性能与可追溯性如何兼得?揭秘NASA/JPL级工具链中隐藏的5层编译器优化约束

更多请点击: https://intelliparadigm.com 第一章:FDA认证C代码性能与可追溯性协同设计的底层逻辑 在医疗设备软件开发中,FDA 21 CFR Part 11 与 IEC 62304 要求 C 代码不仅需满足实时性与内存安全,更须建立从需求→设计→实现→…...

基于Rootless Podman的AI编程代理安全沙箱设计与实践

1. 项目概述:一个为AI编程代理打造的隔离沙箱如果你和我一样,日常工作中会频繁使用Claude Code、Cursor Agent这类AI编程助手,那你肯定也思考过同一个问题:“我到底敢不敢让它直接在我的开发机上跑?”这些工具功能强大…...

【C语言Modbus通信性能跃迁指南】:20年嵌入式老兵亲授4大零拷贝+无锁队列优化实战(附实测吞吐提升3.7倍数据)

更多请点击: https://intelliparadigm.com 第一章:C语言Modbus通信性能跃迁的底层逻辑与演进瓶颈 Modbus协议在工业嵌入式系统中长期依赖C语言实现,其性能边界并非由协议规范决定,而是受制于C运行时、内存模型与硬件交互方式的耦…...

holysheep-cli:Windows平台AI编程助手一键配置工具详解

1. 项目概述与核心价值 如果你是一名开发者,或者正在学习编程,那么最近一两年肯定被各种AI编程工具轮番轰炸过。从GitHub Copilot到Cursor,从Claude Code到各种基于大模型的命令行工具,它们确实能极大提升编码效率,但随…...

轻量级Docker管理面板clawpanel:部署、安全与核心功能详解

1. 项目概述与核心价值最近在折腾个人服务器和容器化应用时,发现一个挺普遍的需求:如何用一个统一的界面,去管理那些散落在不同服务器、不同环境里的Docker容器?特别是对于个人开发者、小团队或者像我这样喜欢在家里搞点“家庭实验…...

告别网盘限速!LinkSwift直链下载助手让你轻松获取八大平台真实下载地址

告别网盘限速!LinkSwift直链下载助手让你轻松获取八大平台真实下载地址 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / 阿里云盘 / 中国…...

别再死记硬背了!用Python+PyTorch手把手图解自注意力机制(附完整代码)

别再死记硬背了!用PythonPyTorch手把手图解自注意力机制(附完整代码) 理解自注意力机制最有效的方式不是背诵公式,而是亲手实现它。本文将带你用PyTorch从零构建一个可交互的自注意力模块,并通过动态可视化揭示其核心…...

别急着换新!用OpenCore Legacy Patcher v1.4.3,让你的2012款MacBook Pro吃上macOS Sonoma

2012款MacBook Pro升级macOS Sonoma全攻略:OpenCore Legacy Patcher实战手册 手里那台2012年的MacBook Pro还在坚持服役?别急着让它退休。通过OpenCore Legacy Patcher这个神奇工具,我们完全可以让这台"老兵"焕发新生,…...

D3KeyHelper深度解析:暗黑3专业级按键宏架构与高级应用指南

D3KeyHelper深度解析:暗黑3专业级按键宏架构与高级应用指南 【免费下载链接】D3keyHelper D3KeyHelper是一个有图形界面,可自定义配置的暗黑3鼠标宏工具。 项目地址: https://gitcode.com/gh_mirrors/d3/D3keyHelper D3KeyHelper是一款专为《暗黑…...

pyVideoTrans终极指南:从零开始掌握视频翻译配音全流程

pyVideoTrans终极指南:从零开始掌握视频翻译配音全流程 【免费下载链接】pyvideotrans Translate the video from one language to another and embed dubbing & subtitles. 项目地址: https://gitcode.com/gh_mirrors/py/pyvideotrans pyVideoTrans是一…...

告别模拟器!Win11专业版原生安卓子系统保姆级安装与APK安装指南(附文件映射技巧)

告别模拟器!Win11专业版原生安卓子系统深度配置与APK自由安装实战 在移动应用生态与桌面操作系统加速融合的今天,开发者与极客用户对跨平台运行安卓应用的需求持续升温。传统安卓模拟器虽然解决了基础需求,但普遍存在性能损耗高、广告干扰多、…...

MATLAB绘图救急:3分钟搞定散点图、三维曲面图的网格线精准控制

MATLAB绘图救急:3分钟搞定散点图、三维曲面图的网格线精准控制 在数据可视化领域,网格线常常被忽视,但它却是提升图表专业度的关键细节。想象一下,当你需要在学术报告中展示一组实验数据,或者在工程会议上呈现复杂的三…...

AI Agent插件框架:从意图识别到任务规划的工程实践

1. 项目概述:Jini-Plugin,一个能“理解”你意图的智能插件 最近在折腾AI应用开发,特别是想让大语言模型(LLM)能更“听话”、更“能干”地执行我的指令。我发现,很多时候不是模型能力不行,而是我…...

在Hermes Agent项目中配置Taotoken作为自定义模型提供商

在Hermes Agent项目中配置Taotoken作为自定义模型提供商 1. 准备工作 在开始配置前,请确保已安装Hermes Agent框架并创建了项目。同时需要在Taotoken控制台获取有效的API Key,并在模型广场确认要使用的模型ID。这两个信息将在后续配置中使用。 2. 配置…...

手把手调试:用STM32CubeIDE和FreeRTOS Tracealyzer可视化portYIELD_FROM_ISR的调度过程

手把手调试:用STM32CubeIDE和FreeRTOS Tracealyzer可视化portYIELD_FROM_ISR的调度过程 在嵌入式实时操作系统开发中,理解任务调度机制是掌握系统行为的关键。对于FreeRTOS开发者来说,portYIELD_FROM_ISR函数是一个经常出现在中断服务例程(IS…...

终极窗口尺寸强制调整工具:3分钟掌握任何窗口的完全控制权

终极窗口尺寸强制调整工具:3分钟掌握任何窗口的完全控制权 【免费下载链接】WindowResizer 一个可以强制调整应用程序窗口大小的工具 项目地址: https://gitcode.com/gh_mirrors/wi/WindowResizer 你是否曾经遇到过那些"顽固不化"的应用程序窗口&a…...

别再手动调参了!用YOLOv5的k-means+遗传算法自动生成最佳Anchor(附完整代码)

突破YOLOv5检测极限:基于遗传算法的Anchor智能优化实战 在目标检测领域,Anchor的设计质量直接影响模型性能。传统手工调参方式不仅耗时耗力,还难以获得最优解。本文将带您深入探索YOLOv5中结合k-means与遗传算法的Anchor自动优化方案&#xf…...

别再手动写CSS了!用这个Vue3自定义指令,5分钟搞定Element Plus表格表头吸顶

Vue3 Element Plus 表格表头吸顶:5分钟实现零CSS的优雅方案 后台管理系统开发中,数据表格的交互体验直接影响用户效率。当页面滚动时,表头消失会导致用户频繁回滚查看字段含义——这个看似简单的需求,却让不少开发者栽在CSS定位…...

别再手动编译了!用vcpkg在Windows上5分钟搞定Pangolin+OpenGL开发环境(附完整配置清单)

Windows下极速搭建PangolinOpenGL开发环境的终极指南 如果你正在Windows平台上尝试进行3D视觉开发,一定对Pangolin这个轻量级OpenGL库不陌生。作为ORB-SLAM等知名开源项目的标配界面库,Pangolin提供了简洁高效的3D可视化解决方案。然而,许多…...

从Webpack到Vite:如何平滑地将一个老Vue3子应用迁移进Qiankun微前端架构?

从Webpack到Vite:如何平滑地将一个老Vue3子应用迁移进Qiankun微前端架构? 当技术栈迭代遇上架构升级,团队常面临"既要保留历史资产又要拥抱新生态"的困境。最近接手一个电商后台系统的微前端改造,主应用已采用ViteVue3技…...

Agentic RAG系统优化:解决多跳问答中的信息遗忘与重复检索

1. Agentic RAG系统优化背景 在当今信息爆炸的时代,检索增强生成(Retrieval-Augmented Generation, RAG)系统已成为连接海量知识库与自然语言处理的重要桥梁。这类系统通过将外部文档检索与生成式语言模型相结合,显著提升了复杂问…...

Windows风扇控制终极指南:FanControl完全配置教程

Windows风扇控制终极指南:FanControl完全配置教程 【免费下载链接】FanControl.Releases This is the release repository for Fan Control, a highly customizable fan controlling software for Windows. 项目地址: https://gitcode.com/GitHub_Trending/fa/Fan…...

League Akari:5步打造你的英雄联盟智能游戏管家

League Akari:5步打造你的英雄联盟智能游戏管家 【免费下载链接】League-Toolkit An all-in-one toolkit for LeagueClient. Gathering power 🚀. 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit League Akari是一款基于官方LCU AP…...

MZmine 3:开源质谱数据分析的完整解决方案,让你轻松搞定代谢组学研究!

MZmine 3:开源质谱数据分析的完整解决方案,让你轻松搞定代谢组学研究! 【免费下载链接】mzmine3 mzmine source code repository 项目地址: https://gitcode.com/gh_mirrors/mz/mzmine3 你是否曾被质谱数据分析的复杂性所困扰&#xf…...

SD卡协议扫盲:从CMD55到ACMD41,手把手拆解SDIO的‘特殊命令’机制

SD卡协议深度解析:特殊命令机制与实战调试指南 在嵌入式开发中,SD卡作为最常用的存储介质之一,其底层通信协议却常常让开发者感到困惑。特别是当遇到需要先发送CMD55再发送ACMD41这类"特殊命令"时,很多开发者会陷入调试…...

告别选型纠结!一文看懂RK3588与RK3588S的五大核心差异,帮你选对核心板

RK3588与RK3588S深度对比:从芯片选型到产品落地的实战指南 在智能硬件开发领域,芯片选型往往决定了产品的性能上限和成本结构。面对Rockchip推出的两款旗舰级处理器RK3588和RK3588S,许多开发者都会陷入选择困难。这两款芯片看似同源&#xff…...