mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-23 15:59:45 -05:00
Color: combine stringToRgb, namedToRgb and hexToRgb and optimize a bit.
This commit is contained in:
parent
ba42884f57
commit
741652aa9c
1 changed files with 25 additions and 21 deletions
|
@ -65,12 +65,7 @@ var Color = this.Color = Base.extend(new function() {
|
||||||
};
|
};
|
||||||
|
|
||||||
function stringToRGB(string) {
|
function stringToRGB(string) {
|
||||||
return string.match(/^#[0-9a-f]{3,6}$/i)
|
if (string.match(/^#[0-9a-f]{3,6}$/i)) {
|
||||||
? hexToRgb(string)
|
|
||||||
: namedToRgb(string);
|
|
||||||
};
|
|
||||||
|
|
||||||
function hexToRgb(string) {
|
|
||||||
var hex = string.match(/^#?(\w{1,2})(\w{1,2})(\w{1,2})$/);
|
var hex = string.match(/^#?(\w{1,2})(\w{1,2})(\w{1,2})$/);
|
||||||
if (hex.length >= 4) {
|
if (hex.length >= 4) {
|
||||||
var rgb = [];
|
var rgb = [];
|
||||||
|
@ -79,13 +74,22 @@ var Color = this.Color = Base.extend(new function() {
|
||||||
? hex[i] + hex[i] : hex[i], 16) / 255);
|
? hex[i] + hex[i] : hex[i], 16) / 255);
|
||||||
return rgb;
|
return rgb;
|
||||||
}
|
}
|
||||||
};
|
} else {
|
||||||
|
var hex = namedColors[string];
|
||||||
function namedToRgb(name) {
|
|
||||||
var hex = namedColors[name];
|
|
||||||
if (!hex)
|
if (!hex)
|
||||||
throw new Error('The named color "' + name + '" does not exist.');
|
throw new Error('The named color "' + string
|
||||||
return hex && hexToRgb(hex);
|
+ '" does not exist.');
|
||||||
|
hex = hex.match(/^#?(\w{1,2})(\w{1,2})(\w{1,2})$/);
|
||||||
|
if (hex.length >= 4) {
|
||||||
|
var rgb = new Array(3);
|
||||||
|
for (var i = 0; i < 3; i++) {
|
||||||
|
var channel = hex[i + 1];
|
||||||
|
rgb[i] = parseInt(channel.length == 1
|
||||||
|
? channel + channel : channel, 16) / 255;
|
||||||
|
}
|
||||||
|
return rgb;
|
||||||
|
}
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
@ -146,7 +150,7 @@ var Color = this.Color = Base.extend(new function() {
|
||||||
},
|
},
|
||||||
|
|
||||||
getType: function() {
|
getType: function() {
|
||||||
return this._alpha == -1 ? this._colorType : 'a' + this._colorType;
|
return this._colorType;
|
||||||
},
|
},
|
||||||
|
|
||||||
getComponents: function() {
|
getComponents: function() {
|
||||||
|
|
Loading…
Reference in a new issue