paper.js/test/tests/Color.js

196 lines
5.3 KiB
JavaScript
Raw Normal View History

2011-07-01 06:17:45 -04:00
/*
* Paper.js - The Swiss Army Knife of Vector Graphics Scripting.
2011-07-01 06:17:45 -04:00
* http://paperjs.org/
*
* Copyright (c) 2011 - 2013, Juerg Lehni & Jonathan Puckey
2011-07-01 06:17:45 -04:00
* http://lehni.org/ & http://jonathanpuckey.com/
*
* Distributed under the MIT license. See LICENSE file for details.
*
* All rights reserved.
*/
2011-03-08 20:25:50 -05:00
module('Color');
2011-02-19 10:48:59 -05:00
test('Set named color', function() {
var path = new Path();
path.fillColor = 'red';
2013-04-08 03:19:47 -04:00
compareColors(path.fillColor, new Color(1, 0, 0));
equals(path.fillColor.toCss(), 'rgb(255, 0, 0)');
2011-02-19 10:48:59 -05:00
});
test('Set color to hex', function() {
var path = new Path();
path.fillColor = '#ff0000';
2013-04-08 03:19:47 -04:00
compareColors(path.fillColor, new Color(1, 0, 0));
equals(path.fillColor.toCss(), 'rgb(255, 0, 0)');
2011-02-19 10:48:59 -05:00
var path = new Path();
path.fillColor = '#f00';
2013-04-08 03:19:47 -04:00
compareColors(path.fillColor, new Color(1, 0, 0));
equals(path.fillColor.toCss(), 'rgb(255, 0, 0)');
2011-02-19 10:48:59 -05:00
});
test('Set color to object', function() {
var path = new Path();
path.fillColor = { red: 1, green: 0, blue: 1};
2013-04-08 03:19:47 -04:00
compareColors(path.fillColor, new Color(1, 0, 1));
equals(path.fillColor.toCss(), 'rgb(255, 0, 255)');
2011-02-19 10:48:59 -05:00
var path = new Path();
path.fillColor = { gray: 0.2 };
2013-04-08 03:19:47 -04:00
compareColors(path.fillColor, new Color(0.2));
2013-04-08 23:20:47 -04:00
equals(path.fillColor.toCss(), 'rgb(51, 51, 51)');
2011-02-19 10:48:59 -05:00
});
test('Set color to array', function() {
var path = new Path();
path.fillColor = [1, 0, 0];
2013-04-08 03:19:47 -04:00
compareColors(path.fillColor, new Color(1, 0, 0));
equals(path.fillColor.toCss(), 'rgb(255, 0, 0)');
2011-02-19 10:48:59 -05:00
});
test('Creating Colors', function() {
2011-07-07 10:09:02 -04:00
2013-04-08 03:19:47 -04:00
compareColors(new Color('#ff0000'), new Color(1, 0, 0),
'Color from hex code');
2011-07-07 10:09:02 -04:00
2013-04-08 03:19:47 -04:00
compareColors(new Color({ red: 1, green: 0, blue: 1}),
new Color(1, 0, 1), 'Color from rgb object literal');
2011-03-08 20:25:50 -05:00
2013-04-08 03:19:47 -04:00
compareColors(new Color({ gray: 0.2 }),
2013-04-08 10:07:41 -04:00
new Color(0.2), 'Color from gray object literal');
2011-03-08 20:25:50 -05:00
2013-04-08 03:19:47 -04:00
compareColors(new Color({ hue: 0, saturation: 1, brightness: 1}),
new Color(1, 0, 0).convert('hsb'), 'Color from hsb object literal');
2011-03-08 20:25:50 -05:00
2013-04-08 03:19:47 -04:00
compareColors(new Color([1, 0, 0]), new Color(1, 0, 0),
'Rgb Color from array');
2011-07-07 10:09:02 -04:00
2013-04-08 03:19:47 -04:00
compareColors(new Color([1]), new Color(1),
'Gray Color from array');
2011-03-08 20:25:50 -05:00
});
test('Deprecated Colors Constructors', function() {
compareColors(new RgbColor('#ff0000'), new Color(1, 0, 0),
'Color from hex code');
compareColors(new RgbColor(1, 0, 1),
new Color(1, 0, 1), 'Color from rgb object literal');
compareColors(new GrayColor(0.2),
new Color(0.2), 'Color from gray object literal');
compareColors(new HsbColor(0, 1, 1),
new Color(1, 0, 0).convert('hsb'), 'Color from hsb object literal');
compareColors(new RgbColor([1, 0, 0]), new Color(1, 0, 0),
'Rgb Color from array');
compareColors(new GrayColor([1]), new Color(1),
'Gray Color from array');
});
2013-04-08 03:19:47 -04:00
test('Get gray from RGB Color', function() {
var color = new Color(1, 0.5, 0.2);
2013-04-08 23:20:47 -04:00
compareNumbers(color.gray, 0.6152);
2011-02-19 10:48:59 -05:00
var color = new Color(0.5, 0.2, 0.1);
2013-04-08 23:20:47 -04:00
compareNumbers(color.gray, 0.27825);
2011-02-19 10:48:59 -05:00
});
2013-04-08 03:19:47 -04:00
test('Get gray from HSB Color', function() {
var color = new Color({hue: 0, saturation: 0, brightness: 0.2 });
2013-04-08 23:20:47 -04:00
compareNumbers(color.gray, 0.19998);
2011-03-08 20:25:50 -05:00
});
2013-04-08 03:19:47 -04:00
test('Get red from HSB Color', function() {
var color = new Color({hue: 0, saturation: 1, brightness: 1 });
2011-03-08 20:25:50 -05:00
compareNumbers(color.red, 1);
});
2013-04-08 03:19:47 -04:00
test('Get hue from RGB Color', function() {
var color = new Color(1, 0, 0);
2011-03-08 20:25:50 -05:00
compareNumbers(color.hue, 0);
2011-07-07 10:09:02 -04:00
compareNumbers(color.saturation, 1);
2011-03-08 20:25:50 -05:00
});
2011-02-19 10:48:59 -05:00
test('Gray Color', function() {
2013-04-08 03:19:47 -04:00
var color = new Color(1);
2013-04-08 23:20:47 -04:00
compareNumbers(color.gray, 1, 'color.gray');
compareNumbers(color.red, 1, 'color.red');
compareNumbers(color.blue, 1, 'color.blue');
2011-07-07 10:09:02 -04:00
2011-02-19 10:48:59 -05:00
color.red = 0.5;
2013-04-08 23:20:47 -04:00
console.log(color + '');
compareNumbers(color.gray, 0.85045, 'color.gray');
2011-02-19 10:48:59 -05:00
color.green = 0.2;
2013-04-08 03:19:47 -04:00
2013-04-08 23:20:47 -04:00
compareNumbers(color.red, 0.5, 'color.red');
compareNumbers(color.green, 0.2, 'color.green');
compareNumbers(color.blue, 1, 'color.blue');
2013-04-08 03:19:47 -04:00
2013-04-08 23:20:47 -04:00
compareNumbers(color.gray, 0.38085, 'color.gray');
2011-02-19 10:48:59 -05:00
});
test('Converting Colors', function() {
var rgbColor = new Color(1, 0.5, 0.2);
2013-04-08 23:20:47 -04:00
compareNumbers(rgbColor.gray, 0.6152);
2013-04-08 03:19:47 -04:00
var grayColor = new Color(0.2);
2013-04-08 23:20:47 -04:00
compareColors(grayColor.convert('rgb'), new Color(0.2, 0.2, 0.2));
compareColors(grayColor.convert('hsb'), { hue: 0, saturation: 0, brightness: 0.2 });
2013-04-08 03:19:47 -04:00
compareColors(new Color(1, 0, 0).convert('hsb'), { hue: 0, saturation: 1, brightness: 1 });
2011-02-24 07:00:46 -05:00
});
2013-04-08 03:19:47 -04:00
test('Setting Color#gray', function() {
var color = new Color(1, 0.5, 0.2);
2011-02-24 07:00:46 -05:00
color.gray = 0.1;
2013-04-08 03:19:47 -04:00
compareColors(color, new Color(0.1));
2011-03-08 20:25:50 -05:00
});
2013-04-08 03:19:47 -04:00
test('Setting Color#red', function() {
var color = new Color({ hue: 180, saturation: 0, brightness: 0 });
2011-03-08 20:25:50 -05:00
color.red = 1;
2013-04-08 10:07:41 -04:00
compareColors(color, new Color(1, 0, 0));
2011-03-08 20:25:50 -05:00
});
2013-04-08 03:19:47 -04:00
test('Setting Color#gray', function() {
var color = new Color({ hue: 180, saturation: 0, brightness: 0 });
2011-03-08 20:25:50 -05:00
color.gray = 0.5;
2013-04-08 03:19:47 -04:00
compareColors(color, new Color(0.5));
2011-05-15 08:11:35 -04:00
});
test('Color.read(channels)', function() {
var color = Color.read([0, 0, 1]);
2013-04-08 03:19:47 -04:00
compareColors(color, new Color(0, 0, 1));
2011-05-21 07:34:27 -04:00
});
test('Cloning colors', function() {
var color = new Color(0, 0, 0);
2011-05-21 07:34:27 -04:00
equals(function() {
return color.clone() != color;
}, true);
equals(function() {
return new Color(color) != color;
2011-05-21 07:34:27 -04:00
}, true);
2011-05-21 11:25:05 -04:00
});
test('Color#convert', function() {
var color = new Color(0, 0, 0);
2011-05-21 11:25:05 -04:00
var converted = color.convert('rgb');
equals(function() {
return converted !== color;
}, true);
equals(function() {
2011-05-21 15:02:06 -04:00
return converted.equals(color);
2011-05-21 11:25:05 -04:00
}, true);
2011-08-13 09:25:29 -04:00
});
test('Saturation from black rgb', function() {
equals(function() {
2013-04-08 03:19:47 -04:00
return new Color(0, 0, 0).saturation === 0;
2011-08-13 09:25:29 -04:00
}, true);
2011-02-19 10:48:59 -05:00
});