lvgl8.2 lv_obj_set_grid_cell
时间: 2023-08-31 18:05:10 浏览: 252
`lv_obj_set_grid_cell()` 是 LittlevGL 中的一个函数,它可以用来设置对象在网格布局中的单元格位置。
函数原型如下:
```c
void lv_obj_set_grid_cell(lv_obj_t * obj, uint8_t x, uint8_t y, uint8_t colspan, uint8_t rowspan, lv_grid_align_t align);
```
其中,参数含义如下:
- `obj`:需要设置的对象指针。
- `x`:单元格横坐标。
- `y`:单元格纵坐标。
- `colspan`:对象跨越的列数。
- `rowspan`:对象跨越的行数。
- `align`:对象在单元格中的对齐方式。
示例代码:
```c
lv_obj_t * obj = lv_obj_create(lv_scr_act());
lv_obj_set_size(obj, 50, 50);
lv_obj_set_grid_cell(obj, 1, 1, 2, 1, LV_GRID_ALIGN_CENTER);
```
这段代码创建了一个大小为 50x50 的对象,将其设置在网格布局的第二行第二列,跨越两列一行,并且在单元格中居中对齐。
相关问题
lvgl8 lv_obj_set_grid_dsc_array
`lv_obj_set_grid_dsc_array()` 是一个函数,它用于将一个对象的网格描述数组设置为指定的值。网格描述数组用于定义对象的子对象布局。该函数的原型如下:
```
void lv_obj_set_grid_dsc_array(lv_obj_t * obj, const lv_grid_dsc_t * dsc)
```
函数参数说明如下:
- `obj`: 要设置网格描述数组的对象。
- `dsc`: 指向要设置为对象网格描述数组的指针。
这个函数会覆盖先前设置的网格描述数组。传递给该函数的指针必须指向包含正确数量元素的 `lv_grid_dsc_t` 数组。例如,如果您希望网格描述数组包含 2 行和 3 列,则可以使用以下代码:
```
static lv_grid_t grid_row_col[2][3];
lv_obj_set_grid_dsc_array(obj, &grid_row_col[0][0]);
```
这将设置对象的网格描述数组为 `grid_row_col`。
请注意,此函数仅设置网格描述数组。要创建网格,请使用 `lv_obj_set_grid_cell()` 函数。
void lv_example_scroll_2_dir(void) { #if 1 lv_obj_t* cont = lv_obj_create(lv_scr_act()); lv_obj_set_size(cont, 400, 300); lv_obj_add_flag(cont, LV_OBJ_FLAG_SCROLL_ONE); /*Allow max 1 page swipe*/ lv_obj_set_scroll_snap_x(cont, LV_SCROLL_SNAP_CENTER); /*Snap a page to the center*/ lv_obj_set_scrollbar_mode(cont, LV_SCROLLBAR_MODE_OFF); lv_obj_add_event_cb(cont, scroll_end_event, LV_EVENT_SCROLL_BEGIN/*LV_EVENT_ALL*//*LV_EVENT_SCROLL*//*LV_EVENT_SCROLL_END*/, NULL); lv_obj_add_event_cb(cont, scroll_end_event, LV_EVENT_SCROLL_END, NULL); lv_obj_center(cont); /*A grid for the left center and right pages*/ lv_coord_t col_dsc[] = { LV_GRID_CONTENT, LV_GRID_CONTENT, LV_GRID_CONTENT, LV_GRID_CONTENT, LV_GRID_CONTENT, LV_GRID_TEMPLATE_LAST }; lv_coord_t row_dsc[] = { LV_GRID_FR(1), LV_GRID_TEMPLATE_LAST }; lv_obj_set_grid_dsc_array(cont, col_dsc, row_dsc); /*Create 5 pages*/ for (int i = 0; i < 10; i++) { lv_obj_t* obj = lv_obj_create(cont); lv_obj_set_size(obj, lv_pct(33), lv_pct(100)); lv_obj_t* label = lv_label_create(obj); lv_label_set_text_fmt(label, "Page %d", i); lv_obj_set_style_border_width(obj, 0, 0); } /*Page 2, 3 hidden, page 4, 0, 1 are placed to the grid */ //lv_obj_add_flag(lv_obj_get_child(cont, 2), LV_OBJ_FLAG_HIDDEN); //lv_obj_add_flag(lv_obj_get_child(cont, 3), LV_OBJ_FLAG_HIDDEN); //lv_obj_set_grid_cell(lv_obj_get_child(cont, 4), LV_GRID_ALIGN_CENTER, 0, 1, LV_GRID_ALIGN_CENTER, 0, 1); //lv_obj_set_grid_cell(lv_obj_get_child(cont, 0), LV_GRID_ALIGN_CENTER, 1, 1, LV_GRID_ALIGN_CENTER, 0, 1); //lv_obj_set_grid_cell(lv_obj_get_child(cont, 1), LV_GRID_ALIGN_CENTER, 2, 1, LV_GRID_ALIGN_CENTER, 0, 1); lv_obj_set_grid_cell(lv_obj_get_child(cont, 0), LV_GRID_ALIGN_CENTER, 0, 1, LV_GRID_ALIGN_CENTER, 0, 1); lv_obj_set_grid_cell(lv_obj_get_child(cont, 1), LV_GRID_ALIGN_CENTER, 1, 1, LV_GRID_ALIGN_CENTER, 0, 1); lv_obj_set_grid_cell(lv_obj_get_child(cont, 2), LV_GRID_ALIGN_CENTER, 2, 1, LV_GRID_ALIGN_CENTER, 0, 1); lv_obj_set_grid_cell(lv_obj_get_child(cont, 3), LV_GRID_ALIGN_CENTER, 3, 1, LV_GRID_ALIGN_CENTER, 0, 1); lv_obj_set_grid_cell(lv_obj_get_child(cont, 4), LV_GRID_ALIGN_CENTER, 4, 1, LV_GRID_ALIGN_CENTER, 0, 1); /*Be sure page 0 is centered*/ lv_obj_scroll_to_view(lv_obj_get_child(cont, 0), LV_ANIM_OFF); }帮我注释一下这段代码
这段代码是 LittlevGL (LVGL)的示例代码,实现了一个可以左右滑动的页面(类似于轮播图),页面可以居中对齐。下面是代码注释:
```C
void lv_example_scroll_2_dir(void) {
/*创建一个容器,作为滑动页面的容器*/
lv_obj_t* cont = lv_obj_create(lv_scr_act());
lv_obj_set_size(cont, 400, 300);
/*设置容器只能左右滑动一页*/
lv_obj_add_flag(cont, LV_OBJ_FLAG_SCROLL_ONE);
/*设置容器滑动时,页面停留在中心*/
lv_obj_set_scroll_snap_x(cont, LV_SCROLL_SNAP_CENTER);
/*关闭滚动条*/
lv_obj_set_scrollbar_mode(cont, LV_SCROLLBAR_MODE_OFF);
/*容器添加滑动事件*/
lv_obj_add_event_cb(cont, scroll_end_event, LV_EVENT_SCROLL_BEGIN/*LV_EVENT_ALL*//*LV_EVENT_SCROLL*//*LV_EVENT_SCROLL_END*/, NULL);
lv_obj_add_event_cb(cont, scroll_end_event, LV_EVENT_SCROLL_END, NULL);
/*容器居中*/
lv_obj_center(cont);
/*创建一个网格,用于布局页面*/
lv_coord_t col_dsc[] = { LV_GRID_CONTENT, LV_GRID_CONTENT, LV_GRID_CONTENT, LV_GRID_CONTENT, LV_GRID_CONTENT, LV_GRID_TEMPLATE_LAST };
lv_coord_t row_dsc[] = { LV_GRID_FR(1), LV_GRID_TEMPLATE_LAST };
lv_obj_set_grid_dsc_array(cont, col_dsc, row_dsc);
/*创建 10 个页面*/
for (int i = 0; i < 10; i++) {
lv_obj_t* obj = lv_obj_create(cont);
lv_obj_set_size(obj, lv_pct(33), lv_pct(100));
lv_obj_t* label = lv_label_create(obj);
lv_label_set_text_fmt(label, "Page %d", i);
lv_obj_set_style_border_width(obj, 0, 0);
}
/*将第 0、1、2、3、4 个页面放到网格中,使它们居中*/
lv_obj_set_grid_cell(lv_obj_get_child(cont, 0), LV_GRID_ALIGN_CENTER, 0, 1, LV_GRID_ALIGN_CENTER, 0, 1);
lv_obj_set_grid_cell(lv_obj_get_child(cont, 1), LV_GRID_ALIGN_CENTER, 1, 1, LV_GRID_ALIGN_CENTER, 0, 1);
lv_obj_set_grid_cell(lv_obj_get_child(cont, 2), LV_GRID_ALIGN_CENTER, 2, 1, LV_GRID_ALIGN_CENTER, 0, 1);
lv_obj_set_grid_cell(lv_obj_get_child(cont, 3), LV_GRID_ALIGN_CENTER, 3, 1, LV_GRID_ALIGN_CENTER, 0, 1);
lv_obj_set_grid_cell(lv_obj_get_child(cont, 4), LV_GRID_ALIGN_CENTER, 4, 1, LV_GRID_ALIGN_CENTER, 0, 1);
/*将第 2、3 个页面隐藏*/
//lv_obj_add_flag(lv_obj_get_child(cont, 2), LV_OBJ_FLAG_HIDDEN);
//lv_obj_add_flag(lv_obj_get_child(cont, 3), LV_OBJ_FLAG_HIDDEN);
/*将页面 0 居中显示*/
lv_obj_scroll_to_view(lv_obj_get_child(cont, 0), LV_ANIM_OFF);
}
```
注释中已经解释了每一行代码的作用,其中有些代码是被注释掉了的,这可能是作者在开发过程中的调试代码。
阅读全文
相关推荐
![rar](https://img-home.csdnimg.cn/images/20241231044955.png)
![7z](https://img-home.csdnimg.cn/images/20241231044736.png)
![rar](https://img-home.csdnimg.cn/images/20241231044955.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)