Improve hex Color parser

Addresses changes in #1469
This commit is contained in:
Jürg Lehni 2018-10-06 21:57:30 +02:00
parent fb47244787
commit fd1a517e84
2 changed files with 17 additions and 13 deletions

View file

@ -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];

View file

@ -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');