data:image/s3,"s3://crabby-images/488e0/488e07843e6a10d954df4db8df4a336798398b57" alt=""
css3的滤镜真的非常强大,上面的效果,之前很难实现,现在一行代码搞定。其实css3的很多效果,感觉都是根据ps来的,例如投影、渐变等等和ps设置几乎一致。
Filters主要是运用在图片上,以实现一些特效。(尽管他们也能运用于video上),不过我们在些只来讨论图片上的运用。
filter 滤镜的语法:
选择器 { filter: none | <filter-function > [ <filter-function> ]* }其默认值是none,他不具备继承性,其中filter-function一个具有以下值可选:
grayscale灰度 sepia褐色(求专业指点翻译) saturate饱和度 hue-rotate色相旋转 invert反色 opacity透明度 brightness亮度 contrast对比度 blur模糊 drop-shadow阴影浏览器的兼容性:
目前支持这个属性的浏览器少得可怜,现在只是webkit支持,而且只有webkit nightly版本和Chrome 18.0.976以上以上版本才支持,所以说,你要是想看到效果就需要下载这两个版本中的一个,我使用的是Google Chrome Canary。
下面,我们一个一个演示效果。为了方便讲解,我们首先假设有一个class为normal的图片:
<img class="normal" src="images/filter.jpg" />一、grayscale灰度
使用这个特效,会把图片变成灰色的,也就是说你的图片将只有两种颜色“黑色”和“白色”
.grayscale{ -webkit-filter:grayscale(1); filter:grayscale(1); }默认值:100%,
如果你在grayscale()中没有任何参数值,将会以“100%”渲染。其效果下图所示:
data:image/s3,"s3://crabby-images/fb901/fb901feef4836a8485f9900eef24a420ba41cc1f" alt=""
二、sepia
sepia,老旧照片效果
.sepia{ -webkit-filter:sepia(1); filter:sepia(1); }默认值:100%,
如果你在sepia()中没有任参数值,将会以“100%”渲染,具体效果如下:
data:image/s3,"s3://crabby-images/eaf77/eaf773ef2b721c8994422ae9f22689ba1f7b8a4f" alt=""
三、saturate饱和度
saturat是用来改变图片的饱和度
.saturate{ -webkit-filter:saturate(0.5); filter:saturate(0.5); }默认值:100%,
data:image/s3,"s3://crabby-images/93659/936593949a77ac5dac533b9f48bd260f24368602" alt=""
如果我们将其值变大到300%:
.saturate{ -webkit-filter:saturate(3); filter:saturate(3); }
data:image/s3,"s3://crabby-images/b805e/b805ef801447dd29fe20e8542ba27d85a509e721" alt=""
四、hue-rotate色相旋转
hue-rotate用来改变图片的色相
.hue-rotate{ -webkit-filter:hue-rotate(90deg); filter:hue-rotate(90deg); }默认值:0deg
data:image/s3,"s3://crabby-images/8d1fb/8d1fb6cf6442b11a84e72a41158abcc0094d5993" alt=""
五、invert反色
invert做出来的效果就像是我们照相机底面的效果一样
.invert{ -webkit-filter:invert(1); filter:invert(1); }默认值:100%
data:image/s3,"s3://crabby-images/92032/92032a7e19fe2213004be3ddf3d8554b5f13b8df" alt=""
六、opacity透明度
改变图片的透明度
.opacity{ -webkit-filter:opacity(.2); filter:opacity(.2); }默认值:100%
data:image/s3,"s3://crabby-images/ece4c/ece4cf02ec88e3e721f7b20c4b3d3b4fec489989" alt=""
七、brightness亮度
改变图片的亮度
.brightness{ -webkit-filter:brightness(.5); filter:brightness(.5); }默认值:100%
data:image/s3,"s3://crabby-images/e3f56/e3f569a4b9cdc62501080f916877c549df025a1d" alt=""
八、contrast对比度
改变图片的对比度
.contrast{ -webkit-filter:contrast(2); filter:contrast(2); }默认值:100%
data:image/s3,"s3://crabby-images/118dc/118dcfbdea7a4bbb697c527bc00717d37d5e4bfd" alt=""
九、blur模糊
改变图片的清晰度,就是PS里面的高斯模糊
.blur{ -webkit-filter:blur(3px); filter:blur(3px); }默认值:0
data:image/s3,"s3://crabby-images/7bdd6/7bdd62718e1ae3ec8f255e3b9e4ed47f67c9bdc9" alt=""
十、drop-shadow阴影
这个很像box-shadow一样的效果,给图片加阴影效果
.drop-shadow{ -webkit-filter:drop-shadow(5px 5px 5px #ccc); filter:drop-shadow(5px 5px 5px #ccc); }
data:image/s3,"s3://crabby-images/6570f/6570fce2f86d48dedee71ab8f3c15163d885fba2" alt=""
以上,为css3 的 filter 滤镜效果,当然,也可以综合使用:
.custom{ -webkit-filter:saturate(5) hue-rotate(500deg) grayscale(0.3) sepia(0.7) contrast(1.5) invert(0.2) brightness(.9); filter:saturate(5) hue-rotate(500deg) grayscale(0.3) sepia(0.7) contrast(1.5) invert(0.2) brightness(.9); }
data:image/s3,"s3://crabby-images/31e37/31e37d3c16765bb0e053a33823d1cc79a95e74bc" alt="CSS3 Filter滤镜 CSS3 Filter滤镜"