Skip to main content

build GUIs from functions, using magic

Project description

icon

License Version conda-forge Python Version Build Status codecov

magicgui: build GUIs from functions, using magic.

📖 Docs

Installation

magicgui uses qtpy to support both pyside2 and pyqt5 backends. However, you must have one of those installed for magicgui to work.

install with pip

pip install magicgui[pyqt5]
# or
pip install magicgui[pyside2]

or with conda:

conda install -c conda-forge magicgui pyqt  # or pyside2 instead of pyqt

:information_source: If you'd like to help us extend support to a different backend, please open an issue.

Basic usage

from magicgui import magicgui
from enum import Enum

class Medium(Enum):
    Glass = 1.520
    Oil = 1.515
    Water = 1.333
    Air = 1.0003

# decorate your function with the @magicgui decorator
@magicgui(call_button="calculate", result_widget=True)
def snells_law(aoi=30.0, n1=Medium.Glass, n2=Medium.Water, degrees=True):
    import math

    aoi = math.radians(aoi) if degrees else aoi
    try:
        result = math.asin(n1.value * math.sin(aoi) / n2.value)
        return math.degrees(result) if degrees else result
    except ValueError:
        return "Total internal reflection!"

# your function is now capable of showing a GUI
snells_law.show(run=True)

snells

But that's just the beginning! Please see Documentation for many more details and usage examples.

Contributing

Contributions are welcome!

Please note: magicgui attempts to adhere to strict coding rules and employs the following static analysis tools to prevent errors from being introduced into the codebase:

To prevent continuous integration failures when contributing, please consider installing pre-commit in your environment to run all of these checks prior to checking in new code.

pre-commit install

Changelog

v0.2.11 (2021-09-11)

Full Changelog

Implemented enhancements:

Fixed bugs:

  • Fix call button text and and param options when using decorator on class method #276 (tlambert03)
  • Fix check for Optional Type #270 (tlambert03)
  • Change comparison to null_value in ValueWidget from == to is #267 (tlambert03)
  • Fix missing event emission when nullable widget is set to null value. #263 (tlambert03)
  • Fix optional annotation affecting later widgets #262 (tlambert03)
  • Fix RangeWidget with implicit optional type #257 (tlambert03)

Merged pull requests:

v0.2.10 (2021-07-11)

Full Changelog

Implemented enhancements:

  • Add tracking property to sliders. When False, changed only emits on release. #248 (tlambert03)
  • Add ValueWidget._nullable, and enable for categorical widgets #227 (tlambert03)

Fixed bugs:

Merged pull requests:

v0.2.9 (2021-04-05)

Full Changelog

Implemented enhancements:

Fixed bugs:

Merged pull requests:

v0.2.8 (2021-03-24)

Full Changelog

v0.2.8rc0 (2021-03-24)

Full Changelog

Implemented enhancements:

  • Update call button to default True when auto_call is False #194 (jni)
  • add RadioButtons widget #183 (tlambert03)

Fixed bugs:

Merged pull requests:

v0.2.7 (2021-02-28)

Full Changelog

Implemented enhancements:

Fixed bugs:

Merged pull requests:

v0.2.6rc0 (2021-01-25)

Full Changelog

v0.2.6 (2021-01-25)

Full Changelog

Merged pull requests:

v0.2.5 (2021-01-13)

Full Changelog

Merged pull requests:

v0.2.4 (2021-01-12)

Full Changelog

Merged pull requests:

  • Extend combobox api with set_choice, get_choice, del_choice #92 (tlambert03)

v0.2.3 (2021-01-08)

Full Changelog

Merged pull requests:

v0.2.2 (2021-01-02)

Full Changelog

Merged pull requests:

v0.2.1 (2020-12-29)

Full Changelog

Merged pull requests:

v0.2.0 (2020-12-26)

Full Changelog

Merged pull requests:

v0.1.6 (2020-07-23)

Full Changelog

v0.1.6rc0 (2020-07-23)

Full Changelog

Merged pull requests:

v0.1.5 (2020-05-24)

Full Changelog

Merged pull requests:

v0.1.4 (2020-05-19)

Full Changelog

Merged pull requests:

v0.1.3 (2020-05-04)

Full Changelog

Merged pull requests:

v0.1.2 (2020-03-06)

Full Changelog

Merged pull requests:

v0.1.1 (2020-02-19)

Full Changelog

Merged pull requests:

v0.1.0 (2020-02-18)

Full Changelog

Merged pull requests:

v0.0.8 (2020-02-11)

Full Changelog

v0.0.7 (2020-02-09)

Full Changelog

v0.0.6 (2020-02-09)

Full Changelog

* This Changelog was automatically generated by github_changelog_generator

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

magicgui-0.2.11.tar.gz (20.8 MB view details)

Uploaded Source

Built Distribution

magicgui-0.2.11-py2.py3-none-any.whl (125.8 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file magicgui-0.2.11.tar.gz.

File metadata

  • Download URL: magicgui-0.2.11.tar.gz
  • Upload date:
  • Size: 20.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.2 CPython/3.9.6

File hashes

Hashes for magicgui-0.2.11.tar.gz
Algorithm Hash digest
SHA256 93595972d37b05d0b3cb206c69ee26a21d28628f436dc58fd36f2bc70c4c442f
MD5 ce2fd1cc2d8672ed6114e19c06ed6084
BLAKE2b-256 05a485af765dd7bf314eee8f880b6a389f13e111efea8b22452d1013bd3d6dd6

See more details on using hashes here.

File details

Details for the file magicgui-0.2.11-py2.py3-none-any.whl.

File metadata

  • Download URL: magicgui-0.2.11-py2.py3-none-any.whl
  • Upload date:
  • Size: 125.8 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.2 CPython/3.9.6

File hashes

Hashes for magicgui-0.2.11-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 c5fb3fe4aa3db43ae1787f561230372dcf53a7835769b6bc743ed00c66e4f04b
MD5 2fc4b979efda5152fe86d8d0b79f1af5
BLAKE2b-256 4bdbc409e2073764e7bfd9407365a7ea08f43d49191df815cffe52bd5d837bc4

See more details on using hashes here.

Supported by

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