Python package for determining the hex colour code given a cropped image.
Project description
hexdropper
A Python package designed for graphic designers, developers, and color enthusiasts. It simplifies the process of obtaining hex color codes from images. Given a cropped image, hexdropper quickly identifies and outputs the corresponding hex color code, streamlining design and development workflows.
Contributors
Features
The key functionalities include:
-
read_image
: This function reads image files, and converts the image into a numpy array of RGB values. -
most_common_rgb
: This function identifies the most common RGB value within the given image. -
rgb_to_hex
: This function converts RGB values into their corresponding hex color codes. -
create_color_image
: This function generates an image displaying the hex code on a background of the color it represents.
Installation
The current package is still under development. We have provided below a set of developer installation instructions.
User Installation
To install hexdropper
, simply run the following command in your terminal:
$ pip install hexdropper
This will download and install the latest version of hexdropper
from the Python Package Index (PyPI).
Developer Installation
Getting Started
Clone a copy of this repository onto your local machine. See this page for details on how to clone a repository.
Setting up a Conda Environment
We recommend creating an isolated conda environment on your local machine to test and develop the package. To create and activate a conda environment for this project, type in the below command in your terminal.
$ conda create --name hexdropper python=3.9 -y
$ conda activate hexdropper
Using Poetry for Package Management
Please follow the official poetry documentation to install poetry on your local machine. Note that poetry should always be installed on a dedicated virtual environment.
Navigate to the root directory of your project folder. Ensure that your virtual conda environment has been activated. Run the following line of code to install existing packages required for the hexdropper
package:
$ poetry install
If you would like to add a new package or dependency, run the following code in your terminal, replacing [name-of-dependency]
with the package you would like to install (e.g., numpy)
$ poetry add [name-of-dependency]
You can also pin the specific version of the package you would like to install like so:
$ poetry add numpy=1.22.0 --dry-run
Running Tests
Ensure pytest
and pytest-cov
are installed via poetry. If not, run the following in your terminal:
$ poetry add --group dev pytest
$ poetry add --group dev pytest-cov
Ensuring that your test scripts are completed, then run the following code in your terminal to run the tests for all functions in the package:
$ pytest tests/
To run coverage tests, run the following command:
$ pytest tests/ --cov=hexdropper
Usage
Rather than using multiple external tools to obtain the necessary hex code to better customize one's graphics or visualization, we developed a package, hexdropper
, that would make it easier for users to directly obtain the desired hex code right here in Python.
Package set up
Once the package is installed, import the package directly by running the following command in Python
from hexdropper import *
Read image
Start by reading in a cropped image containing the color you would like to match, using the read_image
function and specifying the path to the image on the device. The image does not need to be perfectly cropped, as long as the color we are interested in is most prominent.
Note that the input image must be of type jpg or any other color formats that only have 3 color channels. Formats like png have 4 channels (RGB and an alpha channel that controls transparency).
image = read_image('img/cropped_img.jpg')
Obtaining the most common RGB
Now that the cropped image has been imported as an array, we can extract its RGB values.
Sometimes, it might not be feasible to crop an image perfectly. For instance, a user may have missed a few dark pixels at the edge of the cropped image, or perhaps, the image itself is a bit noisy. To account for these situations, the function most_common_rgb
takes the most common RGB value in the cropped image and outputs it as a tuple that corresponds to the red, green, and blue channels respectively.
rgb_val = most_common_rgb(image)
Converting RGB to hexadecimal format
Once we have obtained the most common RGB value from an image using the most_common_rgb
function, we can convert its output using the rgb_to_hex
function. This function returns a string representing the color in hexadecimal format.
rgb_to_hex(rgb_val)
In addition to accepting tuples, the rgb_to_hex
function can also accept three separate integers representing the red, green, and blue color channels.
rgb_to_hex(8, 181, 212)
Export the extrated color as an image
The user can also create a new image that solely features the extracted color. This allows for a visual reference of the color for other users (particularly if they do not have a programming background) when designing graphics that coordinate with MDS logo's color scheme.
By default, the function will create a 200x200 pixel image with the extrated color. By default, the image will be saved in the current working directory and named with the color code (e.g., 08B5D4.png).
hex_code = rgb_to_hex(8, 181, 212)
create_color_image(hex_code)
The user can also change the size of the image and the directory to save the image in. we can do so by adjusting the parameters of the create_color_image
function.
# Create a 100x100 pixel image and save it to a specific path
create_color_image(hex_code, image_size=(100, 100), output_path='/path/to/save/08B5D4.png')
This package can be especially useful for designers and developers who need visuals that match or complement colors extracted from images, as demonstrated with the UBC MDS Logo in our example.
If you have any questions or feedback about hexdropper
, feel free to reach out or contribute to our project. Happy color dropping!
Python Ecosystem Context
hexdropper fills a unique niche in the Python ecosystem. While there are packages like Pillow for image processing and Matplotlib for visualization, hexdropper specifically focuses on color extraction and conversion, a task not directly addressed by existing packages. Its ability to directly translate image colors into hex codes and visually represent them is distinctive, setting it apart from general-purpose image manipulation tools. Related packages include:
- Pillow: For comprehensive image processing capabilities.
- Matplotlib: For creating visualizations and figures.
Contributing
Interested in contributing? Check out the contributing guidelines. 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
hexdropper
was created by Julia Everitt, Hancheng Qin, Joey Wu, Mona Zhu. It is licensed under the terms of the MIT license.
Credits
hexdropper
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
Built Distribution
File details
Details for the file hexdropper-0.0.8.tar.gz
.
File metadata
- Download URL: hexdropper-0.0.8.tar.gz
- Upload date:
- Size: 7.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f37e8e12cc699a582a54460c936a9a85e5822d2fddf0bf1b201bd6396343d414 |
|
MD5 | e3f1de975a441c9e2e6362ebf7c88582 |
|
BLAKE2b-256 | 18b5b5b029b3fac79b13d7ee8bd9d77c1b449666802d3bca610512de5e6bd3cc |
File details
Details for the file hexdropper-0.0.8-py3-none-any.whl
.
File metadata
- Download URL: hexdropper-0.0.8-py3-none-any.whl
- Upload date:
- Size: 9.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4aebaf7dece243c924320218fec0f72eb50b8e116fdf236b7f3099bf7deb9998 |
|
MD5 | fc2b6a9630764befa8095107605323c4 |
|
BLAKE2b-256 | f8c776022ce9981a17d1d8d5db3b392ffd82ab1e49972af1b17de0e5bc734d8e |