filter

  • 将模糊或者颜色偏移等图像效果用于元素,通常用于调整图像,背景和边框的渲染
  • css 标准中已内置一些预定义效果的函数,也可通过url使用SVG滤镜

语法

/* URL to SVG filter */
filter: url(filter.svg#id); /* <filter-function> values */
filter: blur(5px);
filter: brightness(0.4);
filter: contrast(200%);
filter: drop-shadow(16px 16px 20px blue);
filter: grayscale(50%);
filter: hue-rotate(90deg);
filter: invert(75%);
filter: opacity(25%);
filter: saturate(30%);
filter: sepia(60%); /* Multiple filters */
filter: contrast(175%) brightness(3%); /* Global values */
filter: inherit;
filter: initial;
filter: unset;

滤镜属性

  • 需要设定某一函数的值。如果该值无效,函数返回“none“。

url()

  • url 函数接收一个XML文件,该文件是一个SVG filter,并且包含一个ID值 来指定哪一个滤镜
filter:url(resources.svg#c1)

blur()

  • 定义模糊度
  • 可以接受css长度单位,不接受百分比
filter:blur(5px)

brightness()

  • 定义亮度
  • 默认为1, 1-0 逐渐变暗,1以上逐渐变亮
  • 可以是百分比, 不能为负数

contrast()

  • 定义对比度
  • 1-0 逐渐变成灰黑 1以上颜色逐渐变艳丽
  • 可以是百分比, 不能为负数

drop-shadow()

  • 定义阴影效果,合成在图像下面,
  • 参数 和 shadow, box-shadow 相似
  • shadow, box-shadow属性不同之处在于通过filter,一些浏览器为了提升性能会提供硬件加速。

    传参顺序从左至右:

    1. 水平偏移距离正值右偏,负值左偏(offset-x)。必传
    2. 垂直偏移距离正值向下偏,负值上偏(offset-y)。必传
    3. 一个length值(表示距离尺寸的一种css数据格式) 值越大,越模糊阴影会变得更大更淡.)不允许负值 默认为0 (blur-radius)可选
    4. 一个length值,正值会使阴影扩张和变大,负值会是阴影缩小,默认 0
    5. color 色值,在Gecko (Firefox), Presto (Opera)和Trident (Internet Explorer)中, 会应用color 属性的值,颜色值省略,WebKit中阴影是透明的。
filter:drop-shadow(16px 16px 10px black)

grayscale()

  • 定义灰度
  • 取值0 - 1的数值之间,可设置百分比,不可为负数
filter:grayscale(50%);

hue-rotate()

  • 定义颜色,色相旋转调整
  • 单位 deg
  • 可为负值
filter: hue-rotate(90deg)

invert()

  • 反向输入图,定义转换比例
  • 默认0 0%和100%之间,则是效果的线性乘子。
filter: invert(100%)

opacity()

  • 转化图像的透明程度
  • 类似于css的opacity属性
  • 1-0 逐渐变透明,支持百分比 ,不能为负数
  • 和opacity属性不同之处在于通过filter,一些浏览器为了提升性能会提供硬件加速。
filter: opacity(50%)

saturate()

  • 定义图像饱和度
  • 1-0 至完全不包和,1为正常, 1以上饱和度更高,更艳丽,支持百分比
filter:saturate(369%)

sepia()

  • 定义深褐色的色度
  • 0 - 1 逐渐变为深褐色 支持百分比,不支持负数
filter: sepia(100%)

组合函数

  • 可以将任意数量的函数一起控制渲染,其中有一个不符合规范将全部失效
filter:sepia(100%) saturate(369%) opacity(50%)

兼容性

CSS filter 属性的更多相关文章

  1. CSS filter 有哪些神奇用途

    背景 基本概念 CSS filter 属性将模糊或颜色偏移等图形效果应用于元素形成滤镜,滤镜通常用于调整图像,背景和边框的渲染.它的值可以为 filter 函数 <filter-function ...

  2. CSS中filter属性的使用

    filter 属性定义了元素的可视效果 blur 给图像设置高斯模糊."radius"一值设定高斯函数的标准差,或者是屏幕上以多少像素融在一起, 所以值越大越模糊. 如果没有设定值 ...

  3. 20190614笔记(颜色透明度,css,filter,滤镜,计算属性,json和formData转换)

    今天忙里偷闲,把最近做的笔记做一下整理. 1.json和formData互相转换 适用场景:对接后台接口.后台接口写的因人而异,不同的人有不同的风格.比如,文件上传,原本就是formData格式,有人 ...

  4. [转] CSS direction属性简介与实际应用 ---张鑫旭

    一.用的少并不代表没有用 至少,在我接触的这么多项目里,没有见到使用过CSS direction属性做实际开发的. 为什么呢?是因为direction长得丑吗? 虽然说direction确实其貌不扬, ...

  5. css filter详解

    css filter详解 filter 属性详解 属性 名称 类型 说明 grayscale 灰度 值为数值 取值范围从0到1的小数(包括0和1) sepia 褐色 值为数值 取值范围从0到1的小数( ...

  6. div+css的属性

    div+css的属性 gCascading Style Sheet 层叠式样式表 ==> 层叠样式表 Internal Style Sheet 内部样式表 External Style Shee ...

  7. 【转载】CSS direction属性简介与实际应用

    文章转载自 张鑫旭-鑫空间-鑫生活 http://www.zhangxinxu.com/wordpress/ 原文链接:http://www.zhangxinxu.com/wordpress/?p=5 ...

  8. 【css3】使用filter属性实现改变svg图标颜色

    1.兼容性: 2.应用场景:新增页面上传svg图标后,更改图标颜色后,在列表页面展示色值改后的svg图标. 3.解决方案:使用filter属性中的 drop-shadow,drop-shadow滤镜可 ...

  9. WebRTC与CSS滤镜(CSS filter)

    我们知道了如何使用WebRTC打开摄像头,可以截取视频帧并且用canvas显示出来. 本文将滤镜与视频结合.给视频加上一层滤镜.主要使用到的是filter属性. canvas与滤镜 先来看filter ...

随机推荐

  1. 误删除$ORACLE_HOME/dbs下的参数文件、密码文件,如何快速重建

    [oracle@11g dbs]$ pwd/home/oracle/app/oracle/product/11.2.0/dbhome_1/dbs[oracle@11g dbs]$ lltotal 24 ...

  2. LINUX socket网络编程

    1. 网络中进程之间如何通信 进 程通信的概念最初来源于单机系统.由于每个进程都在自己的地址范围内运行,为保证两个相互通信的进 程之间既互不干扰又协调一致工作,操作系统为进程通信提供了相应设施,如 U ...

  3. ClientSocket.h ClientSocket.cpp

    ClientSocket.h #pragma once // CClientSocket 命令目标 #include "ClientProDlg.h" #include " ...

  4. Redux API之applyMiddleware

    applyMiddleware(...middlewares) 使用包含自定义功能的 middleware 来扩展 Redux 是一种推荐的方式.Middleware 可以让你包装 store 的di ...

  5. qpython 读入数据问题: EOF error with input / raw_input

    直接使用input会报错 EOF error with input / raw_input 原因是在qpy里console mode 命令行模式不是完全和pc上的命令行一致,所以input和raw_i ...

  6. Ubuntu下CodeBlocks更改调试终端

    Ubuntu下CodeBlocks更改调试终端   Ubuntu下的CodeBlocks自带的调试终端xterm不能进行复制粘贴操作,更换调试终端就可以解决了,就是把ubuntu下的gnome-ter ...

  7. 虚拟机出现ping DUP

    在主机的网络连接里,停用虚拟网卡vmnet1和vmnet8,再启用虚拟网卡vmnet1和vmnet8.

  8. 【转载】Eclipse:Android开发中如何查看System.out.println的输出内容

    Android开发中在代码中通过System.out.println的输出内容不知道去哪了,在console视图中看不到.而通过Log.i之类的要在Logcat视图中看到,夹杂了太多的其它App及底层 ...

  9. jquery获取元素对应高度

    https://www.cnblogs.com/sntetwt/p/3823592.html 获取点击元素距离页面的高度 $(select).offset().top - $(document).sc ...

  10. C++ com

    http://www.cnblogs.com/hlxs/p/3783920.html 昨天看了<COM本质论>的第一章"COM是一个更好的C++",觉得很有必要做一些笔 ...