forked from sheetjs/sheetjs
		
	
		
			
				
	
	
		
			87 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| function hex2RGB(h) {
 | |
| 	var o = h.substr(h[0]==="#"?1:0,6);
 | |
|         var R = o.substr(0,2);
 | |
|         var G = o.substr(2,2);
 | |
|         var B = o.substr(4,2);
 | |
| 	return [parseInt(R,16),parseInt(G,16),parseInt(B,16)];
 | |
| }
 | |
| function rgb2Hex(rgb) {
 | |
| 	for(var i=0,o=1; i!=3; ++i) o = o*256 + (rgb[i]>255?255:rgb[i]<0?0:rgb[i]);
 | |
| 	return o.toString(16).toUpperCase().substr(1);
 | |
| }
 | |
| 
 | |
| function rgb2HSL(rgb) {
 | |
| 	var R = rgb[0]/255, G = rgb[1]/255, B=rgb[2]/255;
 | |
| 	var M = Math.max(R, G, B), m = Math.min(R, G, B), C = M - m;
 | |
| 	if(C === 0) return [0, 0, R];
 | |
| 
 | |
| 	var H6 = 0, S = 0, L2 = (M + m);
 | |
| 	S = C / (L2 > 1 ? 2 - L2 : L2);
 | |
| 	switch(M){
 | |
| 		case R: H6 = ((G - B) / C + 6)%6; break;
 | |
| 		case G: H6 = ((B - R) / C + 2); break;
 | |
| 		case B: H6 = ((R - G) / C + 4); break;
 | |
| 	}
 | |
| 	return [H6 / 6, S, L2 / 2];
 | |
| }
 | |
| 
 | |
| function hsl2RGB(hsl){
 | |
| 	var H = hsl[0], S = hsl[1], L = hsl[2];
 | |
| 	var C = S * 2 * (L < 0.5 ? L : 1 - L), m = L - C/2;
 | |
| 	var rgb = [m,m,m], h6 = 6*H;
 | |
| 
 | |
| 	var X;
 | |
| 	if(S !== 0) switch(h6|0) {
 | |
| 		case 0: case 6: X = C * h6; rgb[0] += C; rgb[1] += X; break;
 | |
| 		case 1: X = C * (2 - h6);   rgb[0] += X; rgb[1] += C; break;
 | |
| 		case 2: X = C * (h6 - 2);   rgb[1] += C; rgb[2] += X; break;
 | |
| 		case 3: X = C * (4 - h6);   rgb[1] += X; rgb[2] += C; break;
 | |
| 		case 4: X = C * (h6 - 4);   rgb[2] += C; rgb[0] += X; break;
 | |
| 		case 5: X = C * (6 - h6);   rgb[2] += X; rgb[0] += C; break;
 | |
| 	}
 | |
| 	for(var i = 0; i != 3; ++i) rgb[i] = Math.round(rgb[i]*255);
 | |
| 	return rgb;
 | |
| }
 | |
| /* 18.8.3 bgColor tint algorithm */
 | |
| function rgb_tint(hex, tint) {
 | |
| 	if(tint === 0) return hex;
 | |
| 	var hsl = rgb2HSL(hex2RGB(hex));
 | |
| 	if (tint < 0) hsl[2] = hsl[2] * (1 + tint);
 | |
| 	else hsl[2] = 1 - (1 - hsl[2]) * (1 - tint);
 | |
| 	return rgb2Hex(hsl2RGB(hsl));
 | |
| }
 | |
| 
 | |
|  var exp = [
 | |
|       { patternType: 'darkHorizontal',
 | |
|         fgColor: { theme: 9, "tint":-0.249977111117893, rgb: 'F79646' },
 | |
|         bgColor: { theme: 5, "tint":0.3999755851924192, rgb: 'C0504D' } },
 | |
|       { patternType: 'darkUp',
 | |
|         fgColor: { theme: 3, "tint":-0.249977111117893, rgb: 'EEECE1' },
 | |
|         bgColor: { theme: 7, "tint":0.3999755851924192, rgb: '8064A2' } },
 | |
|       { patternType: 'darkGray',
 | |
|         fgColor: { theme: 3, rgb: 'EEECE1' },
 | |
|         bgColor: { theme: 1, rgb: 'FFFFFF' } },
 | |
|       { patternType: 'lightGray',
 | |
|         fgColor: { theme: 6, "tint":0.3999755851924192, rgb: '9BBB59' },
 | |
|         bgColor: { theme: 2, "tint":-0.499984740745262, rgb: '1F497D' } },
 | |
|       { patternType: 'lightDown',
 | |
|         fgColor: { theme: 4, rgb: '4F81BD' },
 | |
|         bgColor: { theme: 7, rgb: '8064A2' } },
 | |
|       { patternType: 'lightGrid',
 | |
|         fgColor: { theme: 6, "tint":-0.249977111117893, rgb: '9BBB59' },
 | |
|         bgColor: { theme: 9, "tint":-0.249977111117893, rgb: 'F79646' } },
 | |
|       { patternType: 'lightGrid',
 | |
|         fgColor: { theme: 4, rgb: '4F81BD' },
 | |
|         bgColor: { theme: 2, "tint":-0.749992370372631, rgb: '1F497D' } },
 | |
|       { patternType: 'lightVertical',
 | |
|         fgColor: { theme: 3, "tint":0.3999755851924192, rgb: 'EEECE1' },
 | |
|         bgColor: { theme: 7, "tint":0.3999755851924192, rgb: '8064A2' } }
 | |
|     ];
 | |
|  var map = [];
 | |
|  exp.forEach(function(e) {
 | |
|     e.fgColor.new =  rgb_tint( e.fgColor.rgb,  e.fgColor.tint || 0); 
 | |
| console.log(e.fgColor.rgb, e.fgColor.new);
 | |
|     e.bgColor.new =  rgb_tint( e.bgColor.rgb,  e.bgColor.tint || 0); 
 | |
| console.log(e.bgColor.rgb, e.bgColor.new);
 | |
|  });
 |