自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

CSS 如何根據(jù)背景色自動切換黑白文字?

開發(fā) 前端
通常這種情況,大家可能會通過 JS 去計算背景色的深淺度(灰度),算法是公開的,如果已知顏色的RGB值,那么可以通過以下方式得到顏色灰度。

在項目中,經(jīng)常會碰到背景色不確定的場景,為了讓內(nèi)容文字足夠清晰可見,文字和背景之間需要有足夠的對比度。換句話說,當背景是深色時,文字為白色,當背景是淺色時,文字為黑色,就像這樣:

圖片

通常這種情況,大家可能會通過 js 去計算背景色的深淺度(灰度),算法是公開的,如果已知顏色的??RGB??值,那么可以通過以下方式得到顏色灰度

luma = (red * 0.2126 + green * 0.7152 + blue * 0.0722) / 255

這樣可以得到一個0~1之間的范圍值,可以根據(jù)需求,設(shè)定一個閾值,超過表示為淺色,否則為深色。

原理就是這樣,這里就不多介紹了。

那么,純 CSS 也能實現(xiàn)這樣的效果嗎?當然可以,而且實現(xiàn)更簡單,一起看看吧。

一、CSS 濾鏡實現(xiàn)

實現(xiàn)這個效果需要用到 CSS 濾鏡。

假設(shè)有 HTML 是這樣的。

<div class="box">
<span class="txt">前端偵探</span>
</div>

因為要使用濾鏡對文字單獨處理,所以需要額外一層標簽。

然后,容器和文字用同一種顏色表示,目的是讓文字顏色和背景相關(guān)聯(lián),可以通過currentColor實現(xiàn)。

.box{
color: #ffeb3b;
background-color: currentColor;
}

接下來可以想一下,如何讓彩色文字變成黑白?

提到黑白,可以想到灰度濾鏡(grayscale),相信大家前幾天都用到過,這樣可以將彩色的文字轉(zhuǎn)換成灰色。

.text{
filter: grayscale(1)
}

效果如下:

圖片

這樣文字顏色由原來的黃綠色變成了淺灰色。

但是,這種灰色在現(xiàn)在這種背景下太難看清了,我們需要的是純正的黑色或者白色,現(xiàn)在只是灰色,如何“加強”一下呢?

這時,我們可以用到對比度濾鏡(contrast),在前面的基礎(chǔ)上再疊加一層。

.text{
filter: grayscale(1) contrast(999)
}

這里的對比度給的比較大,這樣就會極大的增強對比度,黑的更黑,白的更白,如果是淺灰,那就變成白色,如果是深灰,那就變成黑色,效果如下:

圖片

這樣能還不太明顯,我們把背景色換一下。

圖片

最后,還差一步,由于前面的操作是將原有顏色經(jīng)過濾鏡轉(zhuǎn)換成了和自身相對應(yīng)的白色或者黑色,但是是相反的,所以需要用到反轉(zhuǎn)濾鏡(invert),顛倒黑白。

.text{
filter: grayscale(1) contrast(999) invert(1)
}

效果如下:

圖片

下面用一張圖來表示轉(zhuǎn)換過程:

圖片

下面是任意顏色的適配效果,還是挺完美的。

圖片

代碼很簡單,就這么一行:

.text{
filter: grayscale(1) contrast(999) invert(1)
}

完整代碼可以查看以下任意鏈接

  • CSS auto-color (juejin.cn)[1]
  • CSS auto-color (codepen.io)[2]
  • CSS auto-color (runjs.work)[3]

二、CSS 其他思路

除了上面這種方式,還可以通過 CSS 變量來實現(xiàn),要復(fù)雜一些。

這里簡單介紹一下實現(xiàn)思路:

  1. 將顏色RGB值拆分成 3 個獨立的 CSS變量。
  2. 通過灰度算法,用 CSS 計算函數(shù)算出灰度。
  3. 用得到的灰度和閾值做差值,通過hsl模式轉(zhuǎn)換成純黑和純白。

有興趣的可以參考張鑫旭老師的這篇文章:CSS前景背景自動配色技術(shù)簡介[4],可以看到,整體實現(xiàn)和 js 邏輯幾乎是一致的,下面是完整實現(xiàn)。

:root {
/* 定義RGB變量 */
--red: 44;
--green: 135;
--blue: 255;
/* 文字顏色變色的臨界值,建議0.5~0.6 */
--threshold: 0.5;
}

.btn {
/* 按鈕背景色就是基本背景色 */
background: rgb(var(--red), var(--green), var(--blue));

/**
* 使用sRGB Luma方法計算灰度(可以看成亮度)
* 算法為:
* lightness = (red * 0.2126 + green * 0.7152 + blue * 0.0722) / 255
*/
--r: calc(var(--red) * 0.2126);
--g: calc(var(--green) * 0.7152);
--b: calc(var(--blue) * 0.0722);
--sum: calc(var(--r) + var(--g) + var(--b));
--lightness: calc(var(--sum) / 255);

/* 設(shè)置顏色 */
color: hsl(0, 0%, calc((var(--lightness) - var(--threshold)) * -999999%));
}

效果如下:

圖片

相比前面的實現(xiàn)而言,實現(xiàn)更加靈活,可以少一層標簽。

另外,CSS 正在起草一個顏色對比函數(shù)color-contrast,可以從幾個顏色中自動選擇對比度最高的那個,實現(xiàn)是這樣的。

.text-contrast-primary {
color: color-contrast(var(--theme-primary) vs white, black);
}

不過,現(xiàn)在還沒有任何瀏覽器支持。

圖片

如果將來支持了,這將是終極解決方案。

三、優(yōu)缺點總結(jié)

總的來說,在color-contrast函數(shù)支持之前,我更推薦 CSS 濾鏡方式,有以下幾點好處

  1. 代碼簡潔,就一行代碼,3 個濾鏡。
  2. 對顏色格式無任何要求,無需轉(zhuǎn)換成RGB模式。
  3. 無需了解顏色算法,對設(shè)計更為友好。

當然,也是存在一些缺點

  1. 需要單獨一層標簽,使用場景可能有限制。
  2. 對顏色敏感度較高,不然無從下手。
  3. 顏色轉(zhuǎn)換有限制,最終只能是黑白,其他顏色就無能為力了。

下面來回顧一下用到的3個濾鏡,總結(jié)一下:

  1. 灰度濾鏡(grayscale),可以將彩色的文字轉(zhuǎn)換成灰色。
  2. 對比度濾鏡(contrast),可以極大的增強對比度,黑的更黑,白的更白,如果是淺灰,那就變成白色,如果是深灰,那就變成黑色。
  3. 反轉(zhuǎn)濾鏡(invert),可以翻轉(zhuǎn)顏色,顛倒黑白。

重新體會顏色轉(zhuǎn)換過程:

圖片

參考資料

[1]CSS auto-color (juejin.cn): ??https://code.juejin.cn/pen/7180639403566448698。

[2]CSS auto-color (codepen.io): ??https://codepen.io/xboxyan/pen/bGjVbGj。

[3]CSS auto-color (runjs.work): ??https://runjs.work/projects/bb844abe80da401d。

[4]CSS前景背景自動配色技術(shù)簡介: ??https://www.zhangxinxu.com/wordpress/2018/11/css-background-color-font-auto-match/。

責任編輯:姜華 來源: 前端偵探
相關(guān)推薦

2024-05-08 08:42:58

TypeScript函數(shù)文本顏色

2021-04-16 05:54:05

CSS 文字動畫技巧

2024-01-30 13:53:31

2010-08-11 16:30:49

Flex DataGr

2010-08-11 16:41:30

Flex DataGr

2023-12-04 08:06:41

CSS文字效果

2025-01-20 08:35:53

2010-09-08 09:54:16

CSS自動換行CSS

2009-07-30 09:42:29

CSS實現(xiàn)文字旋轉(zhuǎn)

2013-05-15 10:27:05

R語言

2010-09-13 13:56:52

CSSDIV背景

2024-12-12 08:55:25

CSS代碼模式

2010-09-14 09:24:40

CSS實例

2010-09-14 09:18:28

DIVCSS

2022-10-31 19:10:39

CSS元素focus

2010-08-24 13:05:23

CSS超鏈接

2022-07-19 06:20:47

CSSbackground

2010-09-09 14:38:05

CSS背景圖片

2010-08-26 15:18:27

CSS樣式

2010-08-26 10:26:44

CSS
點贊
收藏

51CTO技術(shù)棧公眾號