加入收藏 | 设为首页 | 会员中心 | 我要投稿 辽源站长网 (https://www.0437zz.com/)- 云专线、云连接、智能数据、边缘计算、数据安全!
当前位置: 首页 > 服务器 > 系统 > 正文

css中filter属性和backdrop-filter的应用与区别详解

发布时间:2020-09-23 22:09:44 所属栏目:系统 来源:网络整理
导读:这篇文章主要介绍了css中filter属性和backdrop-filter的应用与区别详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的
副标题[/!--empirenews.page--]

filter和backdrop-filter具有一定区别:

Filter不仅仅作用于当前元素,后代元素也会继承这个属性,作用于一个空背景元素则没有效果。

backdrop-filter 是使透过该层的底部元素模糊化

backdrop-filter属性可以让你为一个元素后面区域添加图形效果(如模糊或颜色偏移)。 因为它适用于元素 背后 的所有元素,为了看到效果,必须使元素或其背景至少部分透明。

backdrop-filter目前兼容性不佳,尤其是安卓移动端。

filter属性

我们先来说说filter属性,css3中的filter属性简单易用且强大,这些效果作用在图片上可以实现一些特有的特效。而且目前主流浏览器都已经支持了这个属性。

从上图来看,大部分浏览器的兼容性都是不错的。

我们还是直接用代码来看。

body { display: flex; width: 100%; height: 100vh; align-items: center; justify-content: center; } .img { width: 500px; height: 500px; }

<body> <img src=http://www.jb51.net/css/"./img/kyoto.jpg" class="img filter"> </body>

我们定义一张照片在网页中央,先不做任何处理。

这是原图呈现的效果。

接下来我们看filter的几个比较重要的属性。

opacity

opacity 代表透明度,值为0-1之间的小数,值越大透明度越低。

.filter{ filter: opacity(.3); }

如下图展示:

blur

blur可以设置图片使用高斯模糊效果,单位值是px。所谓高斯模糊,就是指一个图像与二维高斯分布的概率密度函数做卷积。

简单点说:高斯模糊常常用来模拟人眼中的物体变远、变快的效果。在照片处理中,我们常常将背景施以高斯模糊,使得背景仿佛变远了,从而突出前景的人物或物体。一些所谓“先拍照,后对焦”的技术利用的也是高斯模糊这个效果。若想弄出视点飞快移动的效果,也可以对背景使用高斯模糊。

.filter { filter: blur(2px); }

invert

invert 可以设定反色, 值为0-1之间的小数。

.filter { filter: invert(1); }

saturate

saturate可以设定照片饱和度,取值范围为数字即可,默认值1,即100%。

.filter { filter: saturate(5); }

比如这里我设置饱和度是500%,如下图效果:

grayscale

grayscale代表灰度,取值在0-1之间,。

.filter { filter: grayscale(1); }

下图是grayscale为1,即灰度是100%时候的效果。

另外,如果使用该效果参数里没值的话,也会默认以1,即100%为值取值,即如下面设置。

.filter { filter: grayscale(); }

sepia

sepia代表的是照片褐色,类似于大部分美图软件里的怀旧功能的那种效果,取值也是0-1,和grayscale一样。

.filter { filter: sepia(1); }

hue-rotate

hue-rotate用来改变图片的色相,默认值为0deg,取值是角度(angle)。

.filter { filter: hue-rotate(90deg); }

hue-rotate一般配合css动画使用,可以呈现不一样效果。比如电池充电的动画,随着高度在纵坐标上移,hue-rotate的值逐渐改变,这里因为无法上传git图片,只能看下静态图片:

brightness

brightness可以改变图片的亮度,默认值为100%,即1。

.filter { filter: brightness(2); }

contrast

contrast代表对比度,这个属性取值和饱和度saturate类似,取值也是数字。

.filter { filter: contrast(2.5); }

这里我们演示对比度是250%时候的效果,如下图:

drop-shadow

drop-shadow这个属性类似于box-shadow,给图片加阴影。

.filter { filter: drop-shadow(20px 20px 10px 20px #000) /**水平阴影位置,垂直阴影位置,模糊距离,阴影颜色**/ }

backdrop-filter属性

我们回过头来在看backdrop-filter属性以下几点特点

backdrop-filter 是使透过该层的底部元素模糊化

backdrop-filter属性可以让你为一个元素后面区域添加图形效果(如模糊或颜色偏移)。 因为它适用于元素 背后 的所有元素,为了看到效果,必须使元素或其背景至少部分透明。

backdrop-filter目前兼容性不佳,尤其是安卓移动端。

上面这些只看文字不好理解,我直接上代码:

(编辑:辽源站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

推荐文章
    热点阅读