Skip to main content

build GUIs from functions, using magic.

Project description

icon

License Version Python Version Build Status Docs Code style: black codecov

magicgui: build GUIs from functions, using magic.

📖 Docs

Installation

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

pip install magicgui pyside2  # or pyqt5 instead of pyside2

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

Basic usage

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")
def snells_law(aoi=30.0, n1=Medium.Glass, n2=Medium.Water, degrees=True):
    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 will now have a new attribute "Gui"
# call it to create (and optionally show) the new GUI!
snell_gui = snells_law.Gui(show=True)

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

To run pyright, you will need to install with npm install -g pyright, then run pyright. See their docs for details.

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.1.1.tar.gz (14.4 kB view details)

Uploaded Source

Built Distribution

magicgui-0.1.1-py2.py3-none-any.whl (13.9 kB view details)

Uploaded Python 2 Python 3

File details

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

File metadata

  • Download URL: magicgui-0.1.1.tar.gz
  • Upload date:
  • Size: 14.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.8.0

File hashes

Hashes for magicgui-0.1.1.tar.gz
Algorithm Hash digest
SHA256 2376fdf1d50cf25d7ea6f5f9f3bbcec8ad74cebcbbe25f433b867edca62373e5
MD5 453fdf9d2fa9c485af24cb9aa803542e
BLAKE2b-256 562d745890d29e25f972e1d787bc59e9ff2b5b55b65ffc36a9688d520f5d8883

See more details on using hashes here.

File details

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

File metadata

  • Download URL: magicgui-0.1.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 13.9 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.8.0

File hashes

Hashes for magicgui-0.1.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 42a92fb5ba67c22ade1c4f41268ab80c8ff3f33b16bfcf3bf516b78173f5f426
MD5 53ce2e7d802fc9c17840be2b2b7dfe06
BLAKE2b-256 ead35c37908c6ffcce96b765529a304d9b3b26a998652d3f522134726c61b5ad

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