LVGL 8.2 点击显示CHART上的点数据值
数据 显示 点击 Chart LVGL 8.2
2023-09-14 09:06:41 时间
事件回调函数
static void event_cb(lv_event_t* e)
{
lv_event_code_t code = lv_event_get_code(e); //获取产生事件对象的事件码
lv_obj_t* chart = lv_event_get_target(e); //获取产生事件的对象
if (code == LV_EVENT_VALUE_CHANGED) { //值已改变事件
lv_obj_invalidate(chart); // 刷新CHART显示
}
if (code == LV_EVENT_REFR_EXT_DRAW_SIZE) { //LV_EVENT_REFR_EXT_DRAW_SIZE事件
lv_coord_t* s = lv_event_get_param(e); // 获取事件对象的size数据
*s = LV_MAX(*s, 20); //得到最大值,且最大值限制在20以上
}
else if (code == LV_EVENT_DRAW_POST_END) { // LV_EVENT_DRAW_POST_END事件
int32_t id = lv_chart_get_pressed_point(chart); // 获取CHART上被点击的点ID
if (id == LV_CHART_POINT_NONE) return; // 不是CHART上的点,则不处理,直接返回
LV_LOG_USER("Selected point %d", (int)id); //打印点ID值
lv_chart_series_t* ser = lv_chart_get_series_next(chart, NULL); // 获取第一条ser线
while (ser) {
lv_point_t p;
lv_chart_get_point_pos_by_id(chart, ser, id, &p); // 通过CHART的点ID获取其在CHART上的位置值并保存在p中
lv_coord_t* y_array = lv_chart_get_y_array(chart, ser); // 获取CHART的ser对应点值的数组集合
lv_coord_t value = y_array[id]; //获取ID对应的ser的点数值
char buf[16];
lv_snprintf(buf, sizeof(buf), LV_SYMBOL_DUMMY"$%d", value); //ser的点值转成字串到buf
lv_draw_rect_dsc_t draw_rect_dsc;
lv_draw_rect_dsc_init(&draw_rect_dsc);
draw_rect_dsc.bg_color = lv_color_black(); /黑色背景
draw_rect_dsc.bg_opa = LV_OPA_50; // 50%透明度
draw_rect_dsc.radius = 3; // 圆角半径为3
draw_rect_dsc.bg_img_src = buf; // 显示数据指向buf
draw_rect_dsc.bg_img_recolor = lv_color_white(); //重新着色为白色
lv_area_t a;
a.x1 = chart->coords.x1 + p.x - 20;
a.x2 = chart->coords.x1 + p.x + 20;
a.y1 = chart->coords.y1 + p.y - 30;
a.y2 = chart->coords.y1 + p.y - 10;
lv_draw_ctx_t* draw_ctx = lv_event_get_draw_ctx(e); //获取事件对象的绘制上下文对象
lv_draw_rect(draw_ctx, &draw_rect_dsc, &a); //绘制点数值到a矩形区
ser = lv_chart_get_series_next(chart, ser); //获取下一条ser线
}
}
else if (code == LV_EVENT_RELEASED) { //点击松手事件
lv_obj_invalidate(chart); // 刷新CHART显示
}
}
创建CHART
/**
* Show the value of the pressed points
*/
static void lv_example_chart_4(void)
{
/*Create a chart*/
lv_obj_t* chart;
chart = lv_chart_create(lv_scr_act()); // 创建CHART对象
lv_obj_set_size(chart, 200, 150); //设置大小
lv_obj_center(chart); // 居中显示
lv_obj_add_event_cb(chart, event_cb, LV_EVENT_ALL, NULL); //添加所有事件
lv_obj_refresh_ext_draw_size(chart); // 调用该对象的祖先事件处理程序来刷新扩展绘制大小的值
/*Zoom in a little in X*/
lv_chart_set_zoom_x(chart, 800); //X方向放大CHART到800
/*Add two data series*/
lv_chart_series_t* ser1 = lv_chart_add_series(chart, lv_palette_main(LV_PALETTE_RED), LV_CHART_AXIS_PRIMARY_Y); //创建第一条ser线
lv_chart_series_t* ser2 = lv_chart_add_series(chart, lv_palette_main(LV_PALETTE_GREEN), LV_CHART_AXIS_PRIMARY_Y); //创建第二第ser线
uint32_t i;
for (i = 0; i < 10; i++) { //每条线都增加10个随机点值
lv_chart_set_next_value(chart, ser1, lv_rand(60, 90));
lv_chart_set_next_value(chart, ser2, lv_rand(10, 40));
}
}
运行效果图
相关文章
- 干货,看微信小程序后台用户数据如何演变和递增
- Qt-Qt使用lcdNumber显示LED数据时钟(Qt5.14.2+win10)
- aaronyang的百度地图API之LBS云[把数据丰富显示1/3]
- fastJson设置接口只接受json格式数据
- 大数据时代 树大数据意识
- 在DataGridView控件中设置数据显示格式
- Hibernate页面数据分页显示
- CSS 根据数据显示样式
- 大数据的七种商业化模式
- AngularJS学习--- 过滤器(filter),格式化要显示的数据 step 9
- 在DataGridView控件中设置数据显示格式
- 使用JavaScript实现Input输入数据后自动计算并实时显示
- FastAdmin控制管理员只显示自己添加的数据
- uni-app:使用uni-list显示列表数据之三:上拉加载更多(hbuilderx 3.6.18)
- 南大《探索数据的奥秘》课件示例代码笔记04
- 利用动态图层实现数据的实时显示(arcEngine IDynamiclayer)
- DEV Gridcontrol 格式化显示数据
- Atitit 歌曲年份抓取的nlp ai项目 原理通过百度搜索,抓取第一页数据,正则数字,过滤年份。。 显示格式。。歌曲,年份,年份周围前后40字符,方便核对 通过百科抓取比较准确 红尘情歌
- SAP UI5 应用开发教程之九十六 - SAP UI5 列表控件分页显示数据时,如何自定义分页大小试读版
- 小程序中实现获取全部数据
- 【阶段二】Python数据分析数据可视化工具使用05篇:统计直方图、面积图与箱型图
- extjs4 分页工具栏pagingtoolbar的每页显示数据combobox下拉框
- leaflet 加载数据,显示热力图(063)
- 深入浅出matplotlib(88):在坐标轴上显示数据点的密集程度
- 第二人生的源码分析(十七)人物Mesh数据显示的实现
- ADO.NET入门教程(二)了解.NET数据提供程序
- 指向字符型数据的指针变量
- wpf 客户端【JDAgent桌面助手】开发详解(三) 瀑布流效果实现与UI虚拟化优化大数据显示
- 扩展知识点---利用应用程序控制输入设备进行数据显示