Create interactive Matplotlib figures!
Project description
Interactive Figure
This package serves for students to learn the basics of Python, Matplotlib and setting up reaction time experiments (visual search task, Stroop task, etc.). For a more accurate timing environment one should refer to e.g. PsychoPy.
This is currently used at the University of Amsterdam (UvA) in the course Introduction to Python Programming for Neuroscientists.
Package created using Hatch.
Installation
pip install interactive-figure
Usage
from interactive_figure import interactive_figure
interactive_figure.create()
# Stall until user input is received.
interactive_figure.wait_for_interaction()
key = interactive_figure.get_last_keypress()
print(f"Pressed key: {key}")
interactive_figure.close()
Demos can be found in the demo folder on GitHub.
Functionality
User interaction
- Capture key presses, button presses and mouse location
Figure control
- Create
- Toggle fullscreen
- Clear
- Wait
- Wait for interaction (optionally timeout)
- Draw
- Close
Limitations
- Waiting for user input will not work in Jupyter Notebooks and the interactive interpreter due to the way Matplotlib handles events.
- Automated testing is hard since tests should cover multiple backends (macosx, QtAgg, Tkgg) on multiple platforms (Windows, macOS, Linux). Tips are very welcome!
Development
# Setup
pipx install hatch
hatch shell
# Build
hatch build -c
docs_source/generate_docs.sh
Links
Project details
Release history Release notifications | RSS feed
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
Close
Hashes for interactive_figure-0.3.2-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | ff1bd37f4fd3eef332af2e6dc117054d681fc7c753708515b10f744d2395911b |
|
MD5 | 06c1a1154d2a65961f047033243f59cd |
|
BLAKE2b-256 | e3144e5dc8c5baf41d32173935943b31cf95af7d703a043361aad01d38e774ec |