- ブログ
- OKLCH完全ガイド:現代CSSカラーの新標準
OKLCH完全ガイド:現代CSSカラーの新標準
フロントエンド研究者on 23 days ago
概要
OKLCH色空間は、2020年に発表されたBjörn OttossonのOKLab研究に由来し、HSLと従来のCIE LCHに比べて、より均一な明度軸、より広い色域カバレッジ、そして簡素化されたアクセシビリティコントラスト計算を提供することを目的としています。現在、Chrome 111+、Safari 15.4+、Firefox 113+などの主要ブラウザはoklch()
をネイティブに解析し、DevToolsカラーピッカーでGUIサポートを提供しています。Figmaも OKLCH色空間の導入を発表し、次世代Web設計とフロントエンドエンジニアリングの礎となっています。
1. 視覚科学と数学的基盤
1.1 従来モデルの限界
- CIE Labは暗部と高彩度域でまだ知覚の歪みを示し、デザインモックアップと実際のディスプレイ間の乖離を引き起こしています
- HSLは単にsRGB直交座標の被覆であり、単純にL値を増加させると彩度の低下と色相シフトを引き起こし、特にダークモードで問題となります
1.2 OKLab → OKLCH マッピング
OKLabはLMS円錐応答を通じてRGBを線形化し、ほぼ線形のL軸とa/bベクトルを得ます。その後、a/bを極座標に変換してCとhを得、これらを組み合わせて均一性と使いやすさのバランスを取ったOKLCHを形成します。
1.3 サンプル式
CSSで直接使用:
color: oklch(62% 0.21 230deg);
ブラウザはデバイスガマットに従って自動的に最も近い表示可能な色にクリップし、メディアクエリや追加のスクリプトを必要としません。
2. OKLCH vs他の色空間比較
次元 | HSL | CIE‑LCH | OKLCH |
---|---|---|---|
知覚的均一性 | 低 | 中 | 高 |
広色域カバレッジ | sRGB | 限定的 | P3/Rec. 2020 |
コントラスト予測可能性 | 困難 | 平均 | 簡単 |
- ボタンホバー実験では、HSLの明度アップは著しい彩度低下を引き起こしますが、OKLCHはLのみを調整することで彩度を保持します
- CIE‑LCHはL≈5で複数のクロマレベルを区別するのに苦労しますが、OKLCHは6以上の区別可能な暗いレベルを出力できます
- OKLCH C軸には理論的上限がなく、Rec. 2020ガマットの約47%をカバーし、sRGBと比べて約30%の改善を提供します
3. ブラウザとツールチェーンサポート
3.1 ブラウザ
- Chrome/Edgeはバージョン111からOKLCHを公式サポートし、DevTools Color PickerにOKLCHスライダーを提供
- Safariはバージョン15.4からモバイルで
oklch()
解析をサポート - Firefox 113でOKLab/OKLCHサポートが同時に実装
- Can I Use統計では、2025年Q2の全世界サポート率は92%を超えています
3.2 デザインとビルドチェーン
- Figmaコミュニティは積極的にOKLCHサポートを要求し、現在2024年ベータテスト中
- PostCSS Preset‑Env Stage 9 Polyfillは、レガシーブラウザに対してsRGBにダウングレードできます
4. アクセシビリティとコントラスト
- APCAは、Lc ≥ 60の時に最適な読書体験を提案し、OKLCHの線形Lは ΔL≈40でこの閾値に達することを可能にします
- 将来のLighthouseはOKLCH L軸を使用して従来のRatioを置き換える可能性があり、監査プロセスをさらに簡素化します
5. 広色域とHDR実践
:root {
--accent: oklch(70% 0.24 200);
}
- P3/HDRデバイスはより鮮やかなシアンブルーを表示可能、sRGBデバイスは自動的にクリップして「色あふれ」を回避
@media (color-gamut: p3)
の重複変数が不要となり、メンテナンスコストを削減
6. 保守可能なカラーシステムの構築
:root {
--brand-l: 60%;
--brand-c: 0.18;
--brand-h: 262deg;
}
@function tone($l) {
@return oklch($l var(--brand-c) var(--brand-h));
}
- Sassループを通じて16段階カラーパレットを生成し、ティント/シェード/グレースケールの多次元ニーズに対応
color-mix(in oklch, var(--brand) 20%, white)
でHoverを素早く生成、oklch(from var(--brand) l -10%)
でActiveを生成contrast-color()
(Color Level 5ドラフト)は、Chrome 125で最適な前景色を選択します
7. SEOとパフォーマンス利益
- PNGグラデーションをCSS OKLCHに置き換えることで、ホームページバンドルを120KB削減し、LCPを11%向上
- 変数切り替えは追加画像を必要とせず、安定したCLSを維持し、検索ランキングに有利
8. コミュニティエコシステムと事例
- Evil MartiansはOKLCH Color Pickerをリリースし、オンラインHEX/HSL → OKLCH変換とsRGBフォールバック検証をサポート
- Smashing MagazineやGitHubの多数のプロジェクトが
color-mix(in oklch, …)
の実用的経験を共有し、エコシステムが急成長
9. よくある落とし穴と対策
問題 | 症状 | 解決策 |
---|---|---|
SDRスクリーン「蛍光」 | C > 0.4時の過彩度 | C≤0.32に制限し、oklch(from …) クリッピングを使用 |
レガシーWebView解析問題 | ページが黒くなる | ビルド時にPostCSS Polyfillを有効化 |
暗いテキストがグレーに見える | ΔLが小さすぎる | ΔL≥40またはcontrast-color() を有効化 |
10. 将来の展望
CSS Color Level 5はlight-dark()
、relative-color-syntax
、contrast-color()
などの機能でOKLCHを完全サポートし、テーマ変数から前景色計算までの閉ループを実現します。
まとめ
OKLCHは視覚的均一性、広色域互換性、コントラスト親和性を持って、Webカラーを「一度宣言、デバイス間で一貫」の新時代に導きます。既存のHSLトークンを即座にL‑C‑h変数にアップグレードし、盲点のないカラー調整体験を享受し、デザイン、開発、アクセシビリティチームの共通言語を確立しましょう。
更新日: 2025-07-12