2.1 KiB
(user.widgets.spiral_progress_bar)=
Ring Progress Bar
Purpose:
The ring Progress Bar widget is a circular progress bar that can be used to visualize the progress of a task. The widget is designed to be used in applications where the progress of a task is represented as a percentage. The Spiral Progress Bar widget is a part of the BEC Widgets library and can be controlled directly using its API, or hooked up to the progress of a device readback or scan.
Key Features:
- circular progress bar to show updates on the progress of a task.
- hooks to update the progress bar from a device readback or scan.
- multiple progress rings to show different tasks in parallel.
Code example:
The following code snipped demonstrates how to create a RingProgressBar
using BEC Widgets within BEC.
# adds a new dock with a ring progress bar
progress = gui.add_dock().add_widget("RingProgressBar")
# customize the size of the ring
progress.set_line_width(20)
By default, the Ring Progress Bar widget will display a single ring. To add more rings, use the add_ring method:
# adds a new dock with a ring progress bar
progress.add_ring()
To access rings and specify their properties, you can use progress.rings
with an index specifying the ring index (
starting from 0):
progress.rings[0].set_line_width(20) # set the width of the first ring
progress.rings[1].set_line_width(10) # set the width of the second ring
By default, the RingProgressBar
widget is set with progress.enable_auto_update(True)
, which will automatically
update the bars in the widget. To manually set updates for each progress bar, use the set_update method. Note that
manually updating a ring will disable the automatic update for the whole widget:
progress.rings[0].set_update("scan") # set the update of the first ring to be an overall scan progress
progress.rings[1].set_update("device",
"samx") # set the update of the second ring to be a device readback (in this case, samx)