Skip to main content

Tool to draw regions of interest (ROIs)

Project description

[[file:https://travis-ci.org/jdoepfert/roipoly.py.svg?branch=master]]

* roipoly.py

Small python module to select a polygonal region of interest (ROI) in
an image that is stored as a numpy array. The usage is similar to the
[[https://mathworks.com/help/images/ref/roipoly.html][roipoly]]
function present in the image processing toolbox from MATLAB.

[[file:/img/ROIs.PNG]]

** Installation
Either from PyPi: ~pip install roipoly~

Or get the latest version from github: ~pip install git+https://github.com/jdoepfert/roipoly.py~

** Running the examples

Basic usage:
#+begin_SRC shell
python examples/basic_example.py
#+end_SRC

Drawing multiple ROIs:
#+begin_SRC shell
python examples/multi_roi_example.py
#+end_SRC

** Usage
*** Creating a ROI
In your python code, import the roipoly module using
#+begin_SRC python
from roipoly import RoiPoly
#+end_SRC
To draw a ROI within an image present as a numpy array, show it first
using e.g. pylabs's =imshow=:
#+begin_SRC python
from matplotlib import pyplot as plt
plt.imshow(image)
#+end_SRC
Then let the user draw a polygonal ROI within that image:
#+begin_SRC python
my_roi = RoiPoly(color='r') # draw new ROI in red color
#+end_SRC
This lets the user interactively draw a polygon within the image by clicking
with the left mouse button to select the vertices of the polygon. To
close the polygon, click with the right mouse button. After finishing
the ROI, the current figure is closed so that the execution of the code
can continue.


*** Displaying a ROI
To display a created ROI within an image, first display the image as
described above using e.g. =imshow=. Then,
#+begin_SRC python
my_roi.display_roi()
#+end_SRC
shows the created ROI on top of this image.

Display multiple ROIs like so:
#+begin_SRC python
for r in [my_roi1, my_roi2, my_roi3]
r.display_roi()
#+end_SRC

To additionally show the mean pixel grey value inside a ROI in the
image, type
#+begin_SRC python
my_roi.display_mean(image)
#+end_SRC

*** Extracting a binary mask image
The function =get_mask(image)= creates a binary mask for a certain ROI
instance, that is, a 2D numpy array of the size of the image array,
whose elements are =True= if they lie inside the ROI polygon,
and =False= otherwise.
#+begin_SRC python
mask = my_roi.get_mask(image)
plt.imshow(mask) # show the binary signal mask
#+end_SRC

This mask image can be used to e.g. calculate the mean pixel intensity
in an image over that ROI:
#+begin_SRC python
mean = plt.mean(image[mask])
#+end_SRC

*** Drawing multiple ROIs
See =examples/multi_roi_example.py=

** Credits
Based on a code snippet originally posted [[http://matplotlib.1069221.n5.nabble.com/How-to-draw-a-region-of-interest-td4972.html][here]] by Daniel Kornhauser.

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

roipoly-0.5.3.tar.gz (9.4 kB view details)

Uploaded Source

File details

Details for the file roipoly-0.5.3.tar.gz.

File metadata

  • Download URL: roipoly-0.5.3.tar.gz
  • Upload date:
  • Size: 9.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.5.0.1 requests/2.22.0 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.7.6

File hashes

Hashes for roipoly-0.5.3.tar.gz
Algorithm Hash digest
SHA256 50e44770518429a83776ce204e1adf1dd344ca528a4a4a9a4d7fae0e3ef0a6b0
MD5 048223b93995e80333abfd78c2649e5d
BLAKE2b-256 2e519917247a1fd36501f88c24e9d49e396fa84e74c14bb47e6bc8dc76e13a4b

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