Python color engine.
Project description
HueForge
A python library to handle everything color related.
This is a python library that handles everything color related. It includes a color class. Valid ways to initialize an object:
from hueforge import Color
# Valid ways to initialize:
example_color = Color("#FF0000") # Hex color format
example_color = Color("#FF0000FF") # Hexa color format
example_color = Color("Orange red") # Direct color format
example_color = Color((255, 0, 0)) # RGB color format
example_color = Color((255, 0, 0, 255)) # RGBA color format
example_color = Color((0, 0)) # Invalid color format; Raises exception
Get a color in a specific format from a Color() instance:
from hueforge import Color
example_color = Color("#FF0000")
print(example_color.hex()) # Outputs: "#FF0000"
print(example_color.hexa()) # Outputs: "#FF0000FF"
print(example_color.rgb()) # Outputs: (255, 0, 0)
print(example_color.rgba()) # Outputs: (255, 0, 0, 255)
print(example_color.direct()) # Outputs: "red"
# Note: example_color.direct() will raise a exception if the color
# is too unique and doesn't have a set name.
Adjust brightness, contrast, hue and saturation.
from hueforge import Color
example_color = Color("#99ABD3")
# Note: These methods don't modify the color in
# place, They return a new color instead.
print(example_color.increase_brightness(40)) # Increase brightness by 40%
print(example_color.increase_contrast(70)) # Increase contrast by 70%
print(example_color.increase_hue(180)) # Increase hue by 180 degrees (0 - 360)
print(example_color.increase_saturation(100)) # Increase Saturation by 100%
# You can also use decrease_brightness, decrease_contrast etc.
Simulate colorblindness and help colorblindness.
from hueforge import Color
example_color = Color("#FF0000")
colorblindness = "protanopia" # Type of colorblindness. Possible values: deuteranopia, deuteranomaly, protanopia, protanomaly, tritanopia, tritanomaly, all, d, t, p, d1, t1, p1, d2, t2, p2, a (all)
print(f"A colorblind person would see this as: {example_color.simulate_colorblindness(colorblindness)}")
print(f"Adjusted color so the colorblind person can see the color properly: {example_color.help_colorblindness(colorblindness)}")
Generate a smooth color gradient starting from one color, Ending with the other:
from hueforge import Color
starting_color = Color("#FF0000")
ending_color = Color("#0000FF")
gradient = starting_color.gradient(ending_color, steps=3)
print(gradient) # Outputs: [Color(#FF0000), Color(#7F007F), Color(#0000FF)]
# Increase steps for a higher quality gradient, It's recommended to keep it under 255.
# By higher quality, I mean that there are more unique colors leading to a smoother gradient. For example, a 2 step gradient would just be [starting_color, end_color]. Such a gradient is useless because of the low quality.
high_quality_gradient = starting_color.gradient(ending_color, steps=5)
print(high_quality_gradient) # Outputs: [Color(#FF0000), Color(#BF003F), Color(#7F007F), Color(#3F00BF), Color(#0000FF)]
Color Harmonies:
from hueforge import Color
example_color = Color("#FF0000")
print(example_color.get_complementary_color())
print(example_color.get_split_complementary_colors())
print(example_color.get_analogous_colors())
print(example_color.get_triadic_colors())
print(example_color.get_tetradic_colors())
print(example_color.get_square_colors())
# Hover over these functions (in an IDE) to see their return order.
That's almost everything that's included in this library. Thanks for using HueForge!
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file hueforge-1.0.tar.gz.
File metadata
- Download URL: hueforge-1.0.tar.gz
- Upload date:
- Size: 2.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8d9098975379ad0a1c3703bcda7fb430817d7da23af5f5747f6fb51484eadca8
|
|
| MD5 |
ed47c92b2165f6a31088c59cd4f3ddbe
|
|
| BLAKE2b-256 |
2d332a7bfafa42463b95b83684b01a896ff655f3e58600e50d70aaf07d7eee9e
|
File details
Details for the file hueforge-1.0-py3-none-any.whl.
File metadata
- Download URL: hueforge-1.0-py3-none-any.whl
- Upload date:
- Size: 2.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
14c029b8760d46d21eb34680f4019cf66881c38ed57ef11876b2db21fc8fd841
|
|
| MD5 |
0268cb1334029a50022700049c1aa8ff
|
|
| BLAKE2b-256 |
851ba84cb0235973230ce5eea9d3daba1c58068e82484526a5a9369a3a21712d
|