搜尋
首頁web前端css教學使用CSS3編寫灰階濾鏡來製作黑白照片效果

這篇文章主要介紹了使用CSS3編寫灰階濾鏡來製作黑白照片效果的方法,CSS3中的filter十分強大,文中還介紹了對IE兼容的方法,需要的朋友可以參考下

CSS3 中的濾鏡(filter)功能讓我們輕鬆方便簡單的處理圖片,而不需要使用PhotoShop 或使用很多JavaScript、PHP 程式碼。這個屬性已經得到比較新的 Firefox、Safari、Chrome 瀏覽器支持,而且我們可以透過綜合的可替代的技術來模擬實現這個效果——甚至是 IE 瀏覽器。

本文中,我們將使用標準測試圖片 Lena Söderberg (譯者註:Lena 這張美女照片,被作為圖片壓縮的標準測試用圖片)作為演示,使用 CSS 將其轉換成黑白圖片。在下面我將講解如何使用 CSS 的這個功能來實現調整色調、模糊、亮度、對比和一些其他的效果。效果圖:
201659103649279.jpg (766×383)

CSS3 的灰階濾鏡

使用 CSS3 來稀釋一個圖片的顏色,再簡單不過了。我們可以把這個 CSS 語句寫成一個類,這樣遇到想要效果的圖片,直接加上個類別就可以了。

img.desaturate { filter: grayscale(100%); }

當然,目前的瀏覽器在使用CSS3 的時候,要加上他們自己的瀏覽器功能實驗性前綴,所以,我們首先要做的,就是寫上瀏覽器的前綴:

img.desaturate { filter: grayscale(100%);   
-webkit-filter: grayscale(100%);   
-moz-filter: grayscale(100%);   
-ms-filter: grayscale(100%);   
-o-filter: grayscale(100%);   
}

想要用在某個圖片上很簡單,加上一個類別:

<img src=lena-söderberg.png alt="Lena Söderberg" style=width:512px;height:512px class=desaturate>

這就可以了。 ## 增加一個 SVG 的濾鏡效果 這個功能目前只在 Chrome 18 有效,其他瀏覽器馬上就會增加支援。為了在 Firefox 4 中得到相同的效果,我們可以需要使用 SVG 濾鏡。我把新建了一個單獨的檔案 的 saturate.svg ,程式碼如下:

<svg version="1.1" xmlns="http://www.w3.org/2000/svg">   
<filter id="greyscale">   
<feColorMatrix type="matrix" values="0.3333 0.3333 0.3333 0 0 
0.3333 0.3333 0.3333 0 0 
0.3333 0.3333 0.3333 0 0 
0  0  0  1 0"/>   
</filter>   
</svg>

不要被這段 SVG 程式碼嚇住了——雖然上面的矩陣數列有點複雜。這段程式碼我推薦你直接複製貼上成一個通用的「小檔案」。我會再寫一篇文章詳細介紹上面矩陣變化,在這裡不再贅述。加上上面的SVG 檔案引用,我們要插入HTML 頁面的CSS 程式碼如下:

img.desaturate{   
filter: grayscale(100%);   
-webkit-filter: grayscale(100%); -moz-filter: grayscale(100%);   
-ms-filter: grayscale(100%); -o-filter: grayscale(100%);   
filter: url(desaturate.svg#greyscale);   
}

為IE 做相容:

##到現在我們的程式碼可以相容於未來的瀏覽器,和最新版的Chrome 、 Firefox 4 。為了讓IE 6-9 加入相容列表,我們需要使用微軟的笨拙但是有效的filter 濾鏡:

img.desaturate{   
filter: grayscale(100%);   
-webkit-filter: grayscale(100%); -moz-filter: grayscale(100%);   
-ms-filter: grayscale(100%); -o-filter: grayscale(100%);   
filter: url(desaturate.svg#greyscale);   
filter: gray;   
}

如果你還想做老版本的Webkit 核心瀏覽器的兼容:

img.desaturate{   
filter: grayscale(100%);   
-webkit-filter: grayscale(100%); -moz-filter: grayscale(100%);   
-ms-filter: grayscale(100%); -o-filter: grayscale(100%);   
filter: url(desaturate.svg#greyscale);   
filter: gray;   
-webkit-filter: grayscale(1);   
}

如果你想要在所有的瀏覽器中實現這個視覺效果(假設你的訪客都支援JavaScript)你可以使用jQuery 或Greyscale.js 來修改你的圖片,使其去色。


上面咱寫的 CSS 程式碼可以讓我們不需要使用 PhotoShop 就可以把圖片變成黑白的。使用 CSS 來實現這個功能,可以非常容易修改:例如,你可以看到當我們把去色程度參數從 100% 變成 50% 的時候圖片會是原色和黑白融合在一起的效果。

其他效果:

此外,在黑白照片上還可以加入其他的一些filter的效果有:

-webkit-filter:blur(5px);  //模糊,此处为5像素   
-webkit-filter:sepia(0.5);  //叠加褐色,取值范围0-1,此处表示50%的褐色   
-webkit-filter:brightness(0.5);  //亮度,取值范围0-1,5倍亮度(数字为0时为正常样式,为1时表示的是100%亮度,无法看到图片)   
-webkit-filter:hue-rotate(30deg); //色相(按照色相环进行旋转,顺时针方向,红-橙-黄-黄绿-绿-蓝绿-蓝-蓝紫-紫-紫红-红)此处为叠加黄色滤镜   
-webkit-filter:invert(1);  //反色,取值范围0-1,0为原图,1为彻底反色之后,0.5为灰色   
-webkit-filter:saturate(4);  //饱和度,取值范围0~*,0为无饱和度,1为原图,值越高饱和度越大   
-webkit-filter:contrast(2);  //对比度,取值范围0~*,0为无对比度(灰色),1为原图,值越高对比度越大   
-webkit-filter:opacity(0.8);  //透明度,取值范围0~1,0为全透明,1为原图   
-webkit-filter:drop-shadow(17px 17px 20px black); //阴影

以上就是本文的全部內容,希望對大家的學習有幫助,更多相關內容請關注PHP中文網!


相關推薦:

CSS實作有立體感的橫向按鈕式選單效果

如何利用CSS3實作3D翻書效果

CSS3滑鼠移入圖片動態提示效果

#

以上是使用CSS3編寫灰階濾鏡來製作黑白照片效果的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
css怎么隐藏元素但不占空间css怎么隐藏元素但不占空间Jun 01, 2022 pm 07:15 PM

两种方法:1、利用display属性,只需给元素添加“display:none;”样式即可。2、利用position和top属性设置元素绝对定位来隐藏元素,只需给元素添加“position:absolute;top:-9999px;”样式。

原来利用纯CSS也能实现文字轮播与图片轮播!原来利用纯CSS也能实现文字轮播与图片轮播!Jun 10, 2022 pm 01:00 PM

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯CSS也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

css3什么是自适应布局css3什么是自适应布局Jun 02, 2022 pm 12:05 PM

自适应布局又称“响应式布局”,是指可以自动识别屏幕宽度、并做出相应调整的网页布局;这样的网页能够兼容多个不同的终端,而不是为每个终端做一个特定的版本。自适应布局是为解决移动端浏览网页而诞生的,能够为使用不同终端的用户提供很好的用户体验。

css3如何实现鼠标点击图片放大css3如何实现鼠标点击图片放大Apr 25, 2022 pm 04:52 PM

实现方法:1、使用“:active”选择器选中鼠标点击图片的状态;2、使用transform属性和scale()函数实现图片放大效果,语法“img:active {transform: scale(x轴放大倍数,y轴放大倍数);}”。

css3动画效果有变形吗css3动画效果有变形吗Apr 28, 2022 pm 02:20 PM

css3中的动画效果有变形;可以利用“animation:动画属性 @keyframes ..{..{transform:变形属性}}”实现变形动画效果,animation属性用于设置动画样式,transform属性用于设置变形样式。

css3怎么设置动画旋转速度css3怎么设置动画旋转速度Apr 28, 2022 pm 04:32 PM

在css3中,可以利用“animation-timing-function”属性设置动画旋转速度,该属性用于指定动画将如何完成一个周期,设置动画的速度曲线,语法为“元素{animation-timing-function:速度属性值;}”。

一文了解CSS3中的新特性 ::target-text 选择器一文了解CSS3中的新特性 ::target-text 选择器Apr 12, 2022 am 11:24 AM

本篇文章带大家一起深入了解一下CSS3中的新特性::target-text 选择器,聊聊该选择器的作用和使用方法,希望对大家有所帮助!

css3线性渐变可以实现三角形吗css3线性渐变可以实现三角形吗Apr 25, 2022 pm 02:47 PM

css3线性渐变可以实现三角形;只需创建一个45度的线性渐变,设置渐变色为两种固定颜色,一个是三角形的颜色,另一个为透明色即可,语法“linear-gradient(45deg,颜色值,颜色值 50%,透明色 50%,透明色 100%)”。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具