yuyeon 0.3.5 → 0.3.6-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/style.css +1 -1
- package/dist/yuyeon.js +2394 -2332
- package/dist/yuyeon.umd.cjs +3 -3
- package/lib/abstract/items.js.map +1 -1
- package/lib/components/alert/YAlert.js +2 -2
- package/lib/components/alert/YAlert.js.map +1 -1
- package/lib/components/badge/YBadge.js.map +1 -1
- package/lib/components/badge/YBadge.scss +87 -87
- package/lib/components/card/YCard.js.map +1 -1
- package/lib/components/checkbox/YCheckbox.js.map +1 -1
- package/lib/components/date-picker/YDateCalendar.js.map +1 -1
- package/lib/components/date-picker/YDatePicker.js.map +1 -1
- package/lib/components/date-picker/YDatePickerControl.js.map +1 -1
- package/lib/components/date-picker/YMonthPicker.js.map +1 -1
- package/lib/components/date-picker/YYearPicker.js.map +1 -1
- package/lib/components/dialog/YDialog.js.map +1 -1
- package/lib/components/divider/YDivider.js.map +1 -1
- package/lib/components/draggable/YDraggable.js.map +1 -1
- package/lib/components/draggable/index.js.map +1 -1
- package/lib/components/dropdown/YDropdown.js.map +1 -1
- package/lib/components/field-input/YFieldInput.js.map +1 -1
- package/lib/components/form/YForm.js.map +1 -1
- package/lib/components/hover/YHover.js.map +1 -1
- package/lib/components/icon/YIcon.js.map +1 -1
- package/lib/components/icons/YIconCheckbox.js.map +1 -1
- package/lib/components/icons/YIconCheckbox.scss +4 -5
- package/lib/components/icons/YIconClear.js.map +1 -1
- package/lib/components/icons/YIconDropdown.js.map +1 -1
- package/lib/components/icons/YIconExpand.js.map +1 -1
- package/lib/components/icons/YIconPageControl.js.map +1 -1
- package/lib/components/icons/YIconSort.js.map +1 -1
- package/lib/components/img/YImg.js +4 -4
- package/lib/components/img/YImg.js.map +1 -1
- package/lib/components/img/index.js.map +1 -1
- package/lib/components/index.js.map +1 -1
- package/lib/components/input/YInput.js.map +1 -1
- package/lib/components/layer/YLayer.js.map +1 -1
- package/lib/components/layer/base.js +2 -2
- package/lib/components/layer/base.js.map +1 -1
- package/lib/components/layer/content.js.map +1 -1
- package/lib/components/list/YListItem.js.map +1 -1
- package/lib/components/menu/YMenu.js +2 -2
- package/lib/components/menu/YMenu.js.map +1 -1
- package/lib/components/panel/YDividePanel.js.map +1 -1
- package/lib/components/panel/YDividePanel.scss +44 -44
- package/lib/components/plate/YPlate.js +2 -2
- package/lib/components/plate/YPlate.js.map +1 -1
- package/lib/components/radio/YRadio.js.map +1 -1
- package/lib/components/radio/YRadioIcon.js.map +1 -1
- package/lib/components/radio/index.js.map +1 -1
- package/lib/components/select/YSelect.js.map +1 -1
- package/lib/components/slider/YSlider.js.map +1 -1
- package/lib/components/slider/index.js.map +1 -1
- package/lib/components/switch/YSwitch.js.map +1 -1
- package/lib/components/tab/YTab.js.map +1 -1
- package/lib/components/tab/YTabs.js.map +1 -1
- package/lib/components/table/YDataTable.js.map +1 -1
- package/lib/components/table/YDataTableBody.js.map +1 -1
- package/lib/components/table/YDataTableControl.js.map +1 -1
- package/lib/components/table/YDataTableControl.scss +17 -17
- package/lib/components/table/YDataTableLayerRows.js.map +1 -1
- package/lib/components/table/YDataTableServer.js.map +1 -1
- package/lib/components/table/YTable.js.map +1 -1
- package/lib/components/table/composables/expand.js.map +1 -1
- package/lib/components/table/composables/header.js.map +1 -1
- package/lib/components/table/composables/items.js.map +1 -1
- package/lib/components/table/composables/measure.js.map +1 -1
- package/lib/components/table/composables/provides.js.map +1 -1
- package/lib/components/table/types/item.js.map +1 -1
- package/lib/components/text-ellipsis/YTextEllipsis.js.map +1 -1
- package/lib/components/text-highlighter/YTextHighlighter.js.map +1 -1
- package/lib/components/text-interpolation/YTi.js.map +1 -1
- package/lib/components/tooltip/YTooltip.js +2 -2
- package/lib/components/tooltip/YTooltip.js.map +1 -1
- package/lib/components/tree-view/YTreeView.js +23 -28
- package/lib/components/tree-view/YTreeView.js.map +1 -1
- package/lib/components/tree-view/YTreeViewNode.js +58 -20
- package/lib/components/tree-view/YTreeViewNode.js.map +1 -1
- package/lib/components/tree-view/tree-view.js +61 -8
- package/lib/components/tree-view/tree-view.js.map +1 -1
- package/lib/components/tree-view/types.js.map +1 -1
- package/lib/composables/choice.js.map +1 -1
- package/lib/composables/coordinate/index.js.map +1 -1
- package/lib/composables/coordinate/levitation.js +2 -2
- package/lib/composables/coordinate/levitation.js.map +1 -1
- package/lib/composables/coordinate/types.js.map +1 -1
- package/lib/composables/defaults/types.js.map +1 -1
- package/lib/composables/form.js.map +1 -1
- package/lib/composables/style-color.js.map +1 -1
- package/lib/composables/theme/index.js.map +1 -1
- package/lib/composables/theme/types.js.map +1 -1
- package/lib/composables/timing.js.map +1 -1
- package/lib/composables/validation.js.map +1 -1
- package/lib/directives/index.js.map +1 -1
- package/lib/directives/plate-wave/index.js +2 -2
- package/lib/directives/plate-wave/index.js.map +1 -1
- package/lib/directives/plate-wave/plate-wave.scss +44 -44
- package/lib/directives/theme-class/index.js.map +1 -1
- package/lib/etc/index.js.map +1 -1
- package/lib/i18n/built-in.js.map +1 -1
- package/lib/i18n/config.js.map +1 -1
- package/lib/i18n/types.js.map +1 -1
- package/lib/index.js.map +1 -1
- package/lib/locales/en.js.map +1 -1
- package/lib/locales/ko.js.map +1 -1
- package/lib/styles/settings/_provided.scss +33 -33
- package/lib/styles/theme/index.scss +4 -4
- package/lib/types/index.js.map +1 -1
- package/lib/util/color/apca.js +30 -30
- package/lib/util/color/apca.js.map +1 -1
- package/lib/util/color/const.js.map +1 -1
- package/lib/util/color/hct/cam16.js +95 -95
- package/lib/util/color/hct/cam16.js.map +1 -1
- package/lib/util/color/hct/hct-solver.js +107 -107
- package/lib/util/color/hct/hct-solver.js.map +1 -1
- package/lib/util/color/hct/hct.js +71 -71
- package/lib/util/color/hct/hct.js.map +1 -1
- package/lib/util/color/index.js +12 -12
- package/lib/util/color/index.js.map +1 -1
- package/lib/util/common.js.map +1 -1
- package/lib/util/component/component.js.map +1 -1
- package/lib/util/component/inject-self.js.map +1 -1
- package/lib/util/component/props.js.map +1 -1
- package/lib/util/component/types.js.map +1 -1
- package/lib/util/date/built-in.js.map +1 -1
- package/lib/util/date/index.js.map +1 -1
- package/lib/util/date/types.js.map +1 -1
- package/lib/util/debounce.js.map +1 -1
- package/lib/util/dom.js.map +1 -1
- package/lib/util/index.js.map +1 -1
- package/lib/util/string.js.map +1 -1
- package/lib/util/ui.js.map +1 -1
- package/package.json +132 -132
- package/types/components/tree-view/YTreeView.d.ts +18 -26
- package/types/components/tree-view/YTreeViewNode.d.ts +71 -1
- package/types/components/tree-view/tree-view.d.ts +17 -1
- package/types/declares.d.ts +1 -1
- package/types/globals.d.ts +19 -19
- package/types/shims.d.ts +64 -64
package/lib/util/color/apca.js
CHANGED
|
@@ -1,29 +1,29 @@
|
|
|
1
1
|
///////////////////////////////////////////////////////////////////////////////
|
|
2
|
-
/** @preserve
|
|
3
|
-
///// SAPC APCA - Advanced Perceptual Contrast Algorithm
|
|
4
|
-
///// Beta 0.1.9 W3 • contrast function only
|
|
5
|
-
///// DIST: W3 • Revision date: July 3, 2022
|
|
6
|
-
///// Function to parse color values and determine Lc contrast
|
|
7
|
-
///// Copyright © 2019-2022 by Andrew Somers. All Rights Reserved.
|
|
8
|
-
///// LICENSE: W3 LICENSE
|
|
9
|
-
///// CONTACT: Please use the ISSUES or DISCUSSIONS tab at:
|
|
10
|
-
///// https://github.com/Myndex/SAPC-APCA/
|
|
11
|
-
/////
|
|
12
|
-
///////////////////////////////////////////////////////////////////////////////
|
|
13
|
-
/////
|
|
14
|
-
///// MINIMAL IMPORTS:
|
|
15
|
-
///// import { APCAcontrast, sRGBtoY, displayP3toY,
|
|
16
|
-
///// calcAPCA, fontLookupAPCA } from 'apca-w3';
|
|
17
|
-
///// import { colorParsley } from 'colorparsley';
|
|
18
|
-
/////
|
|
19
|
-
///// FORWARD CONTRAST USAGE:
|
|
20
|
-
///// Lc = APCAcontrast( sRGBtoY( TEXTcolor ) , sRGBtoY( BACKGNDcolor ) );
|
|
21
|
-
///// Where the colors are sent as an rgba array [255,255,255,1]
|
|
22
|
-
/////
|
|
23
|
-
///// Retrieving an array of font sizes for the contrast:
|
|
24
|
-
///// fontArray = fontLookupAPCA(Lc);
|
|
25
|
-
/////
|
|
26
|
-
///// Live Demonstrator at https://www.myndex.com/APCA/
|
|
2
|
+
/** @preserve
|
|
3
|
+
///// SAPC APCA - Advanced Perceptual Contrast Algorithm
|
|
4
|
+
///// Beta 0.1.9 W3 • contrast function only
|
|
5
|
+
///// DIST: W3 • Revision date: July 3, 2022
|
|
6
|
+
///// Function to parse color values and determine Lc contrast
|
|
7
|
+
///// Copyright © 2019-2022 by Andrew Somers. All Rights Reserved.
|
|
8
|
+
///// LICENSE: W3 LICENSE
|
|
9
|
+
///// CONTACT: Please use the ISSUES or DISCUSSIONS tab at:
|
|
10
|
+
///// https://github.com/Myndex/SAPC-APCA/
|
|
11
|
+
/////
|
|
12
|
+
///////////////////////////////////////////////////////////////////////////////
|
|
13
|
+
/////
|
|
14
|
+
///// MINIMAL IMPORTS:
|
|
15
|
+
///// import { APCAcontrast, sRGBtoY, displayP3toY,
|
|
16
|
+
///// calcAPCA, fontLookupAPCA } from 'apca-w3';
|
|
17
|
+
///// import { colorParsley } from 'colorparsley';
|
|
18
|
+
/////
|
|
19
|
+
///// FORWARD CONTRAST USAGE:
|
|
20
|
+
///// Lc = APCAcontrast( sRGBtoY( TEXTcolor ) , sRGBtoY( BACKGNDcolor ) );
|
|
21
|
+
///// Where the colors are sent as an rgba array [255,255,255,1]
|
|
22
|
+
/////
|
|
23
|
+
///// Retrieving an array of font sizes for the contrast:
|
|
24
|
+
///// fontArray = fontLookupAPCA(Lc);
|
|
25
|
+
/////
|
|
26
|
+
///// Live Demonstrator at https://www.myndex.com/APCA/
|
|
27
27
|
// */
|
|
28
28
|
///////////////////////////////////////////////////////////////////////////////
|
|
29
29
|
|
|
@@ -82,11 +82,11 @@ export function sRGBtoY() {
|
|
|
82
82
|
// NOTE: Currently expects 0-255
|
|
83
83
|
|
|
84
84
|
///// APCA 0.0.98G - 4g - W3 Compatible Constants ////////////////////
|
|
85
|
-
/*
|
|
86
|
-
const mainTRC = 2.4; // 2.4 exponent emulates actual monitor perception
|
|
87
|
-
|
|
88
|
-
sGco = 0.7151522,
|
|
89
|
-
sBco = 0.0721750; // sRGB coefficients
|
|
85
|
+
/*
|
|
86
|
+
const mainTRC = 2.4; // 2.4 exponent emulates actual monitor perception
|
|
87
|
+
const sRco = 0.2126729,
|
|
88
|
+
sGco = 0.7151522,
|
|
89
|
+
sBco = 0.0721750; // sRGB coefficients
|
|
90
90
|
*/
|
|
91
91
|
// Future:
|
|
92
92
|
// 0.2126478133913640 0.7151791475336150 0.0721730390750208
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"apca.js","names":["SA98G","mainTRC","mainTRCencode","sRco","sGco","sBco","normBG","normTXT","revTXT","revBG","blkThrs","blkClmp","scaleBoW","scaleWoB","loBoWoffset","loWoBoffset","deltaYmin","loClip","mFactor","mFactInv","mOffsetIn","mExpAdj","mExp","mOffsetOut","sRGBtoY","rgb","arguments","length","undefined","simpleExp","chan","Math","pow","APCAcontrast","txtY","bgY","places","icp","isNaN","min","max","SAPC","outputContrast","polCat","abs","round","Number","isInteger","toFixed","alphaBlend","rgbaFG","rgbBG","compBlend","rgbOut","i"],"sources":["../../../src/util/color/apca.ts"],"sourcesContent":["///////////////////////////////////////////////////////////////////////////////\n/** @preserve\n ///// SAPC APCA - Advanced Perceptual Contrast Algorithm\n ///// Beta 0.1.9 W3 • contrast function only\n ///// DIST: W3 • Revision date: July 3, 2022\n ///// Function to parse color values and determine Lc contrast\n ///// Copyright © 2019-2022 by Andrew Somers. All Rights Reserved.\n ///// LICENSE: W3 LICENSE\n ///// CONTACT: Please use the ISSUES or DISCUSSIONS tab at:\n ///// https://github.com/Myndex/SAPC-APCA/\n /////\n ///////////////////////////////////////////////////////////////////////////////\n /////\n ///// MINIMAL IMPORTS:\n ///// import { APCAcontrast, sRGBtoY, displayP3toY,\n///// calcAPCA, fontLookupAPCA } from 'apca-w3';\n ///// import { colorParsley } from 'colorparsley';\n /////\n ///// FORWARD CONTRAST USAGE:\n ///// Lc = APCAcontrast( sRGBtoY( TEXTcolor ) , sRGBtoY( BACKGNDcolor ) );\n ///// Where the colors are sent as an rgba array [255,255,255,1]\n /////\n ///// Retrieving an array of font sizes for the contrast:\n ///// fontArray = fontLookupAPCA(Lc);\n /////\n ///// Live Demonstrator at https://www.myndex.com/APCA/\n // */\n///////////////////////////////////////////////////////////////////////////////\n\n///// Module Scope Object Containing Constants /////\n///// APCA 0.0.98G - 4g - W3 Compatible Constants\n\n///// 𝒦 SA98G ///////////////////////////////////\nconst SA98G = {\n mainTRC: 2.4, // 2.4 exponent for emulating actual monitor perception\n\n // For reverseAPCA\n get mainTRCencode() {\n return 1 / this.mainTRC;\n },\n\n // sRGB coefficients\n sRco: 0.2126729,\n sGco: 0.7151522,\n sBco: 0.072175,\n\n // G-4g constants for use with 2.4 exponent\n normBG: 0.56,\n normTXT: 0.57,\n revTXT: 0.62,\n revBG: 0.65,\n\n // G-4g Clamps and Scalers\n blkThrs: 0.022,\n blkClmp: 1.414,\n scaleBoW: 1.14,\n scaleWoB: 1.14,\n loBoWoffset: 0.027,\n loWoBoffset: 0.027,\n deltaYmin: 0.0005,\n loClip: 0.1,\n\n ///// MAGIC NUMBERS for UNCLAMP, for use with 0.022 & 1.414 /////\n // Magic Numbers for reverseAPCA\n mFactor: 1.9468554433171,\n get mFactInv() {\n return 1 / this.mFactor;\n },\n mOffsetIn: 0.0387393816571401,\n mExpAdj: 0.283343396420869,\n get mExp() {\n return this.mExpAdj / this.blkClmp;\n },\n mOffsetOut: 0.312865795870758,\n};\n\n//////////////////////////////////////////////////////////////////////////////\n////////// LUMINANCE CONVERTERS |//////////////////////////////////////////\n\n////////// ƒ sRGBtoY() //////////////////////////////////////////////////\nexport function sRGBtoY(rgb = [0, 0, 0]) {\n // send sRGB 8bpc (0xFFFFFF) or string\n\n // NOTE: Currently expects 0-255\n\n ///// APCA 0.0.98G - 4g - W3 Compatible Constants ////////////////////\n /*\n const mainTRC = 2.4; // 2.4 exponent emulates actual monitor perception\n\n const sRco = 0.2126729,\n sGco = 0.7151522,\n sBco = 0.0721750; // sRGB coefficients\n */\n // Future:\n // 0.2126478133913640\t0.7151791475336150\t0.0721730390750208\n // Derived from:\n // xW\tyW\tK\txR\tyR\txG\tyG\txB\tyB\n // 0.312720\t0.329030\t6504\t0.640\t0.330\t0.300\t0.600\t0.150\t0.060\n\n // linearize r, g, or b then apply coefficients\n // and sum then return the resulting luminance\n\n function simpleExp(chan: number) {\n return Math.pow(chan / 255.0, SA98G.mainTRC);\n }\n\n return (\n SA98G.sRco * simpleExp(rgb[0]) +\n SA98G.sGco * simpleExp(rgb[1]) +\n SA98G.sBco * simpleExp(rgb[2])\n );\n}\n\nexport function APCAcontrast(txtY: number, bgY: number, places = -1) {\n // send linear Y (luminance) for text and background.\n // txtY and bgY must be between 0.0-1.0\n // IMPORTANT: Do not swap, polarity is important.\n\n const icp = [0.0, 1.1]; // input range clamp / input error check\n\n if (\n isNaN(txtY) ||\n isNaN(bgY) ||\n Math.min(txtY, bgY) < icp[0] ||\n Math.max(txtY, bgY) > icp[1]\n ) {\n return 0.0; // return zero on error\n // return 'error'; // optional string return for error\n }\n\n ////////// SAPC LOCAL VARS /////////////////////////////////////////\n\n let SAPC = 0.0; // For raw SAPC values\n let outputContrast = 0.0; // For weighted final values\n let polCat = 'BoW'; // Alternate Polarity Indicator. N normal R reverse\n\n // TUTORIAL\n\n // Use Y for text and BG, and soft clamp black,\n // return 0 for very close luminances, determine\n // polarity, and calculate SAPC raw contrast\n // Then scale for easy to remember levels.\n\n // Note that reverse contrast (white text on black)\n // intentionally returns a negative number\n // Proper polarity is important!\n\n ////////// BLACK SOFT CLAMP ////////////////////////////////////////\n\n // Soft clamps Y for either color if it is near black.\n txtY =\n txtY > SA98G.blkThrs\n ? txtY\n : txtY + Math.pow(SA98G.blkThrs - txtY, SA98G.blkClmp);\n bgY =\n bgY > SA98G.blkThrs\n ? bgY\n : bgY + Math.pow(SA98G.blkThrs - bgY, SA98G.blkClmp);\n\n ///// Return 0 Early for extremely low ∆Y\n if (Math.abs(bgY - txtY) < SA98G.deltaYmin) {\n return 0.0;\n }\n\n ////////// APCA/SAPC CONTRAST - LOW CLIP (W3 LICENSE) ///////////////\n\n if (bgY > txtY) {\n // For normal polarity, black text on white (BoW)\n\n // Calculate the SAPC contrast value and scale\n SAPC =\n (Math.pow(bgY, SA98G.normBG) - Math.pow(txtY, SA98G.normTXT)) *\n SA98G.scaleBoW;\n\n // Low Contrast smooth rollout to prevent polarity reversal\n // and also a low-clip for very low contrasts\n outputContrast = SAPC < SA98G.loClip ? 0.0 : SAPC - SA98G.loBoWoffset;\n } else {\n // For reverse polarity, light text on dark (WoB)\n // WoB should always return negative value.\n polCat = 'WoB';\n\n SAPC =\n (Math.pow(bgY, SA98G.revBG) - Math.pow(txtY, SA98G.revTXT)) *\n SA98G.scaleWoB;\n\n outputContrast = SAPC > -SA98G.loClip ? 0.0 : SAPC + SA98G.loWoBoffset;\n }\n\n // return Lc (lightness contrast) as a signed numeric value\n // Round to the nearest whole number as string is optional.\n // Rounded can be a signed INT as output will be within ± 127\n // places = -1 returns signed float, 1 or more set that many places\n // 0 returns rounded string, uses BoW or WoB instead of minus sign\n\n if (places < 0) {\n // Default (-1) number out, all others are strings\n return outputContrast * 100.0;\n // biome-ignore lint/suspicious/noDoubleEquals: <explanation>\n } else if (places == 0) {\n return (\n Math.round(Math.abs(outputContrast) * 100.0) + '<sub>' + polCat + '</sub>'\n );\n } else if (Number.isInteger(places)) {\n return (outputContrast * 100.0).toFixed(places);\n } else {\n return 0.0;\n }\n}\n\n// send rgba array for text/icon, rgb for background.\n// Only foreground allows alpha of 0.0 to 1.0\n// This blends using gamma encoded space (standard)\n// rounded 0-255 or set round=false for number 0.0-255.0\nexport function alphaBlend(\n rgbaFG = [0, 0, 0, 1.0],\n rgbBG = [0, 0, 0],\n round = true,\n) {\n rgbaFG[3] = Math.max(Math.min(rgbaFG[3], 1.0), 0.0); // clamp alpha 0-1\n let compBlend = 1.0 - rgbaFG[3];\n let rgbOut = [0, 0, 0, 1, true]; // or just use rgbBG to retain other elements?\n\n for (let i = 0; i < 3; i++) {\n rgbOut[i] = rgbBG[i] * compBlend + rgbaFG[i] * rgbaFG[3];\n if (round) rgbOut[i] = Math.min(Math.round(rgbOut[i] as number), 255);\n }\n return rgbOut;\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"apca.js","names":["SA98G","mainTRC","mainTRCencode","sRco","sGco","sBco","normBG","normTXT","revTXT","revBG","blkThrs","blkClmp","scaleBoW","scaleWoB","loBoWoffset","loWoBoffset","deltaYmin","loClip","mFactor","mFactInv","mOffsetIn","mExpAdj","mExp","mOffsetOut","sRGBtoY","rgb","arguments","length","undefined","simpleExp","chan","Math","pow","APCAcontrast","txtY","bgY","places","icp","isNaN","min","max","SAPC","outputContrast","polCat","abs","round","Number","isInteger","toFixed","alphaBlend","rgbaFG","rgbBG","compBlend","rgbOut","i"],"sources":["../../../src/util/color/apca.ts"],"sourcesContent":["///////////////////////////////////////////////////////////////////////////////\r\n/** @preserve\r\n ///// SAPC APCA - Advanced Perceptual Contrast Algorithm\r\n ///// Beta 0.1.9 W3 • contrast function only\r\n ///// DIST: W3 • Revision date: July 3, 2022\r\n ///// Function to parse color values and determine Lc contrast\r\n ///// Copyright © 2019-2022 by Andrew Somers. All Rights Reserved.\r\n ///// LICENSE: W3 LICENSE\r\n ///// CONTACT: Please use the ISSUES or DISCUSSIONS tab at:\r\n ///// https://github.com/Myndex/SAPC-APCA/\r\n /////\r\n ///////////////////////////////////////////////////////////////////////////////\r\n /////\r\n ///// MINIMAL IMPORTS:\r\n ///// import { APCAcontrast, sRGBtoY, displayP3toY,\r\n///// calcAPCA, fontLookupAPCA } from 'apca-w3';\r\n ///// import { colorParsley } from 'colorparsley';\r\n /////\r\n ///// FORWARD CONTRAST USAGE:\r\n ///// Lc = APCAcontrast( sRGBtoY( TEXTcolor ) , sRGBtoY( BACKGNDcolor ) );\r\n ///// Where the colors are sent as an rgba array [255,255,255,1]\r\n /////\r\n ///// Retrieving an array of font sizes for the contrast:\r\n ///// fontArray = fontLookupAPCA(Lc);\r\n /////\r\n ///// Live Demonstrator at https://www.myndex.com/APCA/\r\n // */\r\n///////////////////////////////////////////////////////////////////////////////\r\n\r\n///// Module Scope Object Containing Constants /////\r\n///// APCA 0.0.98G - 4g - W3 Compatible Constants\r\n\r\n///// 𝒦 SA98G ///////////////////////////////////\r\nconst SA98G = {\r\n mainTRC: 2.4, // 2.4 exponent for emulating actual monitor perception\r\n\r\n // For reverseAPCA\r\n get mainTRCencode() {\r\n return 1 / this.mainTRC;\r\n },\r\n\r\n // sRGB coefficients\r\n sRco: 0.2126729,\r\n sGco: 0.7151522,\r\n sBco: 0.072175,\r\n\r\n // G-4g constants for use with 2.4 exponent\r\n normBG: 0.56,\r\n normTXT: 0.57,\r\n revTXT: 0.62,\r\n revBG: 0.65,\r\n\r\n // G-4g Clamps and Scalers\r\n blkThrs: 0.022,\r\n blkClmp: 1.414,\r\n scaleBoW: 1.14,\r\n scaleWoB: 1.14,\r\n loBoWoffset: 0.027,\r\n loWoBoffset: 0.027,\r\n deltaYmin: 0.0005,\r\n loClip: 0.1,\r\n\r\n ///// MAGIC NUMBERS for UNCLAMP, for use with 0.022 & 1.414 /////\r\n // Magic Numbers for reverseAPCA\r\n mFactor: 1.9468554433171,\r\n get mFactInv() {\r\n return 1 / this.mFactor;\r\n },\r\n mOffsetIn: 0.0387393816571401,\r\n mExpAdj: 0.283343396420869,\r\n get mExp() {\r\n return this.mExpAdj / this.blkClmp;\r\n },\r\n mOffsetOut: 0.312865795870758,\r\n};\r\n\r\n//////////////////////////////////////////////////////////////////////////////\r\n////////// LUMINANCE CONVERTERS |//////////////////////////////////////////\r\n\r\n////////// ƒ sRGBtoY() //////////////////////////////////////////////////\r\nexport function sRGBtoY(rgb = [0, 0, 0]) {\r\n // send sRGB 8bpc (0xFFFFFF) or string\r\n\r\n // NOTE: Currently expects 0-255\r\n\r\n ///// APCA 0.0.98G - 4g - W3 Compatible Constants ////////////////////\r\n /*\r\n const mainTRC = 2.4; // 2.4 exponent emulates actual monitor perception\r\n\r\n const sRco = 0.2126729,\r\n sGco = 0.7151522,\r\n sBco = 0.0721750; // sRGB coefficients\r\n */\r\n // Future:\r\n // 0.2126478133913640\t0.7151791475336150\t0.0721730390750208\r\n // Derived from:\r\n // xW\tyW\tK\txR\tyR\txG\tyG\txB\tyB\r\n // 0.312720\t0.329030\t6504\t0.640\t0.330\t0.300\t0.600\t0.150\t0.060\r\n\r\n // linearize r, g, or b then apply coefficients\r\n // and sum then return the resulting luminance\r\n\r\n function simpleExp(chan: number) {\r\n return Math.pow(chan / 255.0, SA98G.mainTRC);\r\n }\r\n\r\n return (\r\n SA98G.sRco * simpleExp(rgb[0]) +\r\n SA98G.sGco * simpleExp(rgb[1]) +\r\n SA98G.sBco * simpleExp(rgb[2])\r\n );\r\n}\r\n\r\nexport function APCAcontrast(txtY: number, bgY: number, places = -1) {\r\n // send linear Y (luminance) for text and background.\r\n // txtY and bgY must be between 0.0-1.0\r\n // IMPORTANT: Do not swap, polarity is important.\r\n\r\n const icp = [0.0, 1.1]; // input range clamp / input error check\r\n\r\n if (\r\n isNaN(txtY) ||\r\n isNaN(bgY) ||\r\n Math.min(txtY, bgY) < icp[0] ||\r\n Math.max(txtY, bgY) > icp[1]\r\n ) {\r\n return 0.0; // return zero on error\r\n // return 'error'; // optional string return for error\r\n }\r\n\r\n ////////// SAPC LOCAL VARS /////////////////////////////////////////\r\n\r\n let SAPC = 0.0; // For raw SAPC values\r\n let outputContrast = 0.0; // For weighted final values\r\n let polCat = 'BoW'; // Alternate Polarity Indicator. N normal R reverse\r\n\r\n // TUTORIAL\r\n\r\n // Use Y for text and BG, and soft clamp black,\r\n // return 0 for very close luminances, determine\r\n // polarity, and calculate SAPC raw contrast\r\n // Then scale for easy to remember levels.\r\n\r\n // Note that reverse contrast (white text on black)\r\n // intentionally returns a negative number\r\n // Proper polarity is important!\r\n\r\n ////////// BLACK SOFT CLAMP ////////////////////////////////////////\r\n\r\n // Soft clamps Y for either color if it is near black.\r\n txtY =\r\n txtY > SA98G.blkThrs\r\n ? txtY\r\n : txtY + Math.pow(SA98G.blkThrs - txtY, SA98G.blkClmp);\r\n bgY =\r\n bgY > SA98G.blkThrs\r\n ? bgY\r\n : bgY + Math.pow(SA98G.blkThrs - bgY, SA98G.blkClmp);\r\n\r\n ///// Return 0 Early for extremely low ∆Y\r\n if (Math.abs(bgY - txtY) < SA98G.deltaYmin) {\r\n return 0.0;\r\n }\r\n\r\n ////////// APCA/SAPC CONTRAST - LOW CLIP (W3 LICENSE) ///////////////\r\n\r\n if (bgY > txtY) {\r\n // For normal polarity, black text on white (BoW)\r\n\r\n // Calculate the SAPC contrast value and scale\r\n SAPC =\r\n (Math.pow(bgY, SA98G.normBG) - Math.pow(txtY, SA98G.normTXT)) *\r\n SA98G.scaleBoW;\r\n\r\n // Low Contrast smooth rollout to prevent polarity reversal\r\n // and also a low-clip for very low contrasts\r\n outputContrast = SAPC < SA98G.loClip ? 0.0 : SAPC - SA98G.loBoWoffset;\r\n } else {\r\n // For reverse polarity, light text on dark (WoB)\r\n // WoB should always return negative value.\r\n polCat = 'WoB';\r\n\r\n SAPC =\r\n (Math.pow(bgY, SA98G.revBG) - Math.pow(txtY, SA98G.revTXT)) *\r\n SA98G.scaleWoB;\r\n\r\n outputContrast = SAPC > -SA98G.loClip ? 0.0 : SAPC + SA98G.loWoBoffset;\r\n }\r\n\r\n // return Lc (lightness contrast) as a signed numeric value\r\n // Round to the nearest whole number as string is optional.\r\n // Rounded can be a signed INT as output will be within ± 127\r\n // places = -1 returns signed float, 1 or more set that many places\r\n // 0 returns rounded string, uses BoW or WoB instead of minus sign\r\n\r\n if (places < 0) {\r\n // Default (-1) number out, all others are strings\r\n return outputContrast * 100.0;\r\n // biome-ignore lint/suspicious/noDoubleEquals: <explanation>\r\n } else if (places == 0) {\r\n return (\r\n Math.round(Math.abs(outputContrast) * 100.0) + '<sub>' + polCat + '</sub>'\r\n );\r\n } else if (Number.isInteger(places)) {\r\n return (outputContrast * 100.0).toFixed(places);\r\n } else {\r\n return 0.0;\r\n }\r\n}\r\n\r\n// send rgba array for text/icon, rgb for background.\r\n// Only foreground allows alpha of 0.0 to 1.0\r\n// This blends using gamma encoded space (standard)\r\n// rounded 0-255 or set round=false for number 0.0-255.0\r\nexport function alphaBlend(\r\n rgbaFG = [0, 0, 0, 1.0],\r\n rgbBG = [0, 0, 0],\r\n round = true,\r\n) {\r\n rgbaFG[3] = Math.max(Math.min(rgbaFG[3], 1.0), 0.0); // clamp alpha 0-1\r\n let compBlend = 1.0 - rgbaFG[3];\r\n let rgbOut = [0, 0, 0, 1, true]; // or just use rgbBG to retain other elements?\r\n\r\n for (let i = 0; i < 3; i++) {\r\n rgbOut[i] = rgbBG[i] * compBlend + rgbaFG[i] * rgbaFG[3];\r\n if (round) rgbOut[i] = Math.min(Math.round(rgbOut[i] as number), 255);\r\n }\r\n return rgbOut;\r\n}\r\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"const.js","names":["RGBA_REGEX","HEX_COLOR_REGEX","SRGB_TO_XYZ","XYZ_TO_SRGB","WHITE_POINT_D65"],"sources":["../../../src/util/color/const.ts"],"sourcesContent":["export const RGBA_REGEX = /rgb(a?)\\((?<v>.*)\\)/;\nexport const HEX_COLOR_REGEX =\n /^#([A-Fa-f0-9]{3}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{8})$/;\n\nexport const SRGB_TO_XYZ = [\n [0.41233895, 0.35762064, 0.18051042],\n [0.2126, 0.7152, 0.0722],\n [0.01932141, 0.11916382, 0.95034478],\n];\n\nexport const XYZ_TO_SRGB = [\n [3.2413774792388685, -1.5376652402851851, -0.49885366846268053],\n [-0.9691452513005321, 1.8758853451067872, 0.04156585616912061],\n [0.05562093689691305, -0.20395524564742123, 1.0571799111220335],\n];\n\nexport const WHITE_POINT_D65 = [95.047, 100.0, 108.883];\n"],"mappings":"AAAA,OAAO,MAAMA,UAAU,GAAG,qBAAqB;AAC/C,OAAO,MAAMC,eAAe,GAC1B,mDAAmD;AAErD,OAAO,MAAMC,WAAW,GAAG,CACzB,CAAC,UAAU,EAAE,UAAU,EAAE,UAAU,CAAC,EACpC,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,EACxB,CAAC,UAAU,EAAE,UAAU,EAAE,UAAU,CAAC,CACrC;AAED,OAAO,MAAMC,WAAW,GAAG,CACzB,CAAC,kBAAkB,EAAE,CAAC,kBAAkB,EAAE,CAAC,mBAAmB,CAAC,EAC/D,CAAC,CAAC,kBAAkB,EAAE,kBAAkB,EAAE,mBAAmB,CAAC,EAC9D,CAAC,mBAAmB,EAAE,CAAC,mBAAmB,EAAE,kBAAkB,CAAC,CAChE;AAED,OAAO,MAAMC,eAAe,GAAG,CAAC,MAAM,EAAE,KAAK,EAAE,OAAO,CAAC","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"const.js","names":["RGBA_REGEX","HEX_COLOR_REGEX","SRGB_TO_XYZ","XYZ_TO_SRGB","WHITE_POINT_D65"],"sources":["../../../src/util/color/const.ts"],"sourcesContent":["export const RGBA_REGEX = /rgb(a?)\\((?<v>.*)\\)/;\r\nexport const HEX_COLOR_REGEX =\r\n /^#([A-Fa-f0-9]{3}|[A-Fa-f0-9]{6}|[A-Fa-f0-9]{8})$/;\r\n\r\nexport const SRGB_TO_XYZ = [\r\n [0.41233895, 0.35762064, 0.18051042],\r\n [0.2126, 0.7152, 0.0722],\r\n [0.01932141, 0.11916382, 0.95034478],\r\n];\r\n\r\nexport const XYZ_TO_SRGB = [\r\n [3.2413774792388685, -1.5376652402851851, -0.49885366846268053],\r\n [-0.9691452513005321, 1.8758853451067872, 0.04156585616912061],\r\n [0.05562093689691305, -0.20395524564742123, 1.0571799111220335],\r\n];\r\n\r\nexport const WHITE_POINT_D65 = [95.047, 100.0, 108.883];\r\n"],"mappings":"AAAA,OAAO,MAAMA,UAAU,GAAG,qBAAqB;AAC/C,OAAO,MAAMC,eAAe,GAC1B,mDAAmD;AAErD,OAAO,MAAMC,WAAW,GAAG,CACzB,CAAC,UAAU,EAAE,UAAU,EAAE,UAAU,CAAC,EACpC,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,EACxB,CAAC,UAAU,EAAE,UAAU,EAAE,UAAU,CAAC,CACrC;AAED,OAAO,MAAMC,WAAW,GAAG,CACzB,CAAC,kBAAkB,EAAE,CAAC,kBAAkB,EAAE,CAAC,mBAAmB,CAAC,EAC/D,CAAC,CAAC,kBAAkB,EAAE,kBAAkB,EAAE,mBAAmB,CAAC,EAC9D,CAAC,mBAAmB,EAAE,CAAC,mBAAmB,EAAE,kBAAkB,CAAC,CAChE;AAED,OAAO,MAAMC,eAAe,GAAG,CAAC,MAAM,EAAE,KAAK,EAAE,OAAO,CAAC","ignoreList":[]}
|
|
@@ -1,59 +1,59 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright 2021 Google LLC
|
|
4
|
-
*
|
|
5
|
-
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
|
-
* you may not use this file except in compliance with the License.
|
|
7
|
-
* You may obtain a copy of the License at
|
|
8
|
-
*
|
|
9
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
10
|
-
*
|
|
11
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
12
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
13
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
14
|
-
* See the License for the specific language governing permissions and
|
|
15
|
-
* limitations under the License.
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2021 Google LLC
|
|
4
|
+
*
|
|
5
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
|
+
* you may not use this file except in compliance with the License.
|
|
7
|
+
* You may obtain a copy of the License at
|
|
8
|
+
*
|
|
9
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
10
|
+
*
|
|
11
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
12
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
13
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
14
|
+
* See the License for the specific language governing permissions and
|
|
15
|
+
* limitations under the License.
|
|
16
16
|
*/
|
|
17
17
|
import { ViewingConditions } from "./viewing-conditions.js";
|
|
18
18
|
import { argbFromXyz, linearized } from "../conversion.js";
|
|
19
19
|
import * as math from "../utils/math-utils.js";
|
|
20
|
-
/**
|
|
21
|
-
* CAM16, a color appearance model. Colors are not just defined by their hex
|
|
22
|
-
* code, but rather, a hex code and viewing conditions.
|
|
23
|
-
*
|
|
24
|
-
* CAM16 instances also have coordinates in the CAM16-UCS space, called J*, a*,
|
|
25
|
-
* b*, or jstar, astar, bstar in code. CAM16-UCS is included in the CAM16
|
|
26
|
-
* specification, and should be used when measuring distances between colors.
|
|
27
|
-
*
|
|
28
|
-
* In traditional color spaces, a color can be identified solely by the
|
|
29
|
-
* observer's measurement of the color. Color appearance models such as CAM16
|
|
30
|
-
* also use information about the environment where the color was
|
|
31
|
-
* observed, known as the viewing conditions.
|
|
32
|
-
*
|
|
33
|
-
* For example, white under the traditional assumption of a midday sun white
|
|
34
|
-
* point is accurately measured as a slightly chromatic blue by CAM16. (roughly,
|
|
35
|
-
* hue 203, chroma 3, lightness 100)
|
|
20
|
+
/**
|
|
21
|
+
* CAM16, a color appearance model. Colors are not just defined by their hex
|
|
22
|
+
* code, but rather, a hex code and viewing conditions.
|
|
23
|
+
*
|
|
24
|
+
* CAM16 instances also have coordinates in the CAM16-UCS space, called J*, a*,
|
|
25
|
+
* b*, or jstar, astar, bstar in code. CAM16-UCS is included in the CAM16
|
|
26
|
+
* specification, and should be used when measuring distances between colors.
|
|
27
|
+
*
|
|
28
|
+
* In traditional color spaces, a color can be identified solely by the
|
|
29
|
+
* observer's measurement of the color. Color appearance models such as CAM16
|
|
30
|
+
* also use information about the environment where the color was
|
|
31
|
+
* observed, known as the viewing conditions.
|
|
32
|
+
*
|
|
33
|
+
* For example, white under the traditional assumption of a midday sun white
|
|
34
|
+
* point is accurately measured as a slightly chromatic blue by CAM16. (roughly,
|
|
35
|
+
* hue 203, chroma 3, lightness 100)
|
|
36
36
|
*/
|
|
37
37
|
export class Cam16 {
|
|
38
|
-
/**
|
|
39
|
-
* All of the CAM16 dimensions can be calculated from 3 of the dimensions, in
|
|
40
|
-
* the following combinations:
|
|
41
|
-
* - {j or q} and {c, m, or s} and hue
|
|
42
|
-
* - jstar, astar, bstar
|
|
43
|
-
* Prefer using a static method that constructs from 3 of those dimensions.
|
|
44
|
-
* This constructor is intended for those methods to use to return all
|
|
45
|
-
* possible dimensions.
|
|
46
|
-
*
|
|
47
|
-
* @param hue
|
|
48
|
-
* @param chroma informally, colorfulness / color intensity. like saturation
|
|
49
|
-
* in HSL, except perceptually accurate.
|
|
50
|
-
* @param j lightness
|
|
51
|
-
* @param q brightness; ratio of lightness to white point's lightness
|
|
52
|
-
* @param m colorfulness
|
|
53
|
-
* @param s saturation; ratio of chroma to white point's chroma
|
|
54
|
-
* @param jstar CAM16-UCS J coordinate
|
|
55
|
-
* @param astar CAM16-UCS a coordinate
|
|
56
|
-
* @param bstar CAM16-UCS b coordinate
|
|
38
|
+
/**
|
|
39
|
+
* All of the CAM16 dimensions can be calculated from 3 of the dimensions, in
|
|
40
|
+
* the following combinations:
|
|
41
|
+
* - {j or q} and {c, m, or s} and hue
|
|
42
|
+
* - jstar, astar, bstar
|
|
43
|
+
* Prefer using a static method that constructs from 3 of those dimensions.
|
|
44
|
+
* This constructor is intended for those methods to use to return all
|
|
45
|
+
* possible dimensions.
|
|
46
|
+
*
|
|
47
|
+
* @param hue
|
|
48
|
+
* @param chroma informally, colorfulness / color intensity. like saturation
|
|
49
|
+
* in HSL, except perceptually accurate.
|
|
50
|
+
* @param j lightness
|
|
51
|
+
* @param q brightness; ratio of lightness to white point's lightness
|
|
52
|
+
* @param m colorfulness
|
|
53
|
+
* @param s saturation; ratio of chroma to white point's chroma
|
|
54
|
+
* @param jstar CAM16-UCS J coordinate
|
|
55
|
+
* @param astar CAM16-UCS a coordinate
|
|
56
|
+
* @param bstar CAM16-UCS b coordinate
|
|
57
57
|
*/
|
|
58
58
|
constructor(hue, chroma, j, q, m, s, jstar, astar, bstar) {
|
|
59
59
|
this.hue = hue;
|
|
@@ -67,10 +67,10 @@ export class Cam16 {
|
|
|
67
67
|
this.bstar = bstar;
|
|
68
68
|
}
|
|
69
69
|
|
|
70
|
-
/**
|
|
71
|
-
* CAM16 instances also have coordinates in the CAM16-UCS space, called J*,
|
|
72
|
-
* a*, b*, or jstar, astar, bstar in code. CAM16-UCS is included in the CAM16
|
|
73
|
-
* specification, and is used to measure distances between colors.
|
|
70
|
+
/**
|
|
71
|
+
* CAM16 instances also have coordinates in the CAM16-UCS space, called J*,
|
|
72
|
+
* a*, b*, or jstar, astar, bstar in code. CAM16-UCS is included in the CAM16
|
|
73
|
+
* specification, and is used to measure distances between colors.
|
|
74
74
|
*/
|
|
75
75
|
distance(other) {
|
|
76
76
|
const dJ = this.jstar - other.jstar;
|
|
@@ -81,20 +81,20 @@ export class Cam16 {
|
|
|
81
81
|
return dE;
|
|
82
82
|
}
|
|
83
83
|
|
|
84
|
-
/**
|
|
85
|
-
* @param argb ARGB representation of a color.
|
|
86
|
-
* @return CAM16 color, assuming the color was viewed in default viewing
|
|
87
|
-
* conditions.
|
|
84
|
+
/**
|
|
85
|
+
* @param argb ARGB representation of a color.
|
|
86
|
+
* @return CAM16 color, assuming the color was viewed in default viewing
|
|
87
|
+
* conditions.
|
|
88
88
|
*/
|
|
89
89
|
static fromInt(argb) {
|
|
90
90
|
return Cam16.fromIntInViewingConditions(argb, ViewingConditions.DEFAULT);
|
|
91
91
|
}
|
|
92
92
|
|
|
93
|
-
/**
|
|
94
|
-
* @param argb ARGB representation of a color.
|
|
95
|
-
* @param viewingConditions Information about the environment where the color
|
|
96
|
-
* was observed.
|
|
97
|
-
* @return CAM16 color.
|
|
93
|
+
/**
|
|
94
|
+
* @param argb ARGB representation of a color.
|
|
95
|
+
* @param viewingConditions Information about the environment where the color
|
|
96
|
+
* was observed.
|
|
97
|
+
* @return CAM16 color.
|
|
98
98
|
*/
|
|
99
99
|
static fromIntInViewingConditions(argb, viewingConditions) {
|
|
100
100
|
const red = (argb & 0x00ff0000) >> 16;
|
|
@@ -144,21 +144,21 @@ export class Cam16 {
|
|
|
144
144
|
return new Cam16(hue, c, j, q, m, s, jstar, astar, bstar);
|
|
145
145
|
}
|
|
146
146
|
|
|
147
|
-
/**
|
|
148
|
-
* @param j CAM16 lightness
|
|
149
|
-
* @param c CAM16 chroma
|
|
150
|
-
* @param h CAM16 hue
|
|
147
|
+
/**
|
|
148
|
+
* @param j CAM16 lightness
|
|
149
|
+
* @param c CAM16 chroma
|
|
150
|
+
* @param h CAM16 hue
|
|
151
151
|
*/
|
|
152
152
|
static fromJch(j, c, h) {
|
|
153
153
|
return Cam16.fromJchInViewingConditions(j, c, h, ViewingConditions.DEFAULT);
|
|
154
154
|
}
|
|
155
155
|
|
|
156
|
-
/**
|
|
157
|
-
* @param j CAM16 lightness
|
|
158
|
-
* @param c CAM16 chroma
|
|
159
|
-
* @param h CAM16 hue
|
|
160
|
-
* @param viewingConditions Information about the environment where the color
|
|
161
|
-
* was observed.
|
|
156
|
+
/**
|
|
157
|
+
* @param j CAM16 lightness
|
|
158
|
+
* @param c CAM16 chroma
|
|
159
|
+
* @param h CAM16 hue
|
|
160
|
+
* @param viewingConditions Information about the environment where the color
|
|
161
|
+
* was observed.
|
|
162
162
|
*/
|
|
163
163
|
static fromJchInViewingConditions(j, c, h, viewingConditions) {
|
|
164
164
|
const q = 4.0 / viewingConditions.c * Math.sqrt(j / 100.0) * (viewingConditions.aw + 4.0) * viewingConditions.fLRoot;
|
|
@@ -173,25 +173,25 @@ export class Cam16 {
|
|
|
173
173
|
return new Cam16(h, c, j, q, m, s, jstar, astar, bstar);
|
|
174
174
|
}
|
|
175
175
|
|
|
176
|
-
/**
|
|
177
|
-
* @param jstar CAM16-UCS lightness.
|
|
178
|
-
* @param astar CAM16-UCS a dimension. Like a* in L*a*b*, it is a Cartesian
|
|
179
|
-
* coordinate on the Y axis.
|
|
180
|
-
* @param bstar CAM16-UCS b dimension. Like a* in L*a*b*, it is a Cartesian
|
|
181
|
-
* coordinate on the X axis.
|
|
176
|
+
/**
|
|
177
|
+
* @param jstar CAM16-UCS lightness.
|
|
178
|
+
* @param astar CAM16-UCS a dimension. Like a* in L*a*b*, it is a Cartesian
|
|
179
|
+
* coordinate on the Y axis.
|
|
180
|
+
* @param bstar CAM16-UCS b dimension. Like a* in L*a*b*, it is a Cartesian
|
|
181
|
+
* coordinate on the X axis.
|
|
182
182
|
*/
|
|
183
183
|
static fromUcs(jstar, astar, bstar) {
|
|
184
184
|
return Cam16.fromUcsInViewingConditions(jstar, astar, bstar, ViewingConditions.DEFAULT);
|
|
185
185
|
}
|
|
186
186
|
|
|
187
|
-
/**
|
|
188
|
-
* @param jstar CAM16-UCS lightness.
|
|
189
|
-
* @param astar CAM16-UCS a dimension. Like a* in L*a*b*, it is a Cartesian
|
|
190
|
-
* coordinate on the Y axis.
|
|
191
|
-
* @param bstar CAM16-UCS b dimension. Like a* in L*a*b*, it is a Cartesian
|
|
192
|
-
* coordinate on the X axis.
|
|
193
|
-
* @param viewingConditions Information about the environment where the color
|
|
194
|
-
* was observed.
|
|
187
|
+
/**
|
|
188
|
+
* @param jstar CAM16-UCS lightness.
|
|
189
|
+
* @param astar CAM16-UCS a dimension. Like a* in L*a*b*, it is a Cartesian
|
|
190
|
+
* coordinate on the Y axis.
|
|
191
|
+
* @param bstar CAM16-UCS b dimension. Like a* in L*a*b*, it is a Cartesian
|
|
192
|
+
* coordinate on the X axis.
|
|
193
|
+
* @param viewingConditions Information about the environment where the color
|
|
194
|
+
* was observed.
|
|
195
195
|
*/
|
|
196
196
|
static fromUcsInViewingConditions(jstar, astar, bstar, viewingConditions) {
|
|
197
197
|
const a = astar;
|
|
@@ -207,19 +207,19 @@ export class Cam16 {
|
|
|
207
207
|
return Cam16.fromJchInViewingConditions(j, c, h, viewingConditions);
|
|
208
208
|
}
|
|
209
209
|
|
|
210
|
-
/**
|
|
211
|
-
* @return ARGB representation of color, assuming the color was viewed in
|
|
212
|
-
* default viewing conditions, which are near-identical to the default
|
|
213
|
-
* viewing conditions for sRGB.
|
|
210
|
+
/**
|
|
211
|
+
* @return ARGB representation of color, assuming the color was viewed in
|
|
212
|
+
* default viewing conditions, which are near-identical to the default
|
|
213
|
+
* viewing conditions for sRGB.
|
|
214
214
|
*/
|
|
215
215
|
toInt() {
|
|
216
216
|
return this.viewed(ViewingConditions.DEFAULT);
|
|
217
217
|
}
|
|
218
218
|
|
|
219
|
-
/**
|
|
220
|
-
* @param viewingConditions Information about the environment where the color
|
|
221
|
-
* will be viewed.
|
|
222
|
-
* @return ARGB representation of color
|
|
219
|
+
/**
|
|
220
|
+
* @param viewingConditions Information about the environment where the color
|
|
221
|
+
* will be viewed.
|
|
222
|
+
* @return ARGB representation of color
|
|
223
223
|
*/
|
|
224
224
|
viewed(viewingConditions) {
|
|
225
225
|
const alpha = this.chroma === 0.0 || this.j === 0.0 ? 0.0 : this.chroma / Math.sqrt(this.j / 100.0);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cam16.js","names":["ViewingConditions","argbFromXyz","linearized","math","Cam16","constructor","hue","chroma","j","q","m","s","jstar","astar","bstar","distance","other","dJ","dA","dB","dEPrime","Math","sqrt","dE","pow","fromInt","argb","fromIntInViewingConditions","DEFAULT","viewingConditions","red","green","blue","redL","greenL","blueL","x","y","z","rC","gC","bC","rD","rgbD","gD","bD","rAF","fl","abs","gAF","bAF","rA","signum","gA","bA","a","b","u","p2","atan2","atanDegrees","PI","hueRadians","ac","nbb","aw","c","fLRoot","huePrime","eHue","cos","p1","nc","ncb","t","alpha","n","mstar","log","sin","fromJch","h","fromJchInViewingConditions","fromUcs","fromUcsInViewingConditions","M","exp","toInt","viewed","hRad","hSin","hCos","gamma","rCBase","max","gCBase","bCBase","rF","gF","bF","fromXyzInViewingConditions","J","Q","C","xyzInViewingConditions"],"sources":["../../../../src/util/color/hct/cam16.ts"],"sourcesContent":["/**\n * @license\n * Copyright 2021 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { ViewingConditions } from './viewing-conditions';\n\nimport { argbFromXyz, linearized } from '../conversion';\nimport * as math from '../utils/math-utils';\n\n/**\n * CAM16, a color appearance model. Colors are not just defined by their hex\n * code, but rather, a hex code and viewing conditions.\n *\n * CAM16 instances also have coordinates in the CAM16-UCS space, called J*, a*,\n * b*, or jstar, astar, bstar in code. CAM16-UCS is included in the CAM16\n * specification, and should be used when measuring distances between colors.\n *\n * In traditional color spaces, a color can be identified solely by the\n * observer's measurement of the color. Color appearance models such as CAM16\n * also use information about the environment where the color was\n * observed, known as the viewing conditions.\n *\n * For example, white under the traditional assumption of a midday sun white\n * point is accurately measured as a slightly chromatic blue by CAM16. (roughly,\n * hue 203, chroma 3, lightness 100)\n */\nexport class Cam16 {\n /**\n * All of the CAM16 dimensions can be calculated from 3 of the dimensions, in\n * the following combinations:\n * - {j or q} and {c, m, or s} and hue\n * - jstar, astar, bstar\n * Prefer using a static method that constructs from 3 of those dimensions.\n * This constructor is intended for those methods to use to return all\n * possible dimensions.\n *\n * @param hue\n * @param chroma informally, colorfulness / color intensity. like saturation\n * in HSL, except perceptually accurate.\n * @param j lightness\n * @param q brightness; ratio of lightness to white point's lightness\n * @param m colorfulness\n * @param s saturation; ratio of chroma to white point's chroma\n * @param jstar CAM16-UCS J coordinate\n * @param astar CAM16-UCS a coordinate\n * @param bstar CAM16-UCS b coordinate\n */\n constructor(\n readonly hue: number,\n readonly chroma: number,\n readonly j: number,\n readonly q: number,\n readonly m: number,\n readonly s: number,\n readonly jstar: number,\n readonly astar: number,\n readonly bstar: number,\n ) {}\n\n /**\n * CAM16 instances also have coordinates in the CAM16-UCS space, called J*,\n * a*, b*, or jstar, astar, bstar in code. CAM16-UCS is included in the CAM16\n * specification, and is used to measure distances between colors.\n */\n distance(other: Cam16): number {\n const dJ = this.jstar - other.jstar;\n const dA = this.astar - other.astar;\n const dB = this.bstar - other.bstar;\n const dEPrime = Math.sqrt(dJ * dJ + dA * dA + dB * dB);\n const dE = 1.41 * Math.pow(dEPrime, 0.63);\n return dE;\n }\n\n /**\n * @param argb ARGB representation of a color.\n * @return CAM16 color, assuming the color was viewed in default viewing\n * conditions.\n */\n static fromInt(argb: number): Cam16 {\n return Cam16.fromIntInViewingConditions(argb, ViewingConditions.DEFAULT);\n }\n\n /**\n * @param argb ARGB representation of a color.\n * @param viewingConditions Information about the environment where the color\n * was observed.\n * @return CAM16 color.\n */\n static fromIntInViewingConditions(\n argb: number,\n viewingConditions: ViewingConditions,\n ): Cam16 {\n const red = (argb & 0x00ff0000) >> 16;\n const green = (argb & 0x0000ff00) >> 8;\n const blue = argb & 0x000000ff;\n const redL = linearized(red);\n const greenL = linearized(green);\n const blueL = linearized(blue);\n const x = 0.41233895 * redL + 0.35762064 * greenL + 0.18051042 * blueL;\n const y = 0.2126 * redL + 0.7152 * greenL + 0.0722 * blueL;\n const z = 0.01932141 * redL + 0.11916382 * greenL + 0.95034478 * blueL;\n\n const rC = 0.401288 * x + 0.650173 * y - 0.051461 * z;\n const gC = -0.250268 * x + 1.204414 * y + 0.045854 * z;\n const bC = -0.002079 * x + 0.048952 * y + 0.953127 * z;\n\n const rD = viewingConditions.rgbD[0] * rC;\n const gD = viewingConditions.rgbD[1] * gC;\n const bD = viewingConditions.rgbD[2] * bC;\n\n const rAF = Math.pow((viewingConditions.fl * Math.abs(rD)) / 100.0, 0.42);\n const gAF = Math.pow((viewingConditions.fl * Math.abs(gD)) / 100.0, 0.42);\n const bAF = Math.pow((viewingConditions.fl * Math.abs(bD)) / 100.0, 0.42);\n\n const rA = (math.signum(rD) * 400.0 * rAF) / (rAF + 27.13);\n const gA = (math.signum(gD) * 400.0 * gAF) / (gAF + 27.13);\n const bA = (math.signum(bD) * 400.0 * bAF) / (bAF + 27.13);\n\n const a = (11.0 * rA + -12.0 * gA + bA) / 11.0;\n const b = (rA + gA - 2.0 * bA) / 9.0;\n const u = (20.0 * rA + 20.0 * gA + 21.0 * bA) / 20.0;\n const p2 = (40.0 * rA + 20.0 * gA + bA) / 20.0;\n const atan2 = Math.atan2(b, a);\n const atanDegrees = (atan2 * 180.0) / Math.PI;\n const hue =\n atanDegrees < 0\n ? atanDegrees + 360.0\n : atanDegrees >= 360\n ? atanDegrees - 360.0\n : atanDegrees;\n const hueRadians = (hue * Math.PI) / 180.0;\n\n const ac = p2 * viewingConditions.nbb;\n const j =\n 100.0 *\n Math.pow(\n ac / viewingConditions.aw,\n viewingConditions.c * viewingConditions.z,\n );\n const q =\n (4.0 / viewingConditions.c) *\n Math.sqrt(j / 100.0) *\n (viewingConditions.aw + 4.0) *\n viewingConditions.fLRoot;\n const huePrime = hue < 20.14 ? hue + 360 : hue;\n const eHue = 0.25 * (Math.cos((huePrime * Math.PI) / 180.0 + 2.0) + 3.8);\n const p1 =\n (50000.0 / 13.0) * eHue * viewingConditions.nc * viewingConditions.ncb;\n const t = (p1 * Math.sqrt(a * a + b * b)) / (u + 0.305);\n const alpha =\n Math.pow(t, 0.9) *\n Math.pow(1.64 - Math.pow(0.29, viewingConditions.n), 0.73);\n const c = alpha * Math.sqrt(j / 100.0);\n const m = c * viewingConditions.fLRoot;\n const s =\n 50.0 *\n Math.sqrt((alpha * viewingConditions.c) / (viewingConditions.aw + 4.0));\n const jstar = ((1.0 + 100.0 * 0.007) * j) / (1.0 + 0.007 * j);\n const mstar = (1.0 / 0.0228) * Math.log(1.0 + 0.0228 * m);\n const astar = mstar * Math.cos(hueRadians);\n const bstar = mstar * Math.sin(hueRadians);\n\n return new Cam16(hue, c, j, q, m, s, jstar, astar, bstar);\n }\n\n /**\n * @param j CAM16 lightness\n * @param c CAM16 chroma\n * @param h CAM16 hue\n */\n static fromJch(j: number, c: number, h: number): Cam16 {\n return Cam16.fromJchInViewingConditions(j, c, h, ViewingConditions.DEFAULT);\n }\n\n /**\n * @param j CAM16 lightness\n * @param c CAM16 chroma\n * @param h CAM16 hue\n * @param viewingConditions Information about the environment where the color\n * was observed.\n */\n static fromJchInViewingConditions(\n j: number,\n c: number,\n h: number,\n viewingConditions: ViewingConditions,\n ): Cam16 {\n const q =\n (4.0 / viewingConditions.c) *\n Math.sqrt(j / 100.0) *\n (viewingConditions.aw + 4.0) *\n viewingConditions.fLRoot;\n const m = c * viewingConditions.fLRoot;\n const alpha = c / Math.sqrt(j / 100.0);\n const s =\n 50.0 *\n Math.sqrt((alpha * viewingConditions.c) / (viewingConditions.aw + 4.0));\n const hueRadians = (h * Math.PI) / 180.0;\n const jstar = ((1.0 + 100.0 * 0.007) * j) / (1.0 + 0.007 * j);\n const mstar = (1.0 / 0.0228) * Math.log(1.0 + 0.0228 * m);\n const astar = mstar * Math.cos(hueRadians);\n const bstar = mstar * Math.sin(hueRadians);\n return new Cam16(h, c, j, q, m, s, jstar, astar, bstar);\n }\n\n /**\n * @param jstar CAM16-UCS lightness.\n * @param astar CAM16-UCS a dimension. Like a* in L*a*b*, it is a Cartesian\n * coordinate on the Y axis.\n * @param bstar CAM16-UCS b dimension. Like a* in L*a*b*, it is a Cartesian\n * coordinate on the X axis.\n */\n static fromUcs(jstar: number, astar: number, bstar: number): Cam16 {\n return Cam16.fromUcsInViewingConditions(\n jstar,\n astar,\n bstar,\n ViewingConditions.DEFAULT,\n );\n }\n\n /**\n * @param jstar CAM16-UCS lightness.\n * @param astar CAM16-UCS a dimension. Like a* in L*a*b*, it is a Cartesian\n * coordinate on the Y axis.\n * @param bstar CAM16-UCS b dimension. Like a* in L*a*b*, it is a Cartesian\n * coordinate on the X axis.\n * @param viewingConditions Information about the environment where the color\n * was observed.\n */\n static fromUcsInViewingConditions(\n jstar: number,\n astar: number,\n bstar: number,\n viewingConditions: ViewingConditions,\n ): Cam16 {\n const a = astar;\n const b = bstar;\n const m = Math.sqrt(a * a + b * b);\n const M = (Math.exp(m * 0.0228) - 1.0) / 0.0228;\n const c = M / viewingConditions.fLRoot;\n let h = Math.atan2(b, a) * (180.0 / Math.PI);\n if (h < 0.0) {\n h += 360.0;\n }\n const j = jstar / (1 - (jstar - 100) * 0.007);\n return Cam16.fromJchInViewingConditions(j, c, h, viewingConditions);\n }\n\n /**\n * @return ARGB representation of color, assuming the color was viewed in\n * default viewing conditions, which are near-identical to the default\n * viewing conditions for sRGB.\n */\n toInt(): number {\n return this.viewed(ViewingConditions.DEFAULT);\n }\n\n /**\n * @param viewingConditions Information about the environment where the color\n * will be viewed.\n * @return ARGB representation of color\n */\n viewed(viewingConditions: ViewingConditions): number {\n const alpha =\n this.chroma === 0.0 || this.j === 0.0\n ? 0.0\n : this.chroma / Math.sqrt(this.j / 100.0);\n\n const t = Math.pow(\n alpha / Math.pow(1.64 - Math.pow(0.29, viewingConditions.n), 0.73),\n 1.0 / 0.9,\n );\n const hRad = (this.hue * Math.PI) / 180.0;\n\n const eHue = 0.25 * (Math.cos(hRad + 2.0) + 3.8);\n const ac =\n viewingConditions.aw *\n Math.pow(this.j / 100.0, 1.0 / viewingConditions.c / viewingConditions.z);\n const p1 =\n eHue * (50000.0 / 13.0) * viewingConditions.nc * viewingConditions.ncb;\n const p2 = ac / viewingConditions.nbb;\n\n const hSin = Math.sin(hRad);\n const hCos = Math.cos(hRad);\n\n const gamma =\n (23.0 * (p2 + 0.305) * t) /\n (23.0 * p1 + 11.0 * t * hCos + 108.0 * t * hSin);\n const a = gamma * hCos;\n const b = gamma * hSin;\n const rA = (460.0 * p2 + 451.0 * a + 288.0 * b) / 1403.0;\n const gA = (460.0 * p2 - 891.0 * a - 261.0 * b) / 1403.0;\n const bA = (460.0 * p2 - 220.0 * a - 6300.0 * b) / 1403.0;\n\n const rCBase = Math.max(0, (27.13 * Math.abs(rA)) / (400.0 - Math.abs(rA)));\n const rC =\n math.signum(rA) *\n (100.0 / viewingConditions.fl) *\n Math.pow(rCBase, 1.0 / 0.42);\n const gCBase = Math.max(0, (27.13 * Math.abs(gA)) / (400.0 - Math.abs(gA)));\n const gC =\n math.signum(gA) *\n (100.0 / viewingConditions.fl) *\n Math.pow(gCBase, 1.0 / 0.42);\n const bCBase = Math.max(0, (27.13 * Math.abs(bA)) / (400.0 - Math.abs(bA)));\n const bC =\n math.signum(bA) *\n (100.0 / viewingConditions.fl) *\n Math.pow(bCBase, 1.0 / 0.42);\n const rF = rC / viewingConditions.rgbD[0];\n const gF = gC / viewingConditions.rgbD[1];\n const bF = bC / viewingConditions.rgbD[2];\n\n const x = 1.86206786 * rF - 1.01125463 * gF + 0.14918677 * bF;\n const y = 0.38752654 * rF + 0.62144744 * gF - 0.00897398 * bF;\n const z = -0.0158415 * rF - 0.03412294 * gF + 1.04996444 * bF;\n\n const argb = argbFromXyz(x, y, z);\n return argb;\n }\n\n /// Given color expressed in XYZ and viewed in [viewingConditions], convert to\n /// CAM16.\n static fromXyzInViewingConditions(\n x: number,\n y: number,\n z: number,\n viewingConditions: ViewingConditions,\n ): Cam16 {\n // Transform XYZ to 'cone'/'rgb' responses\n\n const rC = 0.401288 * x + 0.650173 * y - 0.051461 * z;\n const gC = -0.250268 * x + 1.204414 * y + 0.045854 * z;\n const bC = -0.002079 * x + 0.048952 * y + 0.953127 * z;\n\n // Discount illuminant\n const rD = viewingConditions.rgbD[0] * rC;\n const gD = viewingConditions.rgbD[1] * gC;\n const bD = viewingConditions.rgbD[2] * bC;\n\n // chromatic adaptation\n const rAF = Math.pow((viewingConditions.fl * Math.abs(rD)) / 100.0, 0.42);\n const gAF = Math.pow((viewingConditions.fl * Math.abs(gD)) / 100.0, 0.42);\n const bAF = Math.pow((viewingConditions.fl * Math.abs(bD)) / 100.0, 0.42);\n const rA = (math.signum(rD) * 400.0 * rAF) / (rAF + 27.13);\n const gA = (math.signum(gD) * 400.0 * gAF) / (gAF + 27.13);\n const bA = (math.signum(bD) * 400.0 * bAF) / (bAF + 27.13);\n\n // redness-greenness\n const a = (11.0 * rA + -12.0 * gA + bA) / 11.0;\n // yellowness-blueness\n const b = (rA + gA - 2.0 * bA) / 9.0;\n\n // auxiliary components\n const u = (20.0 * rA + 20.0 * gA + 21.0 * bA) / 20.0;\n const p2 = (40.0 * rA + 20.0 * gA + bA) / 20.0;\n\n // hue\n const atan2 = Math.atan2(b, a);\n const atanDegrees = (atan2 * 180.0) / Math.PI;\n const hue =\n atanDegrees < 0\n ? atanDegrees + 360.0\n : atanDegrees >= 360\n ? atanDegrees - 360\n : atanDegrees;\n const hueRadians = (hue * Math.PI) / 180.0;\n\n // achromatic response to color\n const ac = p2 * viewingConditions.nbb;\n\n // CAM16 lightness and brightness\n const J =\n 100.0 *\n Math.pow(\n ac / viewingConditions.aw,\n viewingConditions.c * viewingConditions.z,\n );\n const Q =\n (4.0 / viewingConditions.c) *\n Math.sqrt(J / 100.0) *\n (viewingConditions.aw + 4.0) *\n viewingConditions.fLRoot;\n\n const huePrime = hue < 20.14 ? hue + 360 : hue;\n const eHue =\n (1.0 / 4.0) * (Math.cos((huePrime * Math.PI) / 180.0 + 2.0) + 3.8);\n const p1 =\n (50000.0 / 13.0) * eHue * viewingConditions.nc * viewingConditions.ncb;\n const t = (p1 * Math.sqrt(a * a + b * b)) / (u + 0.305);\n const alpha =\n Math.pow(t, 0.9) *\n Math.pow(1.64 - Math.pow(0.29, viewingConditions.n), 0.73);\n // CAM16 chroma, colorfulness, chroma\n const C = alpha * Math.sqrt(J / 100.0);\n const M = C * viewingConditions.fLRoot;\n const s =\n 50.0 *\n Math.sqrt((alpha * viewingConditions.c) / (viewingConditions.aw + 4.0));\n\n // CAM16-UCS components\n const jstar = ((1.0 + 100.0 * 0.007) * J) / (1.0 + 0.007 * J);\n const mstar = Math.log(1.0 + 0.0228 * M) / 0.0228;\n const astar = mstar * Math.cos(hueRadians);\n const bstar = mstar * Math.sin(hueRadians);\n return new Cam16(hue, C, J, Q, M, s, jstar, astar, bstar);\n }\n\n /// XYZ representation of CAM16 seen in [viewingConditions].\n xyzInViewingConditions(viewingConditions: ViewingConditions): number[] {\n const alpha =\n this.chroma === 0.0 || this.j === 0.0\n ? 0.0\n : this.chroma / Math.sqrt(this.j / 100.0);\n\n const t = Math.pow(\n alpha / Math.pow(1.64 - Math.pow(0.29, viewingConditions.n), 0.73),\n 1.0 / 0.9,\n );\n const hRad = (this.hue * Math.PI) / 180.0;\n\n const eHue = 0.25 * (Math.cos(hRad + 2.0) + 3.8);\n const ac =\n viewingConditions.aw *\n Math.pow(this.j / 100.0, 1.0 / viewingConditions.c / viewingConditions.z);\n const p1 =\n eHue * (50000.0 / 13.0) * viewingConditions.nc * viewingConditions.ncb;\n\n const p2 = ac / viewingConditions.nbb;\n\n const hSin = Math.sin(hRad);\n const hCos = Math.cos(hRad);\n\n const gamma =\n (23.0 * (p2 + 0.305) * t) /\n (23.0 * p1 + 11 * t * hCos + 108.0 * t * hSin);\n const a = gamma * hCos;\n const b = gamma * hSin;\n const rA = (460.0 * p2 + 451.0 * a + 288.0 * b) / 1403.0;\n const gA = (460.0 * p2 - 891.0 * a - 261.0 * b) / 1403.0;\n const bA = (460.0 * p2 - 220.0 * a - 6300.0 * b) / 1403.0;\n\n const rCBase = Math.max(0, (27.13 * Math.abs(rA)) / (400.0 - Math.abs(rA)));\n const rC =\n math.signum(rA) *\n (100.0 / viewingConditions.fl) *\n Math.pow(rCBase, 1.0 / 0.42);\n const gCBase = Math.max(0, (27.13 * Math.abs(gA)) / (400.0 - Math.abs(gA)));\n const gC =\n math.signum(gA) *\n (100.0 / viewingConditions.fl) *\n Math.pow(gCBase, 1.0 / 0.42);\n const bCBase = Math.max(0, (27.13 * Math.abs(bA)) / (400.0 - Math.abs(bA)));\n const bC =\n math.signum(bA) *\n (100.0 / viewingConditions.fl) *\n Math.pow(bCBase, 1.0 / 0.42);\n const rF = rC / viewingConditions.rgbD[0];\n const gF = gC / viewingConditions.rgbD[1];\n const bF = bC / viewingConditions.rgbD[2];\n\n const x = 1.86206786 * rF - 1.01125463 * gF + 0.14918677 * bF;\n const y = 0.38752654 * rF + 0.62144744 * gF - 0.00897398 * bF;\n const z = -0.0158415 * rF - 0.03412294 * gF + 1.04996444 * bF;\n\n return [x, y, z];\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"cam16.js","names":["ViewingConditions","argbFromXyz","linearized","math","Cam16","constructor","hue","chroma","j","q","m","s","jstar","astar","bstar","distance","other","dJ","dA","dB","dEPrime","Math","sqrt","dE","pow","fromInt","argb","fromIntInViewingConditions","DEFAULT","viewingConditions","red","green","blue","redL","greenL","blueL","x","y","z","rC","gC","bC","rD","rgbD","gD","bD","rAF","fl","abs","gAF","bAF","rA","signum","gA","bA","a","b","u","p2","atan2","atanDegrees","PI","hueRadians","ac","nbb","aw","c","fLRoot","huePrime","eHue","cos","p1","nc","ncb","t","alpha","n","mstar","log","sin","fromJch","h","fromJchInViewingConditions","fromUcs","fromUcsInViewingConditions","M","exp","toInt","viewed","hRad","hSin","hCos","gamma","rCBase","max","gCBase","bCBase","rF","gF","bF","fromXyzInViewingConditions","J","Q","C","xyzInViewingConditions"],"sources":["../../../../src/util/color/hct/cam16.ts"],"sourcesContent":["/**\r\n * @license\r\n * Copyright 2021 Google LLC\r\n *\r\n * Licensed under the Apache License, Version 2.0 (the \"License\");\r\n * you may not use this file except in compliance with the License.\r\n * You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\nimport { ViewingConditions } from './viewing-conditions';\r\n\r\nimport { argbFromXyz, linearized } from '../conversion';\r\nimport * as math from '../utils/math-utils';\r\n\r\n/**\r\n * CAM16, a color appearance model. Colors are not just defined by their hex\r\n * code, but rather, a hex code and viewing conditions.\r\n *\r\n * CAM16 instances also have coordinates in the CAM16-UCS space, called J*, a*,\r\n * b*, or jstar, astar, bstar in code. CAM16-UCS is included in the CAM16\r\n * specification, and should be used when measuring distances between colors.\r\n *\r\n * In traditional color spaces, a color can be identified solely by the\r\n * observer's measurement of the color. Color appearance models such as CAM16\r\n * also use information about the environment where the color was\r\n * observed, known as the viewing conditions.\r\n *\r\n * For example, white under the traditional assumption of a midday sun white\r\n * point is accurately measured as a slightly chromatic blue by CAM16. (roughly,\r\n * hue 203, chroma 3, lightness 100)\r\n */\r\nexport class Cam16 {\r\n /**\r\n * All of the CAM16 dimensions can be calculated from 3 of the dimensions, in\r\n * the following combinations:\r\n * - {j or q} and {c, m, or s} and hue\r\n * - jstar, astar, bstar\r\n * Prefer using a static method that constructs from 3 of those dimensions.\r\n * This constructor is intended for those methods to use to return all\r\n * possible dimensions.\r\n *\r\n * @param hue\r\n * @param chroma informally, colorfulness / color intensity. like saturation\r\n * in HSL, except perceptually accurate.\r\n * @param j lightness\r\n * @param q brightness; ratio of lightness to white point's lightness\r\n * @param m colorfulness\r\n * @param s saturation; ratio of chroma to white point's chroma\r\n * @param jstar CAM16-UCS J coordinate\r\n * @param astar CAM16-UCS a coordinate\r\n * @param bstar CAM16-UCS b coordinate\r\n */\r\n constructor(\r\n readonly hue: number,\r\n readonly chroma: number,\r\n readonly j: number,\r\n readonly q: number,\r\n readonly m: number,\r\n readonly s: number,\r\n readonly jstar: number,\r\n readonly astar: number,\r\n readonly bstar: number,\r\n ) {}\r\n\r\n /**\r\n * CAM16 instances also have coordinates in the CAM16-UCS space, called J*,\r\n * a*, b*, or jstar, astar, bstar in code. CAM16-UCS is included in the CAM16\r\n * specification, and is used to measure distances between colors.\r\n */\r\n distance(other: Cam16): number {\r\n const dJ = this.jstar - other.jstar;\r\n const dA = this.astar - other.astar;\r\n const dB = this.bstar - other.bstar;\r\n const dEPrime = Math.sqrt(dJ * dJ + dA * dA + dB * dB);\r\n const dE = 1.41 * Math.pow(dEPrime, 0.63);\r\n return dE;\r\n }\r\n\r\n /**\r\n * @param argb ARGB representation of a color.\r\n * @return CAM16 color, assuming the color was viewed in default viewing\r\n * conditions.\r\n */\r\n static fromInt(argb: number): Cam16 {\r\n return Cam16.fromIntInViewingConditions(argb, ViewingConditions.DEFAULT);\r\n }\r\n\r\n /**\r\n * @param argb ARGB representation of a color.\r\n * @param viewingConditions Information about the environment where the color\r\n * was observed.\r\n * @return CAM16 color.\r\n */\r\n static fromIntInViewingConditions(\r\n argb: number,\r\n viewingConditions: ViewingConditions,\r\n ): Cam16 {\r\n const red = (argb & 0x00ff0000) >> 16;\r\n const green = (argb & 0x0000ff00) >> 8;\r\n const blue = argb & 0x000000ff;\r\n const redL = linearized(red);\r\n const greenL = linearized(green);\r\n const blueL = linearized(blue);\r\n const x = 0.41233895 * redL + 0.35762064 * greenL + 0.18051042 * blueL;\r\n const y = 0.2126 * redL + 0.7152 * greenL + 0.0722 * blueL;\r\n const z = 0.01932141 * redL + 0.11916382 * greenL + 0.95034478 * blueL;\r\n\r\n const rC = 0.401288 * x + 0.650173 * y - 0.051461 * z;\r\n const gC = -0.250268 * x + 1.204414 * y + 0.045854 * z;\r\n const bC = -0.002079 * x + 0.048952 * y + 0.953127 * z;\r\n\r\n const rD = viewingConditions.rgbD[0] * rC;\r\n const gD = viewingConditions.rgbD[1] * gC;\r\n const bD = viewingConditions.rgbD[2] * bC;\r\n\r\n const rAF = Math.pow((viewingConditions.fl * Math.abs(rD)) / 100.0, 0.42);\r\n const gAF = Math.pow((viewingConditions.fl * Math.abs(gD)) / 100.0, 0.42);\r\n const bAF = Math.pow((viewingConditions.fl * Math.abs(bD)) / 100.0, 0.42);\r\n\r\n const rA = (math.signum(rD) * 400.0 * rAF) / (rAF + 27.13);\r\n const gA = (math.signum(gD) * 400.0 * gAF) / (gAF + 27.13);\r\n const bA = (math.signum(bD) * 400.0 * bAF) / (bAF + 27.13);\r\n\r\n const a = (11.0 * rA + -12.0 * gA + bA) / 11.0;\r\n const b = (rA + gA - 2.0 * bA) / 9.0;\r\n const u = (20.0 * rA + 20.0 * gA + 21.0 * bA) / 20.0;\r\n const p2 = (40.0 * rA + 20.0 * gA + bA) / 20.0;\r\n const atan2 = Math.atan2(b, a);\r\n const atanDegrees = (atan2 * 180.0) / Math.PI;\r\n const hue =\r\n atanDegrees < 0\r\n ? atanDegrees + 360.0\r\n : atanDegrees >= 360\r\n ? atanDegrees - 360.0\r\n : atanDegrees;\r\n const hueRadians = (hue * Math.PI) / 180.0;\r\n\r\n const ac = p2 * viewingConditions.nbb;\r\n const j =\r\n 100.0 *\r\n Math.pow(\r\n ac / viewingConditions.aw,\r\n viewingConditions.c * viewingConditions.z,\r\n );\r\n const q =\r\n (4.0 / viewingConditions.c) *\r\n Math.sqrt(j / 100.0) *\r\n (viewingConditions.aw + 4.0) *\r\n viewingConditions.fLRoot;\r\n const huePrime = hue < 20.14 ? hue + 360 : hue;\r\n const eHue = 0.25 * (Math.cos((huePrime * Math.PI) / 180.0 + 2.0) + 3.8);\r\n const p1 =\r\n (50000.0 / 13.0) * eHue * viewingConditions.nc * viewingConditions.ncb;\r\n const t = (p1 * Math.sqrt(a * a + b * b)) / (u + 0.305);\r\n const alpha =\r\n Math.pow(t, 0.9) *\r\n Math.pow(1.64 - Math.pow(0.29, viewingConditions.n), 0.73);\r\n const c = alpha * Math.sqrt(j / 100.0);\r\n const m = c * viewingConditions.fLRoot;\r\n const s =\r\n 50.0 *\r\n Math.sqrt((alpha * viewingConditions.c) / (viewingConditions.aw + 4.0));\r\n const jstar = ((1.0 + 100.0 * 0.007) * j) / (1.0 + 0.007 * j);\r\n const mstar = (1.0 / 0.0228) * Math.log(1.0 + 0.0228 * m);\r\n const astar = mstar * Math.cos(hueRadians);\r\n const bstar = mstar * Math.sin(hueRadians);\r\n\r\n return new Cam16(hue, c, j, q, m, s, jstar, astar, bstar);\r\n }\r\n\r\n /**\r\n * @param j CAM16 lightness\r\n * @param c CAM16 chroma\r\n * @param h CAM16 hue\r\n */\r\n static fromJch(j: number, c: number, h: number): Cam16 {\r\n return Cam16.fromJchInViewingConditions(j, c, h, ViewingConditions.DEFAULT);\r\n }\r\n\r\n /**\r\n * @param j CAM16 lightness\r\n * @param c CAM16 chroma\r\n * @param h CAM16 hue\r\n * @param viewingConditions Information about the environment where the color\r\n * was observed.\r\n */\r\n static fromJchInViewingConditions(\r\n j: number,\r\n c: number,\r\n h: number,\r\n viewingConditions: ViewingConditions,\r\n ): Cam16 {\r\n const q =\r\n (4.0 / viewingConditions.c) *\r\n Math.sqrt(j / 100.0) *\r\n (viewingConditions.aw + 4.0) *\r\n viewingConditions.fLRoot;\r\n const m = c * viewingConditions.fLRoot;\r\n const alpha = c / Math.sqrt(j / 100.0);\r\n const s =\r\n 50.0 *\r\n Math.sqrt((alpha * viewingConditions.c) / (viewingConditions.aw + 4.0));\r\n const hueRadians = (h * Math.PI) / 180.0;\r\n const jstar = ((1.0 + 100.0 * 0.007) * j) / (1.0 + 0.007 * j);\r\n const mstar = (1.0 / 0.0228) * Math.log(1.0 + 0.0228 * m);\r\n const astar = mstar * Math.cos(hueRadians);\r\n const bstar = mstar * Math.sin(hueRadians);\r\n return new Cam16(h, c, j, q, m, s, jstar, astar, bstar);\r\n }\r\n\r\n /**\r\n * @param jstar CAM16-UCS lightness.\r\n * @param astar CAM16-UCS a dimension. Like a* in L*a*b*, it is a Cartesian\r\n * coordinate on the Y axis.\r\n * @param bstar CAM16-UCS b dimension. Like a* in L*a*b*, it is a Cartesian\r\n * coordinate on the X axis.\r\n */\r\n static fromUcs(jstar: number, astar: number, bstar: number): Cam16 {\r\n return Cam16.fromUcsInViewingConditions(\r\n jstar,\r\n astar,\r\n bstar,\r\n ViewingConditions.DEFAULT,\r\n );\r\n }\r\n\r\n /**\r\n * @param jstar CAM16-UCS lightness.\r\n * @param astar CAM16-UCS a dimension. Like a* in L*a*b*, it is a Cartesian\r\n * coordinate on the Y axis.\r\n * @param bstar CAM16-UCS b dimension. Like a* in L*a*b*, it is a Cartesian\r\n * coordinate on the X axis.\r\n * @param viewingConditions Information about the environment where the color\r\n * was observed.\r\n */\r\n static fromUcsInViewingConditions(\r\n jstar: number,\r\n astar: number,\r\n bstar: number,\r\n viewingConditions: ViewingConditions,\r\n ): Cam16 {\r\n const a = astar;\r\n const b = bstar;\r\n const m = Math.sqrt(a * a + b * b);\r\n const M = (Math.exp(m * 0.0228) - 1.0) / 0.0228;\r\n const c = M / viewingConditions.fLRoot;\r\n let h = Math.atan2(b, a) * (180.0 / Math.PI);\r\n if (h < 0.0) {\r\n h += 360.0;\r\n }\r\n const j = jstar / (1 - (jstar - 100) * 0.007);\r\n return Cam16.fromJchInViewingConditions(j, c, h, viewingConditions);\r\n }\r\n\r\n /**\r\n * @return ARGB representation of color, assuming the color was viewed in\r\n * default viewing conditions, which are near-identical to the default\r\n * viewing conditions for sRGB.\r\n */\r\n toInt(): number {\r\n return this.viewed(ViewingConditions.DEFAULT);\r\n }\r\n\r\n /**\r\n * @param viewingConditions Information about the environment where the color\r\n * will be viewed.\r\n * @return ARGB representation of color\r\n */\r\n viewed(viewingConditions: ViewingConditions): number {\r\n const alpha =\r\n this.chroma === 0.0 || this.j === 0.0\r\n ? 0.0\r\n : this.chroma / Math.sqrt(this.j / 100.0);\r\n\r\n const t = Math.pow(\r\n alpha / Math.pow(1.64 - Math.pow(0.29, viewingConditions.n), 0.73),\r\n 1.0 / 0.9,\r\n );\r\n const hRad = (this.hue * Math.PI) / 180.0;\r\n\r\n const eHue = 0.25 * (Math.cos(hRad + 2.0) + 3.8);\r\n const ac =\r\n viewingConditions.aw *\r\n Math.pow(this.j / 100.0, 1.0 / viewingConditions.c / viewingConditions.z);\r\n const p1 =\r\n eHue * (50000.0 / 13.0) * viewingConditions.nc * viewingConditions.ncb;\r\n const p2 = ac / viewingConditions.nbb;\r\n\r\n const hSin = Math.sin(hRad);\r\n const hCos = Math.cos(hRad);\r\n\r\n const gamma =\r\n (23.0 * (p2 + 0.305) * t) /\r\n (23.0 * p1 + 11.0 * t * hCos + 108.0 * t * hSin);\r\n const a = gamma * hCos;\r\n const b = gamma * hSin;\r\n const rA = (460.0 * p2 + 451.0 * a + 288.0 * b) / 1403.0;\r\n const gA = (460.0 * p2 - 891.0 * a - 261.0 * b) / 1403.0;\r\n const bA = (460.0 * p2 - 220.0 * a - 6300.0 * b) / 1403.0;\r\n\r\n const rCBase = Math.max(0, (27.13 * Math.abs(rA)) / (400.0 - Math.abs(rA)));\r\n const rC =\r\n math.signum(rA) *\r\n (100.0 / viewingConditions.fl) *\r\n Math.pow(rCBase, 1.0 / 0.42);\r\n const gCBase = Math.max(0, (27.13 * Math.abs(gA)) / (400.0 - Math.abs(gA)));\r\n const gC =\r\n math.signum(gA) *\r\n (100.0 / viewingConditions.fl) *\r\n Math.pow(gCBase, 1.0 / 0.42);\r\n const bCBase = Math.max(0, (27.13 * Math.abs(bA)) / (400.0 - Math.abs(bA)));\r\n const bC =\r\n math.signum(bA) *\r\n (100.0 / viewingConditions.fl) *\r\n Math.pow(bCBase, 1.0 / 0.42);\r\n const rF = rC / viewingConditions.rgbD[0];\r\n const gF = gC / viewingConditions.rgbD[1];\r\n const bF = bC / viewingConditions.rgbD[2];\r\n\r\n const x = 1.86206786 * rF - 1.01125463 * gF + 0.14918677 * bF;\r\n const y = 0.38752654 * rF + 0.62144744 * gF - 0.00897398 * bF;\r\n const z = -0.0158415 * rF - 0.03412294 * gF + 1.04996444 * bF;\r\n\r\n const argb = argbFromXyz(x, y, z);\r\n return argb;\r\n }\r\n\r\n /// Given color expressed in XYZ and viewed in [viewingConditions], convert to\r\n /// CAM16.\r\n static fromXyzInViewingConditions(\r\n x: number,\r\n y: number,\r\n z: number,\r\n viewingConditions: ViewingConditions,\r\n ): Cam16 {\r\n // Transform XYZ to 'cone'/'rgb' responses\r\n\r\n const rC = 0.401288 * x + 0.650173 * y - 0.051461 * z;\r\n const gC = -0.250268 * x + 1.204414 * y + 0.045854 * z;\r\n const bC = -0.002079 * x + 0.048952 * y + 0.953127 * z;\r\n\r\n // Discount illuminant\r\n const rD = viewingConditions.rgbD[0] * rC;\r\n const gD = viewingConditions.rgbD[1] * gC;\r\n const bD = viewingConditions.rgbD[2] * bC;\r\n\r\n // chromatic adaptation\r\n const rAF = Math.pow((viewingConditions.fl * Math.abs(rD)) / 100.0, 0.42);\r\n const gAF = Math.pow((viewingConditions.fl * Math.abs(gD)) / 100.0, 0.42);\r\n const bAF = Math.pow((viewingConditions.fl * Math.abs(bD)) / 100.0, 0.42);\r\n const rA = (math.signum(rD) * 400.0 * rAF) / (rAF + 27.13);\r\n const gA = (math.signum(gD) * 400.0 * gAF) / (gAF + 27.13);\r\n const bA = (math.signum(bD) * 400.0 * bAF) / (bAF + 27.13);\r\n\r\n // redness-greenness\r\n const a = (11.0 * rA + -12.0 * gA + bA) / 11.0;\r\n // yellowness-blueness\r\n const b = (rA + gA - 2.0 * bA) / 9.0;\r\n\r\n // auxiliary components\r\n const u = (20.0 * rA + 20.0 * gA + 21.0 * bA) / 20.0;\r\n const p2 = (40.0 * rA + 20.0 * gA + bA) / 20.0;\r\n\r\n // hue\r\n const atan2 = Math.atan2(b, a);\r\n const atanDegrees = (atan2 * 180.0) / Math.PI;\r\n const hue =\r\n atanDegrees < 0\r\n ? atanDegrees + 360.0\r\n : atanDegrees >= 360\r\n ? atanDegrees - 360\r\n : atanDegrees;\r\n const hueRadians = (hue * Math.PI) / 180.0;\r\n\r\n // achromatic response to color\r\n const ac = p2 * viewingConditions.nbb;\r\n\r\n // CAM16 lightness and brightness\r\n const J =\r\n 100.0 *\r\n Math.pow(\r\n ac / viewingConditions.aw,\r\n viewingConditions.c * viewingConditions.z,\r\n );\r\n const Q =\r\n (4.0 / viewingConditions.c) *\r\n Math.sqrt(J / 100.0) *\r\n (viewingConditions.aw + 4.0) *\r\n viewingConditions.fLRoot;\r\n\r\n const huePrime = hue < 20.14 ? hue + 360 : hue;\r\n const eHue =\r\n (1.0 / 4.0) * (Math.cos((huePrime * Math.PI) / 180.0 + 2.0) + 3.8);\r\n const p1 =\r\n (50000.0 / 13.0) * eHue * viewingConditions.nc * viewingConditions.ncb;\r\n const t = (p1 * Math.sqrt(a * a + b * b)) / (u + 0.305);\r\n const alpha =\r\n Math.pow(t, 0.9) *\r\n Math.pow(1.64 - Math.pow(0.29, viewingConditions.n), 0.73);\r\n // CAM16 chroma, colorfulness, chroma\r\n const C = alpha * Math.sqrt(J / 100.0);\r\n const M = C * viewingConditions.fLRoot;\r\n const s =\r\n 50.0 *\r\n Math.sqrt((alpha * viewingConditions.c) / (viewingConditions.aw + 4.0));\r\n\r\n // CAM16-UCS components\r\n const jstar = ((1.0 + 100.0 * 0.007) * J) / (1.0 + 0.007 * J);\r\n const mstar = Math.log(1.0 + 0.0228 * M) / 0.0228;\r\n const astar = mstar * Math.cos(hueRadians);\r\n const bstar = mstar * Math.sin(hueRadians);\r\n return new Cam16(hue, C, J, Q, M, s, jstar, astar, bstar);\r\n }\r\n\r\n /// XYZ representation of CAM16 seen in [viewingConditions].\r\n xyzInViewingConditions(viewingConditions: ViewingConditions): number[] {\r\n const alpha =\r\n this.chroma === 0.0 || this.j === 0.0\r\n ? 0.0\r\n : this.chroma / Math.sqrt(this.j / 100.0);\r\n\r\n const t = Math.pow(\r\n alpha / Math.pow(1.64 - Math.pow(0.29, viewingConditions.n), 0.73),\r\n 1.0 / 0.9,\r\n );\r\n const hRad = (this.hue * Math.PI) / 180.0;\r\n\r\n const eHue = 0.25 * (Math.cos(hRad + 2.0) + 3.8);\r\n const ac =\r\n viewingConditions.aw *\r\n Math.pow(this.j / 100.0, 1.0 / viewingConditions.c / viewingConditions.z);\r\n const p1 =\r\n eHue * (50000.0 / 13.0) * viewingConditions.nc * viewingConditions.ncb;\r\n\r\n const p2 = ac / viewingConditions.nbb;\r\n\r\n const hSin = Math.sin(hRad);\r\n const hCos = Math.cos(hRad);\r\n\r\n const gamma =\r\n (23.0 * (p2 + 0.305) * t) /\r\n (23.0 * p1 + 11 * t * hCos + 108.0 * t * hSin);\r\n const a = gamma * hCos;\r\n const b = gamma * hSin;\r\n const rA = (460.0 * p2 + 451.0 * a + 288.0 * b) / 1403.0;\r\n const gA = (460.0 * p2 - 891.0 * a - 261.0 * b) / 1403.0;\r\n const bA = (460.0 * p2 - 220.0 * a - 6300.0 * b) / 1403.0;\r\n\r\n const rCBase = Math.max(0, (27.13 * Math.abs(rA)) / (400.0 - Math.abs(rA)));\r\n const rC =\r\n math.signum(rA) *\r\n (100.0 / viewingConditions.fl) *\r\n Math.pow(rCBase, 1.0 / 0.42);\r\n const gCBase = Math.max(0, (27.13 * Math.abs(gA)) / (400.0 - Math.abs(gA)));\r\n const gC =\r\n math.signum(gA) *\r\n (100.0 / viewingConditions.fl) *\r\n Math.pow(gCBase, 1.0 / 0.42);\r\n const bCBase = Math.max(0, (27.13 * Math.abs(bA)) / (400.0 - Math.abs(bA)));\r\n const bC =\r\n math.signum(bA) *\r\n (100.0 / viewingConditions.fl) *\r\n Math.pow(bCBase, 1.0 / 0.42);\r\n const rF = rC / viewingConditions.rgbD[0];\r\n const gF = gC / viewingConditions.rgbD[1];\r\n const bF = bC / viewingConditions.rgbD[2];\r\n\r\n const x = 1.86206786 * rF - 1.01125463 * gF + 0.14918677 * bF;\r\n const y = 0.38752654 * rF + 0.62144744 * gF - 0.00897398 * bF;\r\n const z = -0.0158415 * rF - 0.03412294 * gF + 1.04996444 * bF;\r\n\r\n return [x, y, z];\r\n }\r\n}\r\n"],"mappings":"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","ignoreList":[]}
|