/okcolor

Figma plugin for advanced color picking, with OkLCH, APCA, WCAG and more.

Primary LanguageTypeScriptMIT LicenseMIT

Easier color palettes and accessibility

OkColor

This is a plugin for Figma, see its community page.

Picking color and creating balanced color palettes with Figma is not an easy task, HSL and HSB are not perceptually uniform, HSL's lightness is relative to the current hue, so for each of them, the real perceived 50% lightness is not at L 50.

Same problem with hue, if we make a palette from hue 0 to 70 with the same incremental value, we'll get a palette that is not perceptually progressive, some hue changes will seem bigger than others.

We also have a problem known as the “Abney effect”, mainly in the blue hues. If we take the hue 240, it shift from blue to purple when we update the lightness.

OkColor solves all these problems and more, its params are reliable and uniform, you know what you'll get.

If we change the hue of a color in OkLCH and keep the same lightness value, we know that the resulting color will have the same perceived lightness.

You can also easily create perceptually uniform color palettes, and do more advanced things with OkLCH like picking colors in P3 space and use the relative chroma (see this thread for more infos).

For more details, check plugin community's page for a FAQ and a playground file that explain in more details the plugin.

Credits

This plugin is made possible by the Culori JS library and the creator of these color models: Björn Ottosson.

The rendering of the color picker is done by freydev using WebGL shaders.

The APCA contrast feature is made possible by the work of Myndex .

To know more about these uniform color spaces, you can check his original article: Oksvh and Okhsl and the one from oklch.com's creators: OKLCH in CSS: why we moved from RGB and HSL.

For developpers

Why I don't use culori.mjs file from node_modules?

Instead of importing from "../node_modules/culori/bundled/culori.mjs", I duplicated the file on the src folder due to clampChroma's limitation. The problem here is that this function can only clamp in sRGB, so to make it clamp in any provided space, I created "clampChromaInGamut(color, mode = "lch", targetGamut = "rgb")". I will send the suggestion to CuloriJS's author to add it in its code.

I tried to use toGamut() but it changes the hue and luminosity of the final color, and what I needed, was to only clamp the chroma while keeping the two others values untouched.