util methods for calculating color brightness
This commit is contained in:
parent
4823b267cc
commit
8a50a46665
1 changed files with 64 additions and 0 deletions
64
js/reveal.js
64
js/reveal.js
|
@ -714,6 +714,10 @@
|
||||||
if( data.backgroundPosition ) element.style.backgroundPosition = data.backgroundPosition;
|
if( data.backgroundPosition ) element.style.backgroundPosition = data.backgroundPosition;
|
||||||
if( data.backgroundTransition ) element.setAttribute( 'data-background-transition', data.backgroundTransition );
|
if( data.backgroundTransition ) element.setAttribute( 'data-background-transition', data.backgroundTransition );
|
||||||
|
|
||||||
|
if( data.backgroundColor ) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
container.appendChild( element );
|
container.appendChild( element );
|
||||||
|
|
||||||
return element;
|
return element;
|
||||||
|
@ -1065,6 +1069,63 @@
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Measures the distance in pixels between point a and point b.
|
||||||
|
*
|
||||||
|
* @param {String} color The string representation of a color,
|
||||||
|
* the following formats are supported:
|
||||||
|
* - #000
|
||||||
|
* - #000000
|
||||||
|
* - rgb(0,0,0)
|
||||||
|
*/
|
||||||
|
function colorToRgb( color ) {
|
||||||
|
|
||||||
|
var hex3 = color.match( /^#([0-9a-f]{3})$/i );
|
||||||
|
if( hex3 && hex3[1] ) {
|
||||||
|
hex3 = hex3[1];
|
||||||
|
return {
|
||||||
|
r: parseInt( hex3.charAt( 0 ), 16 ) * 0x11,
|
||||||
|
g: parseInt( hex3.charAt( 1 ), 16 ) * 0x11,
|
||||||
|
b: parseInt( hex3.charAt( 2 ), 16 ) * 0x11
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
var hex6 = color.match( /^#([0-9a-f]{6})$/i );
|
||||||
|
if( hex6 && hex6[1] ) {
|
||||||
|
hex6 = hex6[1];
|
||||||
|
return {
|
||||||
|
r: parseInt( hex6.substr( 0, 2 ), 16 ),
|
||||||
|
g: parseInt( hex6.substr( 2, 2 ), 16 ),
|
||||||
|
b: parseInt( hex6.substr( 4, 2 ), 16 )
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
var rgb = color.match( /^rgb\s*\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)$/i );
|
||||||
|
if( rgb ) {
|
||||||
|
return {
|
||||||
|
r: rgb[1],
|
||||||
|
g: rgb[2],
|
||||||
|
b: rgb[3]
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Calculates brightness on a scale of 0-255.
|
||||||
|
*
|
||||||
|
* @param color See colorStringToRgb for supported formats.
|
||||||
|
*/
|
||||||
|
function colorBrightness( color ) {
|
||||||
|
|
||||||
|
if( typeof color === 'string' ) color = colorToRgb( color );
|
||||||
|
|
||||||
|
return ( color.r * 299 + color.g * 587 + color.b * 114 ) / 1000;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Retrieves the height of the given element by looking
|
* Retrieves the height of the given element by looking
|
||||||
* at the position and height of its immediate children.
|
* at the position and height of its immediate children.
|
||||||
|
@ -4039,6 +4100,9 @@
|
||||||
addEventListeners: addEventListeners,
|
addEventListeners: addEventListeners,
|
||||||
removeEventListeners: removeEventListeners,
|
removeEventListeners: removeEventListeners,
|
||||||
|
|
||||||
|
colorToRgb: colorToRgb,
|
||||||
|
colorBrightness: colorBrightness,
|
||||||
|
|
||||||
// Facility for persisting and restoring the presentation state
|
// Facility for persisting and restoring the presentation state
|
||||||
getState: getState,
|
getState: getState,
|
||||||
setState: setState,
|
setState: setState,
|
||||||
|
|
Loading…
Reference in a new issue