Skip to main content

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 support
  • QPlainTextEdit: 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

napari_toolkit-0.0.7.tar.gz (106.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

napari_toolkit-0.0.7-py3-none-any.whl (123.4 kB view details)

Uploaded Python 3

File details

Details for the file napari_toolkit-0.0.7.tar.gz.

File metadata

  • Download URL: napari_toolkit-0.0.7.tar.gz
  • Upload date:
  • Size: 106.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.7

File hashes

Hashes for napari_toolkit-0.0.7.tar.gz
Algorithm Hash digest
SHA256 cc0c64df1392f847b2739e494030d6be9bc1751e1c8dfb37808dd7ceaa3876d6
MD5 3bfad95070748d802698665918aa7305
BLAKE2b-256 50c0eaf6752ce3067c8405b7240c3e25449a3081dac70107a41924cc21753d10

See more details on using hashes here.

File details

Details for the file napari_toolkit-0.0.7-py3-none-any.whl.

File metadata

  • Download URL: napari_toolkit-0.0.7-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

Hashes for napari_toolkit-0.0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 d8a61bf7c9131f3cb2d85f8af86f9c005d389c13f7131743ff1b3f33ed61efde
MD5 14a5850953acebeee7fe6c66d743fb36
BLAKE2b-256 c51be7ddf38cf994d8bab20ef02c523d658e9a3e328242f8f136ed77b771c96e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page