栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > Html/CSS > CSS教程

滤镜、图像混合效果如何在css 中实现?

CSS教程 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

滤镜、图像混合效果如何在css 中实现?

用 Photoshop 的都有用到滤镜来处理图片,那在前端如何用代码来实现呢?
这就得用到 css 滤镜 了。
css 滤镜兼容。
背景知识:
css 滤镜语法:

filter: none | blur() | brightness() | contrast() | drop-shadow() | 
		grayscale() | hue-rotate() | invert() | opacity() | 
		saturate() | sepia() | url();

css 滤镜函数:

url():URL函数接受一个XML文件,该文件设置了 一个SVG滤镜,且可以包含一个锚点来指定一个具体的滤镜元素。如:filter: url(svg-url#element-id)

grayscale(%):灰度。值定义转换的比例。值为100%则完全转为灰度图像,值为0%图像无变化。值在0%到100%之间,则是效果的线性乘子。若未设置,值默认是 0。

sepia(%):将图像转换为深褐色。值定义转换的比例。值为100%则完全是深褐色的,值为0%图像无变化。值在0%到100%之间,则是效果的线性乘子。若未设置,值默认是0。

saturate(%):饱和度。值定义转换的比例。值为0%则是完全不饱和,值为100%则图像无变化。其他值,则是效果的线性乘子。超过100%的值是允许的,则有更高的饱和度。 若值未设置,值默认是1。

hue-rotate(deg):色相旋转。值为色环角度值。值为0deg,则图像无变化。若值未设置,默认值是0deg。该值虽然没有最大值,超过360deg的值相当于又绕一圈。

invert(%):反转输入图像。值定义转换的比例。100%的价值是完全反转。值为0%则图像无变化。值在0%和100%之间,则是效果的线性乘子。 若值未设置,值默认是0。

opacity(%):透明度。值定义转换的比例。值为0%则是完全透明,值为100%则图像无变化。值在0%和100%之间,则是效果的线性乘子,也相当于图像样本乘以数量。 若值未设置,值默认是1。该函数与已有的opacity属性很相似,不同之处在于通过filter,一些浏览器为了提升性能会提供硬件加速。

brightness(%):亮度。值为百分比,如果值是0%,图像会全黑。值是100%,则图像无变化。其他的值对应线性乘子效果。值超过100%也是可以的,图像会比原来更亮。如果没有设定值,默认是1。

contrast(%):对比度。值是0%的话,图像会全黑。值是100%,图像不变。值可以超过100%,意味着会运用更低的对比。若没有设置值,默认是1。

blur(px):高斯模糊。值为像素值, 值越大越模糊;如果没有设定值,则默认是0;这个参数可设置css长度值,但不接受百分比值。

drop-shadow(h-shadow v-shadow blur spread color):阴影 。阴影是合成在图像下面,可以有模糊度的,可以以特定颜色画出的遮罩图的偏移版本。 函数接受(在CSS3背景中定义)类型的值,除了"inset"关键字是不允许的。该函数与已有的box-shadow box-shadow属性很相似。

注意:滤镜的先后顺序不同产生的效果也是不一样的。在使用滤镜动画时,需要大量的计算,不断的重绘页面,属于非常消耗性能的动画,使用时要注意使用场景。记得开启硬件加速及合理使用分层技术

看完基础知识,再来看看几个滤镜的应用吧!

一、不规则投影

应用知识点: url,drop-shadow
代码示例:

box-shadow不适用的情况:1、 半透明图像、背景图像、或者border-image(比如老式的金质像框)。
    2、元素设置了点状、虚线或半透明的边框,但没有背景(或者当background-clip 不是border-box 时);
    3、对话气泡,它的小尾巴通常是用伪元素生成的;
    4、我们在“切角效果”一节中见过的切角形状;
    5、几乎所有的折角效果,包括“折角效果”一节将提到的例子;
    6、通过 clip-path 生成的形状,比如“菱形图片”一节中提到的菱形图像。
 

.note1 {
    position: relative;
    max-width: 30em;
    margin: 50px auto;
    padding: 2em;
    background: #58a;
    background: linear-gradient(-150deg, transparent 1.5em, #58a 0);
    border-radius: .5em;
    
    filter: url(drop-shadow.svg#drop-shadow);
    
    filter: drop-shadow(12px 12px 20px rgba(0, 0, 0, .5));
}

.note1::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    background: linear-gradient(to left bottom, transparent 50%, rgba(0, 0, 0, .2) 0, rgba(0, 0, 0, .4)) 100% 0 no-repeat;
    width: 1.7em;
    height: 3em;
    -webkit-transform: translateY(-1.3em) rotate(-30deg);
    -moz-transform: translateY(-1.3em) rotate(-30deg);
    -ms-transform: translateY(-1.3em) rotate(-30deg);
    -o-transform: translateY(-1.3em) rotate(-30deg);
    transform: translateY(-1.3em) rotate(-30deg);
    transform-origin: bottom right;
    border-bottom-left-radius: inherit;
    box-shadow: -.2em .2em .3em -.1em rgba(0, 0, 0, .15);
}

二、染色效果

应用知识:sepia,saturate,hue-rotate
代码示例:


.color-tint-filter {
    max-width: 640px;
    transition: 2s filter, 2s -webkit-filter;
    -webkit-filter: sepia() saturate(4) hue-rotate(250deg);
    filter: sepia() saturate(4) hue-rotate(250deg);
}
.color-tint-filter:hover {
    -webkit-filter: none;
    filter: none;
}

此效果亦可以通过 css 混合模式 来实现。
应用知识:background-blend-mode
代码示例:


.color-tint {
    display: inline-block;
    width: 640px;
    height: 440px;
    background-size: cover;
    background-color: hsl(335, 100%, 50%);
    background-blend-mode: luminosity;
    transition: 2s background-color;
}
.color-tint:hover {
    background-color: transparent;
}
三、毛玻璃效果

应用知识:blur,background 相关知识
代码示例:

“The only way to get rid of a temptation is to yield to it. Resist it, and your soul grows sick with longing for the things it has forbidden to itself, with desire for what its monstrous laws have made monstrous and unlawful.”
Oscar Wilde, The Picture of Dorian Gray
body, main::before { background: url("img/tiger.jpg") 0 / cover fixed; } main { position: relative; margin: 0 auto; padding: 1em; max-width: 23em; background: hsla(0,0%,100%,.25) border-box; overflow: hidden; border-radius: .3em; box-shadow: 0 0 0 1px hsla(0,0%,100%,.3) inset, 0 .5em 1em rgba(0, 0, 0, 0.6); text-shadow: 0 1px 1px hsla(0,0%,100%,.3); } main::before { content: ''; position: absolute; top: 0; right: 0; bottom: 0; left: 0; margin: -30px; z-index: -1; -webkit-filter: blur(10px); filter: blur(10px); } blockquote { font-style: italic; } blockquote cite { font-style: normal; }

四、通过模糊来弱化背景

应用知识: blur、dialog标签使用
代码示例:

O HAI, I’m a dialog. Click on me to dismiss.

放置文本信息

main { transition: .6s; background: white; } main.de-emphasized { -webkit-filter: blur(3px); filter: blur(3px); } dialog { position: fixed; top: 50%; left: 50%; z-index: 1; width: 10em; padding: 2em; margin: -5em; border: 1px solid silver; border-radius: .5em; box-shadow: 0 .2em .5em rgba(0, 0, 0, .5), 0 0 0 100vmax rgba(0, 0, 0, .2); } dialog:not([open]) { display: none; }

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/242397.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号