Blend Between Multiple Images in JupyterLab.
Project description
Jupyter compare_view
Blend between multiple images using a cell magic in JupyterLab using compare_view.
This project was called jupyter-splitview before.
Installation
pip install jupyter_compare_view
Example
import jupyter_compare_view
%%compare
from skimage import data
from skimage.color import rgb2gray
import matplotlib.pyplot as plt
img = data.chelsea()
grayscale_img = rgb2gray(img)
plt.imshow(img)
plt.axis("off")
plt.show()
plt.imshow(grayscale_img, cmap="gray")
plt.axis("off")
plt.show()
Another example:
from jupyter_compare_view import compare
compare(img, grayscale_img, cmap="gray", start_mode="horizontal", start_slider_pos=0.73)
The split view widget is still responsive after closing and reopening the notebook without running the cell again.
Notebook arguments
(Might still change in future)
-
--config '{"start_mode": "horizontal"}'
will init the compare-view in horizontal slider mode. -
--config '{"circle_size": 30}'
the circle size is now 30 pixel in circle mode. -
--config '{"show_slider": false}'
will hide the slider bar. -
--config '{"start_slider_pos": 0.73}'
will set the slider start position to 73%.- Removed in 0.1.1:
--position 73%
will no longer the slider start position to 73%.
- Removed in 0.1.1:
-
--config '{"start_mode": "horizontal","start_slider_pos": 0.73}'
will both set the start mode to horizontal and set the slider position -
--height 220
will set the height to 220 pixel. -
When
--height
is not provided, the default height of the widget is 300 pixel. -
--height auto
will set the height by the value of the first image's resolution in vertical direction. -
The widget's width will always be adjusted automatically.
Notebook formatting
Formatting with black can be done this way:
pip install 'black[jupyter]'
black --python-cell-magics compare compare_view_magic.ipynb
Developer Installation
git clone --recurse https://github.com/Octoframes/jupyter_compare_view
(Note: In case that the repo was already cloned e.g. with the GitHub Desktop client, the GitHub submodule has to be loaded viagit submodule update --init --recursive
)poetry install
Note: The IPython extension autoreload
reloads modules before every cell execution. Very useful when debugging the %%capture
cell magic!
Just add these lines into the first jupyter cell.
%load_ext autoreload
%autoreload 2
import jupyter_compare_view
Changelog
0.2.4
CHange to importlib #48
0.2.3
Remove setuptools dependency
0.2.2
- Remove python3.7 support #46
- fix jupyterlite example
0.2.1
- Support python 3.11
0.2.0
- Implemented
capture
to display the compare view frame without calling the cell magic. This is not an ipywidget as mentioned here. - Update version requirements #42
0.1.5
- BugFix: Remove black import that was added by accident.
0.1.4
%%compare
is now%%splity
.%%splity
is deprecated.- Update examples
0.1.3
- octoframes github actions setup
0.1.2
- Move the repo from kolibril13/jupyter-spitview to octoframes/jupyter_compare_view
- Rename all references
0.1.1
- Drop the github.com/NUKnightLab/juxtapose backend and replace it with github.com/Octoframes/compare_view.
- Implement horizontal slider
- Implement Round Mask
0.1.0
- Update dependencies
- Update JupyterLite version
- Fix: in JupyterLite, a figure has to be explicitly called by plt.show()
- Better installation workflow
0.0.8
- Fixing problem with cell id and notebook reloading
- Experimentally lowering the dependencies to
ipython = ">=6.0.0"
andipykernel = ">=5.0.0"
so that jupyterlite will work hopefully.
0.0.7
- Rewrite of the import of JavaScript and CSS to make it more robust when closing and opening the notebook
- First attempt to add a JupyterLite example.
0.0.6
Fix poetry workflow
0.0.5
- Ship the javascript directly with the package, so no internet connection is required
- use jinja2 to save HTML in separate file
- load stylesheet and javascript only once in the beginning, and not in every cell that contains the splitview widget.
0.0.4
- New
--height
parameter
0.0.3
- default slider position
- updated minimal example
- internal code restructuring and formatting
- Handle import in non jupyter context
0.0.2
- save images in base64 strings and don't load images to disk (increases package security).
0.0.1
- First release
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
File details
Details for the file jupyter_compare_view-0.2.4.tar.gz
.
File metadata
- Download URL: jupyter_compare_view-0.2.4.tar.gz
- Upload date:
- Size: 12.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.4.0 CPython/3.9.16 Linux/5.15.0-1034-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0edae58d8cc47450d7a545c74a9d5cdfe0e20dc9b1003939d5130737177643c1 |
|
MD5 | d547816543be579db4a230843dc1d7b4 |
|
BLAKE2b-256 | 9c4b382b3882faa4de741bf4a923d7681d597d5e3694ae2076047d45f619dcce |
File details
Details for the file jupyter_compare_view-0.2.4-py3-none-any.whl
.
File metadata
- Download URL: jupyter_compare_view-0.2.4-py3-none-any.whl
- Upload date:
- Size: 11.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.4.0 CPython/3.9.16 Linux/5.15.0-1034-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5b31e56c38d4ace49cca9acc52f8aa3f9013a4bafbdf9c7bc3a70644db03d7dc |
|
MD5 | 773aa7d00b8b4830f03fb4abb8dd6a9b |
|
BLAKE2b-256 | a2669b31bc102a9b959ca60aa4b70153809e8d4773e520618cb115860105e50a |