利用CSS3 filter:drop-shadow實現純CSS改變圖片顏色

體驗更優排版請移步原文:http://blog.kwin.wang/programming/css3-filter-drop-shadow-change-color.html

css


以前作項目過程當中有時候遇到圖片顏色和需求不符,當時就在想若是用純css可以改變圖片顏色就行了,這樣的話就不用讓UI從新給圖片了,如今看來實際上是能夠實現的,原理就是利用CSS3的濾鏡(filter)屬性。你想的沒錯,就是相似PS中的濾鏡。html

filter屬性介紹:css3

filter 屬性定義了元素(一般是<img>)的可視效果(例如:模糊與飽和度)。web

filter使用語法:瀏覽器

filter: grayscale(100%); //grayscale是一個將圖像轉換爲灰度圖像的函數

如下是filter函數描述:ide

Filter 描述
none 默認值,沒有效果。
blur(px) 給圖像設置高斯模糊。"radius"一值設定高斯函數的標準差,或者是屏幕上以多少像素融在一塊兒, 因此值越大越模糊;若是沒有設定值,則默認是0;這個參數可設置css長度值,但不接受百分比值。
brightness(%) 給圖片應用一種線性乘法,使其看起來更亮或更暗。若是值是0%,圖像會全黑。值是100%,則圖像無變化。其餘的值對應線性乘數效果。值超過100%也是能夠的,圖像會比原來更亮。若是沒有設定值,默認是1。
contrast(%) 調整圖像的對比度。值是0%的話,圖像會全黑。值是100%,圖像不變。值能夠超過100%,意味着會運用更低的對比。若沒有設置值,默認是1。
drop-shadow(h-shadow v-shadow blur spread color) 給圖像設置一個陰影效果。陰影是合成在圖像下面,能夠有模糊度的,能夠以特定顏色畫出的遮罩圖的偏移版本。 函數接受<shadow>(在CSS3背景中定義)類型的值,除了"inset"關鍵字是不容許的。該函數與已有的box-shadow box-shadow屬性很類似;不一樣之處在於,經過濾鏡,一些瀏覽器爲了更好的性能會提供硬件加速。<shadow>參數以下:
<offset-x> <offset-y> (必須)這是設置陰影偏移量的兩個 <length>值. <offset-x> 設定水平方向距離. 負值會使陰影出如今元素左邊. <offset-y>設定垂直距離.負值會使陰影出如今元素上方。查看<length>可能的單位.若是兩個值都是0, 則陰影出如今元素正後面 (若是設置了 <blur-radius> and/or <spread-radius>,會有模糊效果);
<blur-radius> (可選)這是第三個code><length>值. 值越大,越模糊,則陰影會變得更大更淡.不容許負值 若未設定,默認是0 (則陰影的邊界很銳利);
<spread-radius> (可選)這是第四個 <length>值。 正值會使陰影擴張和變大,負值會是陰影縮小.若未設定,默認是0 (陰影會與元素同樣大小)。
注意: Webkit, 以及一些其餘瀏覽器 不支持第四個長度,若是加了也不會渲染;
<color> (可選)查看 <color>該值可能的關鍵字和標記。若未設定,顏色值基於瀏覽器。在Gecko (Firefox), Presto (Opera)和Trident (Internet Explorer)中, 會應用color屬性的值。另外, 若是顏色值省略,WebKit中陰影是透明的。
grayscale(%) 將圖像轉換爲灰度圖像。值定義轉換的比例。值爲100%則徹底轉爲灰度圖像,值爲0%圖像無變化。值在0%到100%之間,則是效果的線性乘子。若未設置,值默認是0。
hue-rotate(deg) 給圖像應用色相旋轉。"angle"一值設定圖像會被調整的色環角度值。值爲0deg,則圖像無變化。若值未設置,默認值是0deg。該值雖然沒有最大值,超過360deg的值至關於又繞一圈。
invert(%) 反轉輸入圖像。值定義轉換的比例。100%的價值是徹底反轉。值爲0%則圖像無變化。值在0%和100%之間,則是效果的線性乘子。 若值未設置,值默認是0。
opacity(%) 轉化圖像的透明程度。值定義轉換的比例。值爲0%則是徹底透明,值爲100%則圖像無變化。值在0%和100%之間,則是效果的線性乘子,也至關於圖像樣本乘以數量。 若值未設置,值默認是1。該函數與已有的opacity屬性很類似,不一樣之處在於經過filter,一些瀏覽器爲了提高性能會提供硬件加速。
saturate(%) 轉換圖像飽和度。值定義轉換的比例。值爲0%則是徹底不飽和,值爲100%則圖像無變化。其餘值,則是效果的線性乘子。超過100%的值是容許的,則有更高的飽和度。 若值未設置,值默認是1。
sepia(%) 將圖像轉換爲深褐色。值定義轉換的比例。值爲100%則徹底是深褐色的,值爲0%圖像無變化。值在0%到100%之間,則是效果的線性乘子。若未設置,值默認是0。
url() URL函數接受一個XML文件,該文件設置了 一個SVG濾鏡,且能夠包含一個錨點來指定一個具體的濾鏡元素。
例如:filter: url(svg-url#element-id)
initial 設置屬性爲默認值。
inherit 從父元素繼承該屬性。

filter兼容性:
IE13如下、Android4.4如下不支持svg

看了這麼多,filter怎麼用應該大體有個瞭解了,咱們要改變圖片顏色,主要用的是drop-shadow這個函數,即利用圖片的偏移陰影,再給它賦個顏色來實現,是否是很神奇?wordpress

filter drop-shadow語法:函數

filter: drop-shadow(x偏移, y偏移, 模糊大小, 顏色);

想一想都有點小激動,話很少說,代碼奉上:性能

<div class="logo">
    <div class="logo-for-kmbbs"></div>
</div>
.header-main .logo{
    height: 18px; width: 18px;
    position: absolute;
    top: 15px;
    overflow: hidden;
}
.logo-for-kmbbs{
    height: 18px; width: 18px;
    background: url('images/logo30.png') no-repeat 0 0;
    background-size: 18px 18px;
    position: relative;
    left: -18px;
    border-right: 18px solid transparent;
    -webkit-filter: drop-shadow(18px 0px #fff);
    filter: drop-shadow(18px 0px #fff);
}

這裏經過修改css樣式將這個賦色後的陰影定位到原先圖片的位置,再將原先的圖片隱藏不可見,咱們的目的就這麼輕鬆達成了,原先藍色的logo圖片在這裏被設置成了白色,查看效果

歡迎交流!(•‿•)

參考:
https://www.w3cschool.cn/cssref/css3-pr-filter.html
https://www.zhangxinxu.com/wordpress/2016/06/png-icon-change-color-by-css/

相關文章
相關標籤/搜索