mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-03 19:45:44 -05:00
parent
fb47244787
commit
fd1a517e84
2 changed files with 17 additions and 13 deletions
|
@ -59,21 +59,22 @@ var Color = Base.extend(new function() {
|
||||||
colorCtx;
|
colorCtx;
|
||||||
|
|
||||||
function fromCSS(string) {
|
function fromCSS(string) {
|
||||||
var match = string.match(/^#(\w{1,2})(\w{1,2})(\w{1,2})$/),
|
var match = string.match(
|
||||||
|
/^#([\da-f]{2})([\da-f]{2})([\da-f]{2})([\da-f]{2})?$/i
|
||||||
|
) || string.match(
|
||||||
|
/^#([\da-f])([\da-f])([\da-f])$/i
|
||||||
|
),
|
||||||
type = 'rgb',
|
type = 'rgb',
|
||||||
components;
|
components;
|
||||||
if (/^#[A-Fa-f0-9]+$/.test( string )) {
|
if (match) {
|
||||||
// HEX / HEX+A
|
// Hex with optional alpha channel:
|
||||||
var base = string.replace(/^#/,'');
|
var amount = match[4] ? 4 : 3;
|
||||||
var size = base.length;
|
components = new Array(amount);
|
||||||
components = base.split( size <= 4 ? /(.)/ : /(..)/ );
|
for (var i = 0; i < amount; i++) {
|
||||||
components = components.filter(Boolean).map(function(x) {
|
var value = match[i + 1];
|
||||||
return parseInt(size <= 4 ? x + x : x, 16) / 255;
|
components[i] = parseInt(value.length == 1
|
||||||
});
|
? value + value : value, 16) / 255;
|
||||||
|
}
|
||||||
if ( !components[0] ) components[0] = 0;
|
|
||||||
if ( !components[1] ) components[1] = 0;
|
|
||||||
if ( !components[2] ) components[2] = 0;
|
|
||||||
} else if (match = string.match(/^(rgb|hsl)a?\((.*)\)$/)) {
|
} else if (match = string.match(/^(rgb|hsl)a?\((.*)\)$/)) {
|
||||||
// RGB / RGBA or HSL / HSLA
|
// RGB / RGBA or HSL / HSLA
|
||||||
type = match[1];
|
type = match[1];
|
||||||
|
|
|
@ -66,6 +66,9 @@ test('Creating Colors', function() {
|
||||||
equals(new Color('#ff0000'), new Color(1, 0, 0),
|
equals(new Color('#ff0000'), new Color(1, 0, 0),
|
||||||
'Color from hex string');
|
'Color from hex string');
|
||||||
|
|
||||||
|
equals(new Color('#FF3300'), new Color(1, 0.2, 0),
|
||||||
|
'Color from hex string');
|
||||||
|
|
||||||
equals(new Color('#ff000099'), new Color(1, 0, 0, .6),
|
equals(new Color('#ff000099'), new Color(1, 0, 0, .6),
|
||||||
'Color from hex code with alpha');
|
'Color from hex code with alpha');
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue