1
0
mirror of https://github.com/lvgl/lvgl.git synced 2025-01-14 06:42:58 +08:00
lvgl/docs/widgets/bar.rst
2023-04-27 14:42:02 +02:00

83 lines
2.3 KiB
ReStructuredText

Bar (lv_bar)
============
Overview
********
The bar object has a background and an indicator on it. The width of the
indicator is set according to the current value of the bar.
Vertical bars can be created if the width of the object is smaller than
its height.
Not only the end, but also the start value of the bar can be set, which
changes the start position of the indicator.
Parts and Styles
****************
- :cpp:enumerator:`LV_PART_MAIN` The background of the bar and it uses the typical
background style properties. Adding padding makes the indicator
smaller or larger. The ``anim_time`` style property sets the
animation time if the values set with :cpp:enumerator:`LV_ANIM_ON`.
- :cpp:enumerator:`LV_PART_INDICATOR` The indicator itself; also uses all the typical
background properties.
Usage
*****
Value and range
---------------
A new value can be set by
``lv_bar_set_value(bar, new_value, LV_ANIM_ON/OFF)``. The value is
interpreted in a range (minimum and maximum values) which can be
modified with :cpp:expr:`lv_bar_set_range(bar, min, max)`. The default range is
0..100.
The new value in :cpp:func:`lv_bar_set_value` can be set with or without an
animation depending on the last parameter (``LV_ANIM_ON/OFF``).
Modes
-----
The bar can be one of the following modes:
- :cpp:enumerator:`LV_BAR_MODE_NORMAL` A normal bar as described above
- :cpp:enumerator:`LV_BAR_MODE_SYMMETRICAL` Draw the indicator from the zero value to current value. Requires a negative
minimum range and positive maximum range.
- :cpp:enumerator:`LV_BAR_MODE_RANGE` Allows setting the start value too by
``lv_bar_set_start_value(bar, new_value, LV_ANIM_ON/OFF)``. The start
value always has to be smaller than the end value.
Events
******
- :cpp:enumerator:`LV_EVENT_DRAW_PART_BEGIN` and :cpp:enumerator:`LV_EVENT_DRAW_PART_END` are sent
for the following parts:
- :cpp:enumerator:`LV_BAR_DRAW_PART_INDICATOR` The indicator of the bar
- ``part``: :cpp:enumerator:`LV_PART_INDICATOR`
- ``draw_area``: area of the indicator
- ``rect_dsc``
See the events of the `Base object </widgets/obj>`__ too.
Learn more about :ref:`events`.
Keys
****
No *Keys* are processed by the object type.
Learn more about :ref:`indev_keys`.
Example
*******
.. include:: ../examples/widgets/bar/index.rst
API
***