A CSS filter is a coding technique used to hide or show CSS markup depending on the browser, version number, or capabilities. Browsers have different interpretations of CSS behavior and different levels of support for the W3C standards. CSS filters are sometimes used to achieve consistent layout appearance in multiple browsers that do not have compatible rendering.

大致的意思就是CSS的滤镜的存在就是为了解决不同浏览器能够显示一致的网页效果的技术。在最大程度上保证了兼容性和一致性。关于CSS滤镜的详细的介绍,大家可以参照维基百科https://en.wikipedia.org/wiki/CSS_filter


单纯的讲解关于滤镜的知识会显得有些无趣,那么我们不妨从代码着手,来个top-down的学习方式,来体验一把CSS3滤镜的神奇魅力。

html篇

首先来贴出模板的HTML代码,为了下面的演示方便。

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>前端</title>
     <link rel="stylesheet" type="text/css" href="attachment.css">
</head>
<body>
<br>
<img id="img" src="http://avatar.csdn.net/0/8/F/1_marksinoberg.jpg"/>
<img id="img_temp" class="imgfilter" src="http://avatar.csdn.net/0/8/F/1_marksinoberg.jpg"/>
</body>
</html>

明眼的你也看到了博主这里引用了一个外部的css样式文件,这样可以使得代码的整洁性得到些许的提高,后续维护起来也是比较的方便,建议大家以后也尽量这么干,争取做到样式文件和html代码的分离。

样式篇

attachment.css文件其实内容很少,只涉及到了博主今天要分享的关于滤镜效果的很简短的代码。大致的“框架”如下。

.imgfilter {
-webkit-filter:/*针对于chrome,Safari厂商*/
filter:/*标准的css滤镜写法*/
}

由于目前而言,CSS3还没有被真正的标准化,所以不同厂商之间对其的支持还有点不太一致,但是对于将来而言都将不是问题。博主这里为了更加的普适,就是用标准的filter的方式了。

grayscale

灰度化。见名知意。图片变灰咯。默认值为1,实现的效果就是给图片加上一层灰色状的效果。

从0-1的过程为灰度逐渐增强的过程。

filter: grayscale(0.5);

实现的效果如下:


sepia

老照片效果。默认的参数为1,也就是会显示老照片的效果。这点可以应用到图片处理的应用上面。

filter: sepia(0.7);

实现的效果:


saturate

饱和度。给人的感觉就是图片的“浓度”(这里断章取义的使用了这个名词)问题,我们的直观感受就是图片中颜色的深度以及彩度的变化。

filter: saturate(0.3);

实现的效果:


hue-rotate

色相旋转。默认为0deg,效果即为原图效果。需要注意的是一下情况。

  • 0deg == 360deg
  • 180deg == -180deg
filter: hue-rotate(180deg);

实现的效果:


invert

反相。想必大家都见过或者听闻过早期的照片的底片吧。类似地,反相的效果就是翻转原图的像素,实现一个色度相反的效果。

我个人感觉:

  • 默认为10%0,效果为反相;
  • 0-0.5之间的相当于加上了一层灰影,较适合做蒙皮特效,比如hover的时候给照片加上灰影;
  • 0.5的时候为全灰,无法正常显示图片,可以作为刮刮乐的填色效果
  • 0.5-1为反相显现阶段,逐渐加深的效果。
filter: invert(0.75);

实现的效果:


opactiy

一想到透明度,大家首先可能想到的就是玻璃吧。是的,附加了透明度效果的图片可以被赋予很多奇幻的特效。

默认为1,不透明效果。

0-1为不透明度渐现的过程,0 的时候图片全透明,不可见。

filter: opacity(0.56);

实现的效果:


brightness

亮度。一个很神奇的效果。你是否想到了太阳东升西落,大地由白入黑的一天呢?是的应用了亮度的话,我们其实是可以做出这样的效果的。

默认为100%,效果不变。0的时候图片全黑。

0-1的过程为亮度逐渐增强的过程。

filter: brightness(0);

实现的效果:


contrast

对比度。人与人之间可以相互的对比。图片同样是如此。对比度给人的明显的感觉就是图片色彩的艳丽程度,值越大给人的感觉越是浮夸。但是这并不代表其用处不大。在一些类似于油画作品的展示上,还是很有效果滴。

filter: contrast(0.7);

实现的效果:


blur

模糊度。说实话,一提到模糊我们就会想到毛玻璃不是。确实是这样的一个效果。前提是运用得当的话。

默认为0px,效果为原图。0-infinite的过程为模糊程度渐强的过程,注意是以px为单位进行的变换哦。

filter: blur(10px);

实现的效果:


drop-shadow

shadow给人的印象就是加个阴影什么的了吧。事实上还真的就是这样。类似于box-shadow效果,为图片添加阴影效果,可以根据颜色的拓展实现图片的立体效果。

filter: drop-shadow(1px 1px 2px #6e6e6e);

实现的效果:


综合小效果

最后给大家来个综合一点的小滤镜合集吧。

filter: drop-shadow(2px 2px 3px #6e6e6e) blur(1px) opacity(0.3) brightness(1.2);

再加上一个图片hover的样式效果。

.img:hover {
    transform: scale(2.8);
    animation-duration: 2s;
    border-radius: 28px;
    box-shadow: 2px 2px 2px #6e6e6e;
}

最终的效果。

总结

回顾一下,本文主要是介绍了相关于CSS3的滤镜特效的实例,附带了一些效果图。

单个的效果起到的作用不大,整合起来写一个自己的滤镜样式小工具,真正的运用到实际的项目开发中,才是目的。

CSS3 滤镜学习的更多相关文章

  1. CSS3滤镜

    今天在办公室亲眼目睹了同事使用CSS3滤镜为一张漂亮的照片轮廓加上了阴影,瞬间亮瞎了我的的双眼,见笑了. 所以也迅速尝试使用CSS3滤镜让最新出炉的MUI LOGO也性感一把,试图来愉悦一下大家的双眼 ...

  2. CSS3魔法堂:CSS3滤镜及Canvas、SVG和IE滤镜替代方案详解

    一.前言    IE特有的滤镜常常作为CSS3各种新特性的降级处理补充,而Adobe转向HTML5后与Chrome合作推出CSS3的Filter特性,因此当前仅Webkit内核的浏览器支持CSS3 F ...

  3. Filter Effects - 使用 CSS3 滤镜处理图片

    CSS3 Filter(滤镜)属性提供了提供模糊和改变元素颜色的功能.CSS3 Fitler 常用于调整图像的渲染.背景或边框显示效果.这里给大家分享的这个网站,大家可以体验下 CSS3 对图片的处理 ...

  4. tiltShift.js - CSS3 滤镜实现移轴镜头效果

    tiltShift.js 是一款很棒的 jQuery 插件,使用 CSS3 图片滤镜来实现照片的移轴镜头效果.使用非常简单,使用 data 属性配置参数.温馨提示:为保证最佳的效果,请在 IE10+. ...

  5. 使用CSS3滤镜让图片反转颜色

    CSS提供的滤镜也是一大亮点,我一直痴迷其中,有些滤镜的效果很有用,可是有些的滤镜效果可能只是为了玩玩儿,CSS常见的滤镜有这些:grayscale, blur, sepia,所有常见的过滤器.但是如 ...

  6. CSS3魔法堂:CSS3滤镜及Canvas、SVG和IE滤镜替代方案详解[转]

    一.前言    IE特有的滤镜常常作为CSS3各种新特性的降级处理补充,而Adobe转向HTML5后与Chrome合作推出CSS3的Filter特性,因此当前仅Webkit内核的浏览器支持CSS3 F ...

  7. 【CSS3】CSS3 滤镜实现

    作者:^_^肥仔John      来源:CSS3魔法堂:CSS3滤镜及Canvas.SVG和IE滤镜替代方案详解 IE特有的滤镜常常作为CSS3各种新特性的降级处理补充,而Adobe转向HTML5后 ...

  8. HTMl5/CSS3/Javascript 学习推荐资源

    HTMl5/CSS3/Javascript 学习推荐资源 前端的定义应该是数据内容的展示,在国内大家都觉得前端只是HTML+CSS+Javascript,但是实际上与展示有关的都是前端,所以Ruby/ ...

  9. css3 3d学习心得

    css3 3d学习心得 卡片反转 魔方 banner图 首先我们要学习好css3 3d一定要有一定的立体感 通过这个图片应该清楚的了解到了x轴 y轴 z轴是什么概念了. 首先先给大家看一个小例子: 卡 ...

随机推荐

  1. OpenGL 背面剔除

    在OpenGL种可使用glEnable(GL_CULL_FACE)开启背面剔除功能,即把那些我们看不见的面删除.但在剔除之前我们需要定义正面和背面,这个可以用法线来理解.在数学学科中,法线是用右手法则 ...

  2. ASP.NET Core + Docker +Jenkins 实现持续集成

    1.新建一个ASP.NET Core MVC应用程序: 2.将其上传到git: 3.建立Jenkins任务 (1)选择"新建任务",输入任务名称,选择"自由风格项目&qu ...

  3. python3 Serial 串口助手的接收读取数据

    其实网上已经有许多python语言书写的串口,但大部分都是python2写的,没有找到一个合适的python编写的串口助手,只能自己来写一个串口助手,由于我只需要串口能够接收读取数据就可以了,故而这个 ...

  4. 机器学习技法:08 Adaptive Boosting

    Roadmap Motivation of Boosting Diversity by Re-weighting Adaptive Boosting Algorithm Adaptive Boosti ...

  5. Scriplet的三种代码

    Jsp中注释分为显示注释和隐式注释, 显示注释 -- 可以通过查看源代码看到 <!-- 第一种注释 -->  隐式注释 --  源代码中看不到 <%--jsp注释---%> & ...

  6. swoole_event_add实现异步

    swoole提供了swoole_event_add函数,可以实现异步.此函数可以用在Server或Client模式下. 实现异步tcp客户端 示例: <?php $start_time = mi ...

  7. [UOJ]#33. 【UR #2】树上GCD

    题目大意:给定一棵有根树,边长均为1,对于每一个i,求树上有多少个点对,他们到lca距离的gcd是i.(n<=200,000) 做法:先容斥,求出gcd是i的倍数的点对,考虑长链剖分后从小到大合 ...

  8. python flask 基础入门

    1. Flask 中的Hello World! 在使用pycharm创建一个Flask项目后,将会默认创建一个flask的app,这里来讲下每行代码表示的意义,代码入下 from flask impo ...

  9. python 2week

    本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 定义列表 1 names =  ...

  10. TensorFlow 聊天机器人开源项目评测第一期:DeepQA

    聊天机器人开源项目评测第一期:DeepQA https://github.com/Conchylicultor/DeepQA 用 i5 的笔记本早上运行到下午,跑了 3 轮的结果,最后效果并不理想.官 ...