2023-04-27 06:42:02 -06:00
|
|
|
Tabview (lv_tabview)
|
|
|
|
====================
|
|
|
|
|
|
|
|
Overview
|
|
|
|
********
|
|
|
|
|
|
|
|
The Tab view object can be used to organize content in tabs. The Tab
|
|
|
|
view is built from other widgets:
|
|
|
|
|
|
|
|
- Main container: `lv_obj </widgets/obj>`__
|
|
|
|
- Tab buttons: `lv_btnmatrix </widgets/btnmatrix>`__
|
|
|
|
- Container for the tabs: `lv_obj </widgets/obj>`__
|
|
|
|
- Content of the tabs: `lv_obj </widgets/obj>`__
|
|
|
|
|
|
|
|
The tab buttons can be positioned on the top, bottom, left and right
|
|
|
|
side of the Tab view.
|
|
|
|
|
|
|
|
A new tab can be selected either by clicking on a tab button or by
|
|
|
|
sliding horizontally on the content.
|
|
|
|
|
|
|
|
Parts and Styles
|
|
|
|
****************
|
|
|
|
|
|
|
|
There are no special parts on the Tab view but the ``lv_obj`` and
|
2023-07-27 13:35:12 -07:00
|
|
|
``lv_btnmatrix`` widgets are used to create the Tab view.
|
2023-04-27 06:42:02 -06:00
|
|
|
|
|
|
|
Usage
|
|
|
|
*****
|
|
|
|
|
|
|
|
Create a Tab view
|
|
|
|
-----------------
|
|
|
|
|
|
|
|
:cpp:expr:`lv_tabview_create(parent, tab_pos, tab_size)` creates a new empty
|
|
|
|
Tab view. ``tab_pos`` can be ``LV_DIR_TOP/BOTTOM/LEFT/RIGHT`` to
|
|
|
|
position the tab buttons to a side. ``tab_size`` is the height (in case
|
|
|
|
of ``LV_DIR_TOP/BOTTOM``) or width (in case of ``LV_DIR_LEFT/RIGHT``)
|
|
|
|
tab buttons.
|
|
|
|
|
|
|
|
Add tabs
|
|
|
|
--------
|
|
|
|
|
|
|
|
New tabs can be added with :cpp:expr:`lv_tabview_add_tab(tabview, "Tab name")`.
|
|
|
|
This will return a pointer to an `lv_obj </widgets/obj>`__ object where
|
2023-04-27 11:47:13 -06:00
|
|
|
the tab's content can be created.
|
2023-04-27 06:42:02 -06:00
|
|
|
|
|
|
|
Rename tabs
|
|
|
|
-----------
|
|
|
|
|
|
|
|
A tab can be renamed with
|
|
|
|
:cpp:expr:`lv_tabview_rename_tab(tabview, tab_id, "New Name")`.
|
|
|
|
|
|
|
|
Change tab
|
|
|
|
----------
|
|
|
|
|
|
|
|
To select a new tab you can:
|
|
|
|
|
|
|
|
- Click on its tab button
|
|
|
|
- Slide horizontally
|
2023-10-31 19:13:45 +01:00
|
|
|
- Use :cpp:expr:`lv_tabview_set_active(tabview, id, LV_ANIM_ON)` function
|
2023-04-27 06:42:02 -06:00
|
|
|
|
|
|
|
Get the parts
|
|
|
|
-------------
|
|
|
|
|
|
|
|
:cpp:expr:`lv_tabview_get_content(tabview)` returns the container for the tabs,
|
|
|
|
:cpp:expr:`lv_tabview_get_tab_btns(tabview)` returns the Tab buttons object
|
|
|
|
which is a `Button matrix </widgets/btnmatrix>`__.
|
|
|
|
|
|
|
|
Events
|
|
|
|
******
|
|
|
|
|
|
|
|
- :cpp:enumerator:`LV_EVENT_VALUE_CHANGED` Sent when a new tab is selected by sliding
|
2023-10-31 19:13:45 +01:00
|
|
|
or clicking the tab button. :cpp:expr:`lv_tabview_get_tab_active(tabview)`
|
2023-04-27 06:42:02 -06:00
|
|
|
returns the zero based index of the current tab.
|
|
|
|
|
|
|
|
Learn more about :ref:`events`.
|
|
|
|
|
|
|
|
Keys
|
|
|
|
****
|
|
|
|
|
|
|
|
Keys have effect only on the tab buttons (Button matrix). Add manually
|
|
|
|
to a group if required.
|
|
|
|
|
|
|
|
Learn more about :ref:`indev_keys`.
|
|
|
|
|
|
|
|
Example
|
|
|
|
*******
|
|
|
|
|
|
|
|
.. include:: ../examples/widgets/tabview/index.rst
|
|
|
|
|
|
|
|
API
|
|
|
|
***
|