Color.js 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418
  1. /**
  2. * @author mrdoob / http://mrdoob.com/
  3. */
  4. THREE.Color = function ( color ) {
  5. if ( arguments.length === 3 ) {
  6. return this.setRGB( arguments[ 0 ], arguments[ 1 ], arguments[ 2 ] );
  7. }
  8. return this.set( color )
  9. };
  10. THREE.Color.prototype = {
  11. constructor: THREE.Color,
  12. r: 1, g: 1, b: 1,
  13. set: function ( value ) {
  14. if ( value instanceof THREE.Color ) {
  15. this.copy( value );
  16. } else if ( typeof value === 'number' ) {
  17. this.setHex( value );
  18. } else if ( typeof value === 'string' ) {
  19. this.setStyle( value );
  20. }
  21. return this;
  22. },
  23. setHex: function ( hex ) {
  24. hex = Math.floor( hex );
  25. this.r = ( hex >> 16 & 255 ) / 255;
  26. this.g = ( hex >> 8 & 255 ) / 255;
  27. this.b = ( hex & 255 ) / 255;
  28. return this;
  29. },
  30. setRGB: function ( r, g, b ) {
  31. this.r = r;
  32. this.g = g;
  33. this.b = b;
  34. return this;
  35. },
  36. setHSL: function ( h, s, l ) {
  37. // h,s,l ranges are in 0.0 - 1.0
  38. if ( s === 0 ) {
  39. this.r = this.g = this.b = l;
  40. } else {
  41. var hue2rgb = function ( p, q, t ) {
  42. if ( t < 0 ) t += 1;
  43. if ( t > 1 ) t -= 1;
  44. if ( t < 1 / 6 ) return p + ( q - p ) * 6 * t;
  45. if ( t < 1 / 2 ) return q;
  46. if ( t < 2 / 3 ) return p + ( q - p ) * 6 * ( 2 / 3 - t );
  47. return p;
  48. };
  49. var p = l <= 0.5 ? l * ( 1 + s ) : l + s - ( l * s );
  50. var q = ( 2 * l ) - p;
  51. this.r = hue2rgb( q, p, h + 1 / 3 );
  52. this.g = hue2rgb( q, p, h );
  53. this.b = hue2rgb( q, p, h - 1 / 3 );
  54. }
  55. return this;
  56. },
  57. setStyle: function ( style ) {
  58. // rgb(255,0,0)
  59. if ( /^rgb\((\d+), ?(\d+), ?(\d+)\)$/i.test( style ) ) {
  60. var color = /^rgb\((\d+), ?(\d+), ?(\d+)\)$/i.exec( style );
  61. this.r = Math.min( 255, parseInt( color[ 1 ], 10 ) ) / 255;
  62. this.g = Math.min( 255, parseInt( color[ 2 ], 10 ) ) / 255;
  63. this.b = Math.min( 255, parseInt( color[ 3 ], 10 ) ) / 255;
  64. return this;
  65. }
  66. // rgb(100%,0%,0%)
  67. if ( /^rgb\((\d+)\%, ?(\d+)\%, ?(\d+)\%\)$/i.test( style ) ) {
  68. var color = /^rgb\((\d+)\%, ?(\d+)\%, ?(\d+)\%\)$/i.exec( style );
  69. this.r = Math.min( 100, parseInt( color[ 1 ], 10 ) ) / 100;
  70. this.g = Math.min( 100, parseInt( color[ 2 ], 10 ) ) / 100;
  71. this.b = Math.min( 100, parseInt( color[ 3 ], 10 ) ) / 100;
  72. return this;
  73. }
  74. // #ff0000
  75. if ( /^\#([0-9a-f]{6})$/i.test( style ) ) {
  76. var color = /^\#([0-9a-f]{6})$/i.exec( style );
  77. this.setHex( parseInt( color[ 1 ], 16 ) );
  78. return this;
  79. }
  80. // #f00
  81. if ( /^\#([0-9a-f])([0-9a-f])([0-9a-f])$/i.test( style ) ) {
  82. var color = /^\#([0-9a-f])([0-9a-f])([0-9a-f])$/i.exec( style );
  83. this.setHex( parseInt( color[ 1 ] + color[ 1 ] + color[ 2 ] + color[ 2 ] + color[ 3 ] + color[ 3 ], 16 ) );
  84. return this;
  85. }
  86. // red
  87. if ( /^(\w+)$/i.test( style ) ) {
  88. this.setHex( THREE.ColorKeywords[ style ] );
  89. return this;
  90. }
  91. },
  92. copy: function ( color ) {
  93. this.r = color.r;
  94. this.g = color.g;
  95. this.b = color.b;
  96. return this;
  97. },
  98. copyGammaToLinear: function ( color, gammaFactor ) {
  99. if ( gammaFactor === undefined ) gammaFactor = 2.0;
  100. this.r = Math.pow( color.r, gammaFactor );
  101. this.g = Math.pow( color.g, gammaFactor );
  102. this.b = Math.pow( color.b, gammaFactor );
  103. return this;
  104. },
  105. copyLinearToGamma: function ( color, gammaFactor ) {
  106. if ( gammaFactor === undefined ) gammaFactor = 2.0;
  107. var safeInverse = ( gammaFactor > 0 ) ? ( 1.0 / gammaFactor ) : 1.0;
  108. this.r = Math.pow( color.r, safeInverse );
  109. this.g = Math.pow( color.g, safeInverse );
  110. this.b = Math.pow( color.b, safeInverse );
  111. return this;
  112. },
  113. convertGammaToLinear: function () {
  114. var r = this.r, g = this.g, b = this.b;
  115. this.r = r * r;
  116. this.g = g * g;
  117. this.b = b * b;
  118. return this;
  119. },
  120. convertLinearToGamma: function () {
  121. this.r = Math.sqrt( this.r );
  122. this.g = Math.sqrt( this.g );
  123. this.b = Math.sqrt( this.b );
  124. return this;
  125. },
  126. getHex: function () {
  127. return ( this.r * 255 ) << 16 ^ ( this.g * 255 ) << 8 ^ ( this.b * 255 ) << 0;
  128. },
  129. getHexString: function () {
  130. return ( '000000' + this.getHex().toString( 16 ) ).slice( - 6 );
  131. },
  132. getHSL: function ( optionalTarget ) {
  133. // h,s,l ranges are in 0.0 - 1.0
  134. var hsl = optionalTarget || { h: 0, s: 0, l: 0 };
  135. var r = this.r, g = this.g, b = this.b;
  136. var max = Math.max( r, g, b );
  137. var min = Math.min( r, g, b );
  138. var hue, saturation;
  139. var lightness = ( min + max ) / 2.0;
  140. if ( min === max ) {
  141. hue = 0;
  142. saturation = 0;
  143. } else {
  144. var delta = max - min;
  145. saturation = lightness <= 0.5 ? delta / ( max + min ) : delta / ( 2 - max - min );
  146. switch ( max ) {
  147. case r: hue = ( g - b ) / delta + ( g < b ? 6 : 0 ); break;
  148. case g: hue = ( b - r ) / delta + 2; break;
  149. case b: hue = ( r - g ) / delta + 4; break;
  150. }
  151. hue /= 6;
  152. }
  153. hsl.h = hue;
  154. hsl.s = saturation;
  155. hsl.l = lightness;
  156. return hsl;
  157. },
  158. getStyle: function () {
  159. return 'rgb(' + ( ( this.r * 255 ) | 0 ) + ',' + ( ( this.g * 255 ) | 0 ) + ',' + ( ( this.b * 255 ) | 0 ) + ')';
  160. },
  161. offsetHSL: function ( h, s, l ) {
  162. var hsl = this.getHSL();
  163. hsl.h += h; hsl.s += s; hsl.l += l;
  164. this.setHSL( hsl.h, hsl.s, hsl.l );
  165. return this;
  166. },
  167. add: function ( color ) {
  168. this.r += color.r;
  169. this.g += color.g;
  170. this.b += color.b;
  171. return this;
  172. },
  173. addColors: function ( color1, color2 ) {
  174. this.r = color1.r + color2.r;
  175. this.g = color1.g + color2.g;
  176. this.b = color1.b + color2.b;
  177. return this;
  178. },
  179. addScalar: function ( s ) {
  180. this.r += s;
  181. this.g += s;
  182. this.b += s;
  183. return this;
  184. },
  185. multiply: function ( color ) {
  186. this.r *= color.r;
  187. this.g *= color.g;
  188. this.b *= color.b;
  189. return this;
  190. },
  191. multiplyScalar: function ( s ) {
  192. this.r *= s;
  193. this.g *= s;
  194. this.b *= s;
  195. return this;
  196. },
  197. lerp: function ( color, alpha ) {
  198. this.r += ( color.r - this.r ) * alpha;
  199. this.g += ( color.g - this.g ) * alpha;
  200. this.b += ( color.b - this.b ) * alpha;
  201. return this;
  202. },
  203. equals: function ( c ) {
  204. return ( c.r === this.r ) && ( c.g === this.g ) && ( c.b === this.b );
  205. },
  206. fromArray: function ( array ) {
  207. this.r = array[ 0 ];
  208. this.g = array[ 1 ];
  209. this.b = array[ 2 ];
  210. return this;
  211. },
  212. toArray: function( array, offset ) {
  213. if ( array === undefined ) array = [];
  214. if ( offset === undefined ) offset = 0;
  215. array[ offset ] = this.r;
  216. array[ offset + 1 ] = this.g;
  217. array[ offset + 2 ] = this.b;
  218. return array;
  219. },
  220. clone: function () {
  221. return new THREE.Color().setRGB( this.r, this.g, this.b );
  222. }
  223. };
  224. THREE.ColorKeywords = { 'aliceblue': 0xF0F8FF, 'antiquewhite': 0xFAEBD7, 'aqua': 0x00FFFF, 'aquamarine': 0x7FFFD4, 'azure': 0xF0FFFF,
  225. 'beige': 0xF5F5DC, 'bisque': 0xFFE4C4, 'black': 0x000000, 'blanchedalmond': 0xFFEBCD, 'blue': 0x0000FF, 'blueviolet': 0x8A2BE2,
  226. 'brown': 0xA52A2A, 'burlywood': 0xDEB887, 'cadetblue': 0x5F9EA0, 'chartreuse': 0x7FFF00, 'chocolate': 0xD2691E, 'coral': 0xFF7F50,
  227. 'cornflowerblue': 0x6495ED, 'cornsilk': 0xFFF8DC, 'crimson': 0xDC143C, 'cyan': 0x00FFFF, 'darkblue': 0x00008B, 'darkcyan': 0x008B8B,
  228. 'darkgoldenrod': 0xB8860B, 'darkgray': 0xA9A9A9, 'darkgreen': 0x006400, 'darkgrey': 0xA9A9A9, 'darkkhaki': 0xBDB76B, 'darkmagenta': 0x8B008B,
  229. 'darkolivegreen': 0x556B2F, 'darkorange': 0xFF8C00, 'darkorchid': 0x9932CC, 'darkred': 0x8B0000, 'darksalmon': 0xE9967A, 'darkseagreen': 0x8FBC8F,
  230. 'darkslateblue': 0x483D8B, 'darkslategray': 0x2F4F4F, 'darkslategrey': 0x2F4F4F, 'darkturquoise': 0x00CED1, 'darkviolet': 0x9400D3,
  231. 'deeppink': 0xFF1493, 'deepskyblue': 0x00BFFF, 'dimgray': 0x696969, 'dimgrey': 0x696969, 'dodgerblue': 0x1E90FF, 'firebrick': 0xB22222,
  232. 'floralwhite': 0xFFFAF0, 'forestgreen': 0x228B22, 'fuchsia': 0xFF00FF, 'gainsboro': 0xDCDCDC, 'ghostwhite': 0xF8F8FF, 'gold': 0xFFD700,
  233. 'goldenrod': 0xDAA520, 'gray': 0x808080, 'green': 0x008000, 'greenyellow': 0xADFF2F, 'grey': 0x808080, 'honeydew': 0xF0FFF0, 'hotpink': 0xFF69B4,
  234. 'indianred': 0xCD5C5C, 'indigo': 0x4B0082, 'ivory': 0xFFFFF0, 'khaki': 0xF0E68C, 'lavender': 0xE6E6FA, 'lavenderblush': 0xFFF0F5, 'lawngreen': 0x7CFC00,
  235. 'lemonchiffon': 0xFFFACD, 'lightblue': 0xADD8E6, 'lightcoral': 0xF08080, 'lightcyan': 0xE0FFFF, 'lightgoldenrodyellow': 0xFAFAD2, 'lightgray': 0xD3D3D3,
  236. 'lightgreen': 0x90EE90, 'lightgrey': 0xD3D3D3, 'lightpink': 0xFFB6C1, 'lightsalmon': 0xFFA07A, 'lightseagreen': 0x20B2AA, 'lightskyblue': 0x87CEFA,
  237. 'lightslategray': 0x778899, 'lightslategrey': 0x778899, 'lightsteelblue': 0xB0C4DE, 'lightyellow': 0xFFFFE0, 'lime': 0x00FF00, 'limegreen': 0x32CD32,
  238. 'linen': 0xFAF0E6, 'magenta': 0xFF00FF, 'maroon': 0x800000, 'mediumaquamarine': 0x66CDAA, 'mediumblue': 0x0000CD, 'mediumorchid': 0xBA55D3,
  239. 'mediumpurple': 0x9370DB, 'mediumseagreen': 0x3CB371, 'mediumslateblue': 0x7B68EE, 'mediumspringgreen': 0x00FA9A, 'mediumturquoise': 0x48D1CC,
  240. 'mediumvioletred': 0xC71585, 'midnightblue': 0x191970, 'mintcream': 0xF5FFFA, 'mistyrose': 0xFFE4E1, 'moccasin': 0xFFE4B5, 'navajowhite': 0xFFDEAD,
  241. 'navy': 0x000080, 'oldlace': 0xFDF5E6, 'olive': 0x808000, 'olivedrab': 0x6B8E23, 'orange': 0xFFA500, 'orangered': 0xFF4500, 'orchid': 0xDA70D6,
  242. 'palegoldenrod': 0xEEE8AA, 'palegreen': 0x98FB98, 'paleturquoise': 0xAFEEEE, 'palevioletred': 0xDB7093, 'papayawhip': 0xFFEFD5, 'peachpuff': 0xFFDAB9,
  243. 'peru': 0xCD853F, 'pink': 0xFFC0CB, 'plum': 0xDDA0DD, 'powderblue': 0xB0E0E6, 'purple': 0x800080, 'red': 0xFF0000, 'rosybrown': 0xBC8F8F,
  244. 'royalblue': 0x4169E1, 'saddlebrown': 0x8B4513, 'salmon': 0xFA8072, 'sandybrown': 0xF4A460, 'seagreen': 0x2E8B57, 'seashell': 0xFFF5EE,
  245. 'sienna': 0xA0522D, 'silver': 0xC0C0C0, 'skyblue': 0x87CEEB, 'slateblue': 0x6A5ACD, 'slategray': 0x708090, 'slategrey': 0x708090, 'snow': 0xFFFAFA,
  246. 'springgreen': 0x00FF7F, 'steelblue': 0x4682B4, 'tan': 0xD2B48C, 'teal': 0x008080, 'thistle': 0xD8BFD8, 'tomato': 0xFF6347, 'turquoise': 0x40E0D0,
  247. 'violet': 0xEE82EE, 'wheat': 0xF5DEB3, 'white': 0xFFFFFF, 'whitesmoke': 0xF5F5F5, 'yellow': 0xFFFF00, 'yellowgreen': 0x9ACD32 };