This is a port of the randomColor.js script created by David Merfield.
RandomColor generates attractive colors by default. More specifically, RandomColor produces bright colors with a reasonably high saturation. This makes randomColor particularly useful for data visualizations and generative art.
Get the code on GitHub
Once you have included RandomColor.class.php on your app, calling RandomColor::one($options) or RandomColor::many($count, $options) will return a random attractive color. Beneath is the live output of 36 generations.
RandomColor::many(36);
You can also pass an options object to randomColor. This allows you to specify the hue, luminosity and the format of colors to generate.
RandomColor::one(array('format'=>'hex'));
// "#71a510"
RandomColor::one(array('format'=>'hsv'));
// array('h'=>81,'s'=>90,'v'=>65)
RandomColor::one(array('format'=>'hsl'));
// array('h'=>81,'s'=>81.8200000000000073896444519050419330596923828125,'l'=>35.75000000000000710542735760100185871124267578125)
RandomColor::one(array('format'=>'rgb'));
// array('r'=>113.0,'g'=>165.0,'b'=>16.0)
RandomColor::one(array('format'=>'hslCss'));
// "hsl(81,81.82%,35.75%)"
RandomColor::one(array('format'=>'rgbCss'));
// "rgb(113,165,16)"
RandomColor::many(18, array('hue'=>'red'));
RandomColor::many(18, array('hue'=>'orange'));
RandomColor::many(18, array('hue'=>'yellow'));
RandomColor::many(18, array('hue'=>'green'));
RandomColor::many(18, array('hue'=>'blue'));
RandomColor::many(18, array('hue'=>'purple'));
RandomColor::many(18, array('hue'=>'pink'));
RandomColor::many(18, array('hue'=>'monochrome'));
RandomColor::many(27, array('hue'=>array('blue', 'yellow')));
RandomColor::many(27, array('luminosity'=>'light'));
RandomColor::many(27, array('luminosity'=>'dark'));
RandomColor::many(36, array('luminosity'=>'random', 'hue'=>'random'));