Skip to main content

A Python package that can be used to extract colours from images for use in data visualization projects.

Project description

ci-cd codecov Documentation Status License: MIT Project Status: Active – The project has reached a stable, usable state and is being actively developed. Python Versions

colourpycker

colourpycker is a Python package that can be used to extract colours from images for use in data visualization projects.

Overview

This package allows users to integrate unique colour palettes into their graphs for exploratory data analysis. The colours are retrieved from image data (via URL) and are selected based on their overall prominence in a picture. While there are existing tools that are used to process images and create figures independently, we aim to combine both of their functionalities to help programmers easily design effective and creative visualizations.

Where Our Package Fits

As mentioned, there are packages in Python that are capable of colour extraction and data visualization, but none exist that combine the two functions to our knowledge. Some examples of such packages are as follows:

Pillow: This package adds image processing capabilities into Python interpreters. It can perform various image transformations but does not allow for colours to be extracted directly for further use.

extcolors: This extracts RGB colour codes from images into text along with the occurrence rate (proportion of pixels). However, we would need to use additional packages to create plots using common colours in the image. This would also not allow us to invert them, or create a palette.

color-extraction: This provides the most similar color for the pixels of an image from a palette of predefined colors.

Pylette: This extracts colours and creates a colour palette based on an input image. This palette can be dumped into a csv file that would then need to be processed for use in data visualizations.

Therefore, we are developing colourpycker to bridge this gap.

Installation

$ pip install colourpycker

Functions

get_color_palette(img_url, tolerance, limit): This function extracts the most common colors from an image and returns them as a data frame of hex color codes and RGB values. The user is provided with the ability to set tolerance while picking colors, along with the number of colors that should be returned.

donut(img_url, num_clrs, tolerance, img_size, plot_show=True): This function creates a donut chart with information on the $n$ most common colors in the linked image. The user specifies the image, the number of colors, the tolerance for how similar the colors will be, and specifies the size of the resulting chart in pixels.

scatterplot(img_url, dataset, x, y, fill, tolerance): This function creates a simple scatterplot using the colours selected from the image based on a dataset of the users choosing.

negative(img_url, num_colours, tolerance): This function extracts the most common $n$ colours from an image (via URL) and inverts them to retrieve the negative version of a colour palette, returning the associated HEX codes and RGB values for each colour.

Usage

For more examples on how to use colourpycker, a Jupyter Notebook can be found here with additional use cases.

from colourpycker.colourpycker import scatterplot, negative, get_color_palette, donut

get_color_palette('https://i.imgur.com/s9egWBB.jpg', 20, 5)

donut('https://i.imgur.com/s9egWBB.jpg', 5, 20, 400)

scatterplot('https://i.imgur.com/s9egWBB.jpg', penguins, 'bill_length_mm', 'body_mass_g', 'species', 50)

negative("https://i.imgur.com/s9egWBB.jpg", 10, 20)

Contributing

Interested in contributing? Check out the contributing guidelines and list of contributors who worked on this project. Please note that this project is released with a Code of Conduct. By contributing to this project, you agree to abide by its terms.

License

colourpycker was created by Shaun Hutchinson, Arjun Radhakrishnan, Alex Taciuk, and Lauren Zung. It is licensed under the terms of the MIT license.

Documentation

The official documentation is hosted on Read the Docs: https://colourpycker.readthedocs.io/en/latest/example.html

Credits

colourpycker was created with cookiecutter and the py-pkgs-cookiecutter template.

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

colourpycker-0.0.6.tar.gz (8.4 kB view details)

Uploaded Source

Built Distribution

colourpycker-0.0.6-py3-none-any.whl (8.2 kB view details)

Uploaded Python 3

File details

Details for the file colourpycker-0.0.6.tar.gz.

File metadata

  • Download URL: colourpycker-0.0.6.tar.gz
  • Upload date:
  • Size: 8.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.1

File hashes

Hashes for colourpycker-0.0.6.tar.gz
Algorithm Hash digest
SHA256 656c9a137a72eea08e6ae15765d03db29d33d70406e2bb3a4816a672f0a5ae56
MD5 492230173812804154ba612c4a69e637
BLAKE2b-256 d270c59a04ad6c80f363fe88844fdd37a5859c68fb9caebc87e8e476bbba8806

See more details on using hashes here.

File details

Details for the file colourpycker-0.0.6-py3-none-any.whl.

File metadata

File hashes

Hashes for colourpycker-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 e64f89d17626fbe7f24e46a889c43e3ac2f9b43968a6d71b01ab8fa41fcd5bb7
MD5 664f5674554057d58ee7948faf12aeb8
BLAKE2b-256 3906e45e5cf276bc083d3e957ceccae75a30dfb5a23206ee500505764cd1ac50

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