You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
116 lines
2.5 KiB
116 lines
2.5 KiB
11 months ago
|
.. _lv_tabview:
|
||
|
|
||
|
====================
|
||
|
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: :ref:`lv_obj`
|
||
|
- Tab buttons: an :ref:`lv_obj` with :ref:`lv_button`
|
||
|
- Container for the tabs: :ref:`lv_obj`
|
||
|
- Content of the tabs: :ref:`lv_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.
|
||
|
|
||
|
.. _lv_tabview_parts_and_styles:
|
||
|
|
||
|
Parts and Styles
|
||
|
****************
|
||
|
|
||
|
There are no special parts on the Tab view but the ``lv_obj`` and
|
||
|
``lv_button`` widgets are used to create the Tab view.
|
||
|
|
||
|
.. _lv_tabview_usage:
|
||
|
|
||
|
Usage
|
||
|
*****
|
||
|
|
||
|
Create a Tab view
|
||
|
-----------------
|
||
|
|
||
|
:cpp:expr:`lv_tabview_create(parent)` creates a new empty Tab view.
|
||
|
|
||
|
Add tabs
|
||
|
--------
|
||
|
|
||
|
New tabs can be added with :cpp:expr:`lv_tabview_add_tab(tabview, "Tab name")`.
|
||
|
This will return a pointer to an :ref:`lv_obj` object where
|
||
|
the tab's content can be created.
|
||
|
|
||
|
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
|
||
|
- Use :cpp:expr:`lv_tabview_set_active(tabview, id, LV_ANIM_ON)` function
|
||
|
|
||
|
|
||
|
Set tab bar position
|
||
|
--------------------
|
||
|
|
||
|
Using the :cpp:expr:`lv_tabview_set_tab_bar_position(tabview, LV_DIR_LEFT/RIGHT/TOP/BOTTOM)`
|
||
|
the tab bar can be moved to any sides.
|
||
|
|
||
|
Set tab bar size
|
||
|
----------------
|
||
|
|
||
|
The size of the tab bar can be adjusted by :cpp:expr:`lv_tabview_set_tab_bar_size(tabview, size)`
|
||
|
In case of vertical arrangement is means the height of the tab bar, and in horizontal
|
||
|
arrangement it means the width.
|
||
|
|
||
|
Get the parts
|
||
|
-------------
|
||
|
|
||
|
- :cpp:expr:`lv_tabview_get_content(tabview)` returns the container for tabs content
|
||
|
- :cpp:expr:`lv_tabview_get_tab_bar(tabview)` returns the container for tabs buttons
|
||
|
|
||
|
.. _lv_tabview_events:
|
||
|
|
||
|
Events
|
||
|
******
|
||
|
|
||
|
- :cpp:enumerator:`LV_EVENT_VALUE_CHANGED` Sent when a new tab is selected by sliding
|
||
|
or clicking the tab button. :cpp:expr:`lv_tabview_get_tab_active(tabview)`
|
||
|
returns the zero based index of the current tab.
|
||
|
|
||
|
Learn more about :ref:`events`.
|
||
|
|
||
|
.. _lv_tabview_keys:
|
||
|
|
||
|
Keys
|
||
|
****
|
||
|
|
||
|
Keys have effect only on the tab buttons.
|
||
|
Add manually to a group if required.
|
||
|
|
||
|
Learn more about :ref:`indev_keys`.
|
||
|
|
||
|
.. _lv_tabview_example:
|
||
|
|
||
|
Example
|
||
|
*******
|
||
|
|
||
|
.. include:: ../examples/widgets/tabview/index.rst
|
||
|
|
||
|
.. _lv_tabview_api:
|
||
|
|
||
|
API
|
||
|
***
|