123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640 |
- /**
- * @author bhouston / http://exocortex.com
- * @author TristanVALCKE / https://github.com/Itee
- */
- /* global QUnit */
- import { Color } from '../../../../src/math/Color';
- import { eps } from './Constants.tests';
- export default QUnit.module( 'Maths', () => {
- QUnit.module( 'Color', () => {
- // INSTANCING
- QUnit.test( "Instancing", ( assert ) => {
- // default ctor
- var c = new Color();
- assert.ok( c.r, "Red: " + c.r );
- assert.ok( c.g, "Green: " + c.g );
- assert.ok( c.b, "Blue: " + c.b );
- // rgb ctor
- var c = new Color( 1, 1, 1 );
- assert.ok( c.r == 1, "Passed" );
- assert.ok( c.g == 1, "Passed" );
- assert.ok( c.b == 1, "Passed" );
- } );
- // EXPOSED CONSTANTS
- QUnit.test( "Color.NAMES", ( assert ) => {
- assert.ok( Color.NAMES.aliceblue == 0xF0F8FF, "Exposed Color.NAMES" );
- } );
- // PUBLIC STUFF
- QUnit.test( "isColor", ( assert ) => {
- var a = new Color();
- assert.ok( a.isColor === true, "Passed!" );
- var b = new Object();
- assert.ok( ! b.isColor, "Passed!" );
- } );
- QUnit.test( "set", ( assert ) => {
- var a = new Color();
- var b = new Color( 0.5, 0, 0 );
- var c = new Color( 0xFF0000 );
- var d = new Color( 0, 1.0, 0 );
- a.set( b );
- assert.ok( a.equals( b ), "Set with Color instance" );
- a.set( 0xFF0000 );
- assert.ok( a.equals( c ), "Set with number" );
- a.set( "rgb(0,255,0)" );
- assert.ok( a.equals( d ), "Set with style" );
- } );
- QUnit.test( "setScalar", ( assert ) => {
- var c = new Color();
- c.setScalar( 0.5 );
- assert.ok( c.r == 0.5, "Red: " + c.r );
- assert.ok( c.g == 0.5, "Green: " + c.g );
- assert.ok( c.b == 0.5, "Blue: " + c.b );
- } );
- QUnit.test( "setHex", ( assert ) => {
- var c = new Color();
- c.setHex( 0xFA8072 );
- assert.ok( c.getHex() == 0xFA8072, "Hex: " + c.getHex() );
- assert.ok( c.r == 0xFA / 0xFF, "Red: " + c.r );
- assert.ok( c.g == 0x80 / 0xFF, "Green: " + c.g );
- assert.ok( c.b == 0x72 / 0xFF, "Blue: " + c.b );
- } );
- QUnit.test( "setRGB", ( assert ) => {
- var c = new Color();
- c.setRGB( 0.3, 0.5, 0.7 );
- assert.ok( c.r == 0.3, "Red: " + c.r );
- assert.ok( c.g == 0.5, "Green: " + c.g );
- assert.ok( c.b == 0.7, "Blue: " + c.b );
- } );
- QUnit.test( "setHSL", ( assert ) => {
- var c = new Color();
- var hsl = { h: 0, s: 0, l: 0 };
- c.setHSL( 0.75, 1.0, 0.25 );
- c.getHSL( hsl );
- assert.ok( hsl.h == 0.75, "hue: " + hsl.h );
- assert.ok( hsl.s == 1.00, "saturation: " + hsl.s );
- assert.ok( hsl.l == 0.25, "lightness: " + hsl.l );
- } );
- QUnit.test( "setStyle", ( assert ) => {
- var a = new Color();
- var b = new Color( 8 / 255, 25 / 255, 178 / 255 );
- a.setStyle( "rgb(8,25,178)" );
- assert.ok( a.equals( b ), "Passed" );
- b = new Color( 8 / 255, 25 / 255, 178 / 255 );
- a.setStyle( "rgba(8,25,178,200)" );
- assert.ok( a.equals( b ), "Passed" );
- var hsl = { h: 0, s: 0, l: 0 };
- a.setStyle( "hsl(270,50%,75%)" );
- a.getHSL( hsl );
- assert.ok( hsl.h == 0.75, "hue: " + hsl.h );
- assert.ok( hsl.s == 0.5, "saturation: " + hsl.s );
- assert.ok( hsl.l == 0.75, "lightness: " + hsl.l );
- hsl = { h: 0, s: 0, l: 0 };
- a.setStyle( "hsl(270,50%,75%,0.5)" );
- a.getHSL( hsl );
- assert.ok( hsl.h == 0.75, "hue: " + hsl.h );
- assert.ok( hsl.s == 0.5, "saturation: " + hsl.s );
- assert.ok( hsl.l == 0.75, "lightness: " + hsl.l );
- a.setStyle( "#F8A" );
- assert.ok( a.r == 0xFF / 255, "Red: " + a.r );
- assert.ok( a.g == 0x88 / 255, "Green: " + a.g );
- assert.ok( a.b == 0xAA / 255, "Blue: " + a.b );
- a.setStyle( "#F8ABC1" );
- assert.ok( a.r == 0xF8 / 255, "Red: " + a.r );
- assert.ok( a.g == 0xAB / 255, "Green: " + a.g );
- assert.ok( a.b == 0xC1 / 255, "Blue: " + a.b );
- a.setStyle( "aliceblue" );
- assert.ok( a.r == 0xF0 / 255, "Red: " + a.r );
- assert.ok( a.g == 0xF8 / 255, "Green: " + a.g );
- assert.ok( a.b == 0xFF / 255, "Blue: " + a.b );
- } );
- QUnit.test( "setColorName", ( assert ) => {
- var c = new Color();
- var res = c.setColorName( "aliceblue" );
- assert.ok( c.getHex() == 0xF0F8FF, "Hex: " + c.getHex() );
- assert.ok( c == res, "Returns Self" );
- } );
- QUnit.test( "clone", ( assert ) => {
- var c = new Color( 'teal' );
- var c2 = c.clone();
- assert.ok( c2.getHex() == 0x008080, "Hex c2: " + c2.getHex() );
- } );
- QUnit.test( "copy", ( assert ) => {
- var a = new Color( 'teal' );
- var b = new Color();
- b.copy( a );
- assert.ok( b.r == 0x00 / 255, "Red: " + b.r );
- assert.ok( b.g == 0x80 / 255, "Green: " + b.g );
- assert.ok( b.b == 0x80 / 255, "Blue: " + b.b );
- } );
- QUnit.test( "copyGammaToLinear", ( assert ) => {
- var c = new Color();
- var c2 = new Color();
- c2.setRGB( 0.3, 0.5, 0.9 );
- c.copyGammaToLinear( c2 );
- assert.ok( c.r == 0.09, "Red c: " + c.r + " Red c2: " + c2.r );
- assert.ok( c.g == 0.25, "Green c: " + c.g + " Green c2: " + c2.g );
- assert.ok( c.b == 0.81, "Blue c: " + c.b + " Blue c2: " + c2.b );
- } );
- QUnit.test( "copyLinearToGamma", ( assert ) => {
- var c = new Color();
- var c2 = new Color();
- c2.setRGB( 0.09, 0.25, 0.81 );
- c.copyLinearToGamma( c2 );
- assert.ok( c.r == 0.3, "Red c: " + c.r + " Red c2: " + c2.r );
- assert.ok( c.g == 0.5, "Green c: " + c.g + " Green c2: " + c2.g );
- assert.ok( c.b == 0.9, "Blue c: " + c.b + " Blue c2: " + c2.b );
- } );
- QUnit.test( "convertGammaToLinear", ( assert ) => {
- var c = new Color();
- c.setRGB( 0.3, 0.5, 0.9 );
- c.convertGammaToLinear();
- assert.ok( c.r == 0.09, "Red: " + c.r );
- assert.ok( c.g == 0.25, "Green: " + c.g );
- assert.ok( c.b == 0.81, "Blue: " + c.b );
- } );
- QUnit.test( "convertLinearToGamma", ( assert ) => {
- var c = new Color();
- c.setRGB( 4, 9, 16 );
- c.convertLinearToGamma();
- assert.ok( c.r == 2, "Red: " + c.r );
- assert.ok( c.g == 3, "Green: " + c.g );
- assert.ok( c.b == 4, "Blue: " + c.b );
- } );
- QUnit.test( "getHex", ( assert ) => {
- var c = new Color( 'red' );
- var res = c.getHex();
- assert.ok( res == 0xFF0000, "Hex: " + res );
- } );
- QUnit.test( "getHexString", ( assert ) => {
- var c = new Color( 'tomato' );
- var res = c.getHexString();
- assert.ok( res == 'ff6347', "Hex: " + res );
- } );
- QUnit.test( "getHSL", ( assert ) => {
- var c = new Color( 0x80ffff );
- var hsl = { h: 0, s: 0, l: 0 };
- c.getHSL( hsl );
- assert.ok( hsl.h == 0.5, "hue: " + hsl.h );
- assert.ok( hsl.s == 1.0, "saturation: " + hsl.s );
- assert.ok( ( Math.round( parseFloat( hsl.l ) * 100 ) / 100 ) == 0.75, "lightness: " + hsl.l );
- } );
- QUnit.test( "getStyle", ( assert ) => {
- var c = new Color( 'plum' );
- var res = c.getStyle();
- assert.ok( res == 'rgb(221,160,221)', "style: " + res );
- } );
- QUnit.test( "offsetHSL", ( assert ) => {
- var a = new Color( "hsl(120,50%,50%)" );
- var b = new Color( 0.36, 0.84, 0.648 );
- a.offsetHSL( 0.1, 0.1, 0.1 );
- assert.ok( Math.abs( a.r - b.r ) <= eps, "Check r" );
- assert.ok( Math.abs( a.g - b.g ) <= eps, "Check g" );
- assert.ok( Math.abs( a.b - b.b ) <= eps, "Check b" );
- } );
- QUnit.test( "add", ( assert ) => {
- var a = new Color( 0x0000FF );
- var b = new Color( 0xFF0000 );
- var c = new Color( 0xFF00FF );
- a.add( b );
- assert.ok( a.equals( c ), "Check new value" );
- } );
- QUnit.test( "addColors", ( assert ) => {
- var a = new Color( 0x0000FF );
- var b = new Color( 0xFF0000 );
- var c = new Color( 0xFF00FF );
- var d = new Color();
- d.addColors( a, b );
- assert.ok( d.equals( c ), "Passed" );
- } );
- QUnit.test( "addScalar", ( assert ) => {
- var a = new Color( 0.1, 0.0, 0.0 );
- var b = new Color( 0.6, 0.5, 0.5 );
- a.addScalar( 0.5 );
- assert.ok( a.equals( b ), "Check new value" );
- } );
- QUnit.test( "sub", ( assert ) => {
- var a = new Color( 0x0000CC );
- var b = new Color( 0xFF0000 );
- var c = new Color( 0x0000AA );
- a.sub( b );
- assert.strictEqual( a.getHex(), 0xCC, "Difference too large" );
- a.sub( c );
- assert.strictEqual( a.getHex(), 0x22, "Difference fine" );
- } );
- QUnit.test( "multiply", ( assert ) => {
- var a = new Color( 1, 0, 0.5 );
- var b = new Color( 0.5, 1, 0.5 );
- var c = new Color( 0.5, 0, 0.25 );
- a.multiply( b );
- assert.ok( a.equals( c ), "Check new value" );
- } );
- QUnit.test( "multiplyScalar", ( assert ) => {
- var a = new Color( 0.25, 0, 0.5 );
- var b = new Color( 0.5, 0, 1 );
- a.multiplyScalar( 2 );
- assert.ok( a.equals( b ), "Check new value" );
- } );
- QUnit.test( "copyHex", ( assert ) => {
- var c = new Color();
- var c2 = new Color( 0xF5FFFA );
- c.copy( c2 );
- assert.ok( c.getHex() == c2.getHex(), "Hex c: " + c.getHex() + " Hex c2: " + c2.getHex() );
- } );
- QUnit.test( "copyColorString", ( assert ) => {
- var c = new Color();
- var c2 = new Color( 'ivory' );
- c.copy( c2 );
- assert.ok( c.getHex() == c2.getHex(), "Hex c: " + c.getHex() + " Hex c2: " + c2.getHex() );
- } );
- QUnit.test( "lerp", ( assert ) => {
- var c = new Color();
- var c2 = new Color();
- c.setRGB( 0, 0, 0 );
- c.lerp( c2, 0.2 );
- assert.ok( c.r == 0.2, "Red: " + c.r );
- assert.ok( c.g == 0.2, "Green: " + c.g );
- assert.ok( c.b == 0.2, "Blue: " + c.b );
- } );
- QUnit.test( "equals", ( assert ) => {
- var a = new Color( 0.5, 0.0, 1.0 );
- var b = new Color( 0.5, 1.0, 0.0 );
- assert.strictEqual( a.r, b.r, "Components: r is equal" );
- assert.notStrictEqual( a.g, b.g, "Components: g is not equal" );
- assert.notStrictEqual( a.b, b.b, "Components: b is not equal" );
- assert.notOk( a.equals( b ), "equals(): a not equal b" );
- assert.notOk( b.equals( a ), "equals(): b not equal a" );
- a.copy( b );
- assert.strictEqual( a.r, b.r, "Components after copy(): r is equal" );
- assert.strictEqual( a.g, b.g, "Components after copy(): g is equal" );
- assert.strictEqual( a.b, b.b, "Components after copy(): b is equal" );
- assert.ok( a.equals( b ), "equals() after copy(): a equals b" );
- assert.ok( b.equals( a ), "equals() after copy(): b equals a" );
- } );
- QUnit.test( "fromArray", ( assert ) => {
- var a = new Color();
- var array = [ 0.5, 0.6, 0.7, 0, 1, 0 ];
- a.fromArray( array );
- assert.strictEqual( a.r, 0.5, "No offset: check r" );
- assert.strictEqual( a.g, 0.6, "No offset: check g" );
- assert.strictEqual( a.b, 0.7, "No offset: check b" );
- a.fromArray( array, 3 );
- assert.strictEqual( a.r, 0, "With offset: check r" );
- assert.strictEqual( a.g, 1, "With offset: check g" );
- assert.strictEqual( a.b, 0, "With offset: check b" );
- } );
- QUnit.test( "toArray", ( assert ) => {
- var r = 0.5, g = 1.0, b = 0.0;
- var a = new Color( r, g, b );
- var array = a.toArray();
- assert.strictEqual( array[ 0 ], r, "No array, no offset: check r" );
- assert.strictEqual( array[ 1 ], g, "No array, no offset: check g" );
- assert.strictEqual( array[ 2 ], b, "No array, no offset: check b" );
- var array = [];
- a.toArray( array );
- assert.strictEqual( array[ 0 ], r, "With array, no offset: check r" );
- assert.strictEqual( array[ 1 ], g, "With array, no offset: check g" );
- assert.strictEqual( array[ 2 ], b, "With array, no offset: check b" );
- var array = [];
- a.toArray( array, 1 );
- assert.strictEqual( array[ 0 ], undefined, "With array and offset: check [0]" );
- assert.strictEqual( array[ 1 ], r, "With array and offset: check r" );
- assert.strictEqual( array[ 2 ], g, "With array and offset: check g" );
- assert.strictEqual( array[ 3 ], b, "With array and offset: check b" );
- } );
- QUnit.test( "toJSON", ( assert ) => {
- var a = new Color( 0.0, 0.0, 0.0 );
- var b = new Color( 0.0, 0.5, 0.0 );
- var c = new Color( 1.0, 0.0, 0.0 );
- var d = new Color( 1.0, 1.0, 1.0 );
- assert.strictEqual( a.toJSON(), 0x000000, "Check black" );
- assert.strictEqual( b.toJSON(), 0x007F00, "Check half-blue" );
- assert.strictEqual( c.toJSON(), 0xFF0000, "Check red" );
- assert.strictEqual( d.toJSON(), 0xFFFFFF, "Check white" );
- } );
- // OTHERS
- QUnit.test( "setWithNum", ( assert ) => {
- var c = new Color();
- c.set( 0xFF0000 );
- assert.ok( c.r == 1, "Red: " + c.r );
- assert.ok( c.g === 0, "Green: " + c.g );
- assert.ok( c.b === 0, "Blue: " + c.b );
- } );
- QUnit.test( "setWithString", ( assert ) => {
- var c = new Color();
- c.set( 'silver' );
- assert.ok( c.getHex() == 0xC0C0C0, "Hex c: " + c.getHex() );
- } );
- QUnit.test( "setStyleRGBRed", ( assert ) => {
- var c = new Color();
- c.setStyle( 'rgb(255,0,0)' );
- assert.ok( c.r == 1, "Red: " + c.r );
- assert.ok( c.g === 0, "Green: " + c.g );
- assert.ok( c.b === 0, "Blue: " + c.b );
- } );
- QUnit.test( "setStyleRGBARed", ( assert ) => {
- var c = new Color();
- c.setStyle( 'rgba(255,0,0,0.5)' );
- assert.ok( c.r == 1, "Red: " + c.r );
- assert.ok( c.g === 0, "Green: " + c.g );
- assert.ok( c.b === 0, "Blue: " + c.b );
- } );
- QUnit.test( "setStyleRGBRedWithSpaces", ( assert ) => {
- var c = new Color();
- c.setStyle( 'rgb( 255 , 0, 0 )' );
- assert.ok( c.r == 1, "Red: " + c.r );
- assert.ok( c.g === 0, "Green: " + c.g );
- assert.ok( c.b === 0, "Blue: " + c.b );
- } );
- QUnit.test( "setStyleRGBARedWithSpaces", ( assert ) => {
- var c = new Color();
- c.setStyle( 'rgba( 255, 0, 0 , 1 )' );
- assert.ok( c.r == 1, "Red: " + c.r );
- assert.ok( c.g === 0, "Green: " + c.g );
- assert.ok( c.b === 0, "Blue: " + c.b );
- } );
- QUnit.test( "setStyleRGBPercent", ( assert ) => {
- var c = new Color();
- c.setStyle( 'rgb(100%,50%,10%)' );
- assert.ok( c.r == 1, "Red: " + c.r );
- assert.ok( c.g == 0.5, "Green: " + c.g );
- assert.ok( c.b == 0.1, "Blue: " + c.b );
- } );
- QUnit.test( "setStyleRGBAPercent", ( assert ) => {
- var c = new Color();
- c.setStyle( 'rgba(100%,50%,10%, 0.5)' );
- assert.ok( c.r == 1, "Red: " + c.r );
- assert.ok( c.g == 0.5, "Green: " + c.g );
- assert.ok( c.b == 0.1, "Blue: " + c.b );
- } );
- QUnit.test( "setStyleRGBPercentWithSpaces", ( assert ) => {
- var c = new Color();
- c.setStyle( 'rgb( 100% ,50% , 10% )' );
- assert.ok( c.r == 1, "Red: " + c.r );
- assert.ok( c.g == 0.5, "Green: " + c.g );
- assert.ok( c.b == 0.1, "Blue: " + c.b );
- } );
- QUnit.test( "setStyleRGBAPercentWithSpaces", ( assert ) => {
- var c = new Color();
- c.setStyle( 'rgba( 100% ,50% , 10%, 0.5 )' );
- assert.ok( c.r == 1, "Red: " + c.r );
- assert.ok( c.g == 0.5, "Green: " + c.g );
- assert.ok( c.b == 0.1, "Blue: " + c.b );
- } );
- QUnit.test( "setStyleHSLRed", ( assert ) => {
- var c = new Color();
- c.setStyle( 'hsl(360,100%,50%)' );
- assert.ok( c.r == 1, "Red: " + c.r );
- assert.ok( c.g === 0, "Green: " + c.g );
- assert.ok( c.b === 0, "Blue: " + c.b );
- } );
- QUnit.test( "setStyleHSLARed", ( assert ) => {
- var c = new Color();
- c.setStyle( 'hsla(360,100%,50%,0.5)' );
- assert.ok( c.r == 1, "Red: " + c.r );
- assert.ok( c.g === 0, "Green: " + c.g );
- assert.ok( c.b === 0, "Blue: " + c.b );
- } );
- QUnit.test( "setStyleHSLRedWithSpaces", ( assert ) => {
- var c = new Color();
- c.setStyle( 'hsl(360, 100% , 50% )' );
- assert.ok( c.r == 1, "Red: " + c.r );
- assert.ok( c.g === 0, "Green: " + c.g );
- assert.ok( c.b === 0, "Blue: " + c.b );
- } );
- QUnit.test( "setStyleHSLARedWithSpaces", ( assert ) => {
- var c = new Color();
- c.setStyle( 'hsla( 360, 100% , 50%, 0.5 )' );
- assert.ok( c.r == 1, "Red: " + c.r );
- assert.ok( c.g === 0, "Green: " + c.g );
- assert.ok( c.b === 0, "Blue: " + c.b );
- } );
- QUnit.test( "setStyleHexSkyBlue", ( assert ) => {
- var c = new Color();
- c.setStyle( '#87CEEB' );
- assert.ok( c.getHex() == 0x87CEEB, "Hex c: " + c.getHex() );
- } );
- QUnit.test( "setStyleHexSkyBlueMixed", ( assert ) => {
- var c = new Color();
- c.setStyle( '#87cEeB' );
- assert.ok( c.getHex() == 0x87CEEB, "Hex c: " + c.getHex() );
- } );
- QUnit.test( "setStyleHex2Olive", ( assert ) => {
- var c = new Color();
- c.setStyle( '#F00' );
- assert.ok( c.getHex() == 0xFF0000, "Hex c: " + c.getHex() );
- } );
- QUnit.test( "setStyleHex2OliveMixed", ( assert ) => {
- var c = new Color();
- c.setStyle( '#f00' );
- assert.ok( c.getHex() == 0xFF0000, "Hex c: " + c.getHex() );
- } );
- QUnit.test( "setStyleColorName", ( assert ) => {
- var c = new Color();
- c.setStyle( 'powderblue' );
- assert.ok( c.getHex() == 0xB0E0E6, "Hex c: " + c.getHex() );
- } );
- } );
- } );
|