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()
filter:blur(5px)
brightness()
- 定义亮度
- 默认为1, 1-0 逐渐变暗,1以上逐渐变亮
- 能够是百分比, 不能为负数
contrast()
- 定义对比度
- 1-0 逐渐变成灰黑 1以上颜色逐渐变艳丽
- 能够是百分比, 不能为负数
drop-shadow()
- 定义阴影效果,合成在图像下面,
- 参数 和
shadow
, box-shadow
类似
- 和
shadow
, box-shadow
属性不一样之处在于经过filter,一些浏览器为了提高性能会提供硬件加速。
传参顺序从左至右:
- 水平偏移距离正值右偏,负值左偏(offset-x)。
- 垂直偏移距离正值向下偏,负值上偏(offset-y)。
- 一个length值(表示距离尺寸的一种css数据格式) 值越大,越模糊阴影会变得更大更淡.) 默认为0 (blur-radius)
- 一个length值,正值会使阴影扩张和变大,负值会是阴影缩小,默认 0
- 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()
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%)
兼容性
