UNPKG

c8y-openlayer

Version:

This module is designed to help integrate Openlayer with Cumulocity IoT

215 lines (189 loc) 4.87 kB
import _ol_asserts_ from './asserts.js'; import _ol_math_ from './math.js'; var _ol_color_ = {}; /** * This RegExp matches # followed by 3, 4, 6, or 8 hex digits. * @const * @type {RegExp} * @private */ _ol_color_.HEX_COLOR_RE_ = /^#(?:[0-9a-f]{3,4}){1,2}$/i; /** * Regular expression for matching potential named color style strings. * @const * @type {RegExp} * @private */ _ol_color_.NAMED_COLOR_RE_ = /^([a-z]*)$/i; /** * Return the color as an array. This function maintains a cache of calculated * arrays which means the result should not be modified. * @param {ol.Color|string} color Color. * @return {ol.Color} Color. * @api */ _ol_color_.asArray = function(color) { if (Array.isArray(color)) { return color; } else { return _ol_color_.fromString(/** @type {string} */ (color)); } }; /** * Return the color as an rgba string. * @param {ol.Color|string} color Color. * @return {string} Rgba string. * @api */ _ol_color_.asString = function(color) { if (typeof color === 'string') { return color; } else { return _ol_color_.toString(color); } }; /** * Return named color as an rgba string. * @param {string} color Named color. * @return {string} Rgb string. */ _ol_color_.fromNamed = function(color) { var el = document.createElement('div'); el.style.color = color; document.body.appendChild(el); var rgb = getComputedStyle(el).color; document.body.removeChild(el); return rgb; }; /** * @param {string} s String. * @return {ol.Color} Color. */ _ol_color_.fromString = ( function() { // We maintain a small cache of parsed strings. To provide cheap LRU-like // semantics, whenever the cache grows too large we simply delete an // arbitrary 25% of the entries. /** * @const * @type {number} */ var MAX_CACHE_SIZE = 1024; /** * @type {Object.<string, ol.Color>} */ var cache = {}; /** * @type {number} */ var cacheSize = 0; return ( /** * @param {string} s String. * @return {ol.Color} Color. */ function(s) { var color; if (cache.hasOwnProperty(s)) { color = cache[s]; } else { if (cacheSize >= MAX_CACHE_SIZE) { var i = 0; var key; for (key in cache) { if ((i++ & 3) === 0) { delete cache[key]; --cacheSize; } } } color = _ol_color_.fromStringInternal_(s); cache[s] = color; ++cacheSize; } return color; } ); })(); /** * @param {string} s String. * @private * @return {ol.Color} Color. */ _ol_color_.fromStringInternal_ = function(s) { var r, g, b, a, color, parts; if (_ol_color_.NAMED_COLOR_RE_.exec(s)) { s = _ol_color_.fromNamed(s); } if (_ol_color_.HEX_COLOR_RE_.exec(s)) { // hex var n = s.length - 1; // number of hex digits var d; // number of digits per channel if (n <= 4) { d = 1; } else { d = 2; } var hasAlpha = n === 4 || n === 8; r = parseInt(s.substr(1 + 0 * d, d), 16); g = parseInt(s.substr(1 + 1 * d, d), 16); b = parseInt(s.substr(1 + 2 * d, d), 16); if (hasAlpha) { a = parseInt(s.substr(1 + 3 * d, d), 16); } else { a = 255; } if (d == 1) { r = (r << 4) + r; g = (g << 4) + g; b = (b << 4) + b; if (hasAlpha) { a = (a << 4) + a; } } color = [r, g, b, a / 255]; } else if (s.indexOf('rgba(') == 0) { // rgba() parts = s.slice(5, -1).split(',').map(Number); color = _ol_color_.normalize(parts); } else if (s.indexOf('rgb(') == 0) { // rgb() parts = s.slice(4, -1).split(',').map(Number); parts.push(1); color = _ol_color_.normalize(parts); } else { _ol_asserts_.assert(false, 14); // Invalid color } return /** @type {ol.Color} */ (color); }; /** * @param {ol.Color} color Color. * @param {ol.Color=} opt_color Color. * @return {ol.Color} Clamped color. */ _ol_color_.normalize = function(color, opt_color) { var result = opt_color || []; result[0] = _ol_math_.clamp((color[0] + 0.5) | 0, 0, 255); result[1] = _ol_math_.clamp((color[1] + 0.5) | 0, 0, 255); result[2] = _ol_math_.clamp((color[2] + 0.5) | 0, 0, 255); result[3] = _ol_math_.clamp(color[3], 0, 1); return result; }; /** * @param {ol.Color} color Color. * @return {string} String. */ _ol_color_.toString = function(color) { var r = color[0]; if (r != (r | 0)) { r = (r + 0.5) | 0; } var g = color[1]; if (g != (g | 0)) { g = (g + 0.5) | 0; } var b = color[2]; if (b != (b | 0)) { b = (b + 0.5) | 0; } var a = color[3] === undefined ? 1 : color[3]; return 'rgba(' + r + ',' + g + ',' + b + ',' + a + ')'; }; export default _ol_color_;