Toolkit to handle QWidgets for Napari Plugins.
Project description
Napari Toolkit
A napari toolkit for handling QWidgets to simplify the development of Napari plugins. The toolkit provides enhanced widgets, UI components, and utilities that streamline plugin creation, improve layout management, and enhance user interaction within the Napari ecosystem.
Installation
1. Install napari_toolkit
pip install napari-toolkit
or clone the repository:
git clone https://github.com/MIC-DKFZ/napari_toolkit.git
cd napari_toolkit
pip install -e ./
2. (Optional) Initialize your Plugin
Afterward it is recommended to generate you plugin with copier using the napari-plugin-template.
Gallery
from napari_toolkit.widget_gallery import show_widget_gallery
show_widget_gallery()
Widgets
from napari_toolkit.widgets import (setup_acknowledgements, setup_checkbox, setup_colorbar,
setup_colorpicker, setup_combobox, setup_dirselect,
setup_doubleslider, setup_doublespinbox, setup_editcolorpicker,
setup_editdoubleslider, setup_editslider, setup_fileselect,
setup_hswitch, setup_icon_wrapper, setup_iconbutton,
setup_label, setup_labeleddoubleslider, setup_labeledslider,
setup_layerselect, setup_lineedit, setup_plaintextedit,
setup_progressbar, setup_progressbaredit, setup_pushbutton,
setup_radiobutton, setup_savefileselect, setup_slider,
setup_spinbox, setup_textedit, setup_timeedit,
setup_togglebutton, setup_vswitch)
Buttons
QPushButton: A standard clickable button that can trigger an action.QRadioButton: A radio button for selecting one option in a group.QToggleButton: A clickable button that toggles between an "on" and "off" state.IconButton: A QPushButton with an Icon.
Spinbox
QSpinBox: A numerical input field allowing integer selection with up/down arrows.QDoubleSpinBox: A spinbox similar to QSpinBox but supports floating-point numbers.
Slider
QSlider: A horizontal or vertical slider for selecting an integer value.QDoubleSlider: A slider that supports floating-point values instead of integers.QLabeledSlider: A QSlider combined with a QLabel to display the value.QLabeledDoubleSlider: A QFloatSlider with an accompanying QLabel to show the selected value.QEditSlider: A QSlider paired with an editable text box for precise input.QEditDoubleSlider: A QFloatSlider paired with an editable text box for precise input.
Progressbar
QProgressBar: A visual progress indicator that displays completion percentage.QProgressbarEdit: A QProgressBar with an editable field for manual updates.
Text Edit
QLabel: A non-editable text display widget.QLineEdit: A single-line text input field.QTextEdit: A multi-line text editor with rich-text supportQPlainTextEdit: A multi-line text editor optimized for plain text input.
Switch
QVSwitch: A vertical switch that toggles between multiple states.QHSwitch: A horizontal switch that toggles between multiple states.
QComboBox
QComboBox: A dropdown menu for selecting one option from a list.
Checkbox
QCheckBox: A selectable box that toggles between checked and unchecked states.
Color
Colorbar: A widget displaying a colorbar.QColorPicker: A dialog for selecting colors.QEditColorPicker:A dialog for selecting colors, combined with a textfield and slider for changing efficiently rgba values.
QLayerSelect
QLayerSelect: A dropdown or list for selecting a specific layer type (Labels, Images,...) in the Napari Viewer.
File/Dir Select
QFileSelect: A file selection dialog to choose a file.QFileSelect(save directory): A file selection dialog specifically for saving directories.QDirSelect: A directory selection dialog.
QTimeEdit
QDateTimeEdit: A widget for selecting and editing date and time values.
Containers
from napari_toolkit.containers import (setup_hgroupbox, setup_scrollarea, setup_tabwidget,
setup_vcollapsiblegroupbox)
QGroupBox: A container with a title for grouping related widgets.QCollapsableGroupBox: A QGroupBox that can be expanded or collapsed to show/hide content.QScrollArea: A container that allows scrolling when content exceeds available space.QTabWidget: A widget with multiple tabs for organizing content.
Data Struct
from napari_toolkit.data_structs import setup_list, setup_table, setup_tree
QListWidget: A list-based widget that allows displaying and managing a list of items.QTableWidget: A table-based widget that provides an editable grid of rows and columns, commonly used for structured data representation.QTreeWidget: A hierarchical tree-based widget that enables organizing data in expandable and collapsible parent-child relationships.
Widget Value Handling
Easily get and set values for QWidgets in your Napari plugin. Note: These functions work for many widgets but are not guaranteed to support all
from napari_toolkit.utils.widget_getter import get_value
from napari_toolkit.utils.widget_setter import set_value
set_value(<QWidget>,<value>) # Sets the value of widget
_ = get_value(<QWidget>,<value>) # Retrieves the value of a widget
Acknowledgments
This repository is developed and maintained by the Applied Computer Vision Lab (ACVL) of Helmholtz Imaging.
This napari plugin was generated with copier using the napari-plugin-template.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file napari_toolkit-0.0.5.tar.gz.
File metadata
- Download URL: napari_toolkit-0.0.5.tar.gz
- Upload date:
- Size: 106.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a17e0fdb0117a9ab64591bbb30697965c9eb76356937c5b73137e704a337ec2b
|
|
| MD5 |
17e62697243d77ab04547cec0fe4645b
|
|
| BLAKE2b-256 |
76adc88b7424c65d55c17e278209e86882365333e10e9d37b96b3d550bc67569
|
File details
Details for the file napari_toolkit-0.0.5-py3-none-any.whl.
File metadata
- Download URL: napari_toolkit-0.0.5-py3-none-any.whl
- Upload date:
- Size: 123.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1074f0905784dde4613f8bcd2369c656c234f7b43f8bff20d23d643f9b973cca
|
|
| MD5 |
72135bf3abf5be068f6e74e7ec1298f2
|
|
| BLAKE2b-256 |
f63542ba8ad9e8144da4cc8b587f3cc93fdb2ff617b537afe7318810050302b7
|