basekit/colorworks

Classes for manipulating colors, converting to different formats and finding color harmonies

1.0.0 2017-06-05 13:51 UTC

This package is not auto-updated.

Last update: 2024-12-27 22:09:49 UTC


README

#Getting started:

ColorWorks uses the PSR-0 standards for namespaces, so there should be no trouble using with frameworks like Symfony 2.

###Autoloading

An autoloader class is provided for when loading ColorWorks yourself.

First, include the autoloader and call the static register() function.

<?php
require_once 'path/to/colorworks/lib/ColorWorks/Autoloader.php';
ColorWorks\Autoloader::register();
?>

Now all ColorWorks classes will be automatically loaded in.

###Converting between formats

ColorWorks can convert to and from any of the supported color formats:

<?php
use ColorWorks\Formats\Hex;

$red_hex = new Hex(0xFF0000);
$red_cmyk = $hex->toCMYK();

echo get_class($red_cmyk); // ColorWorks\Formats\CMYK
echo $red_cmyk; // 0,1,1,0
?>

Any color manipulation or conversion will return a new instance of a color class, therefore your original color objects remains intact.

Color manipulation can be chained together:

<?php
use ColorWorks\Formats\Hex;

echo Hex::fromString('red')->hue(-20)->greyscale(); // 555555
?>

Any color manipulation will always return the color in the same format unless you're specifically converting the format. For example:

<?php
use ColorWorks\Formats\RGB;

$red = new RGB(255, 0, 0);
echo get_class($red->hue(-20)->saturation(2)); // ColorWorks\Formats\RGB
?>

###Supported formats:

<?php
new RGB(r, g, b);
new CMY(c, m, y);
new CMYK(c, m, y, k);
new Hex(0x000000);
new HSV(h, s, v);
new CIELab(l, a, b);
new CIELCh(l, c, h);
new XYZ(x, y, z);
new Yxy(Y, x, y);

###Conversion functions:

<?php
->toRGB();
->toCMY();
->toCMYK();
->toHex();
->toHSV();
->toCIELab();
->toCIELCh();
->toXYZ();
->toYxy();