跳转到内容

filter 实现滤镜

刀刀

1/3/2025

0 字

0 分钟

前置知识

filter 属性将模糊或颜色偏移等图形效果应用于元素自身。滤镜通常用于调整图像、背景和边框的渲染。

下面简单罗列一下它所有的属性语法:

css
/* <filter-function> 值 */
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%);

/* URL */
filter: url("filters.svg#filter-id");

/* 多个滤镜 */
filter: contrast(175%) brightness(3%);
filter: drop-shadow(3px 3px red) sepia(100%) drop-shadow(-3px -3px blue);

/* 不使用滤镜 */
filter: none;

/* 全局值 */
filter: inherit;
filter: initial;
filter: revert;
filter: revert-layer;
filter: unset;

实现

下面针对部分函数方法做详细说明。

drop-shadow

使用 <shadow> 参数沿图像的轮廓生成阴影效果。阴影语法类似于 <box-shadow>(在 CSS 背景和边框模块中定义),但不允许使用 inset 关键字以及 spread 参数。与所有 filter 属性值一样,任何在 drop-shadow() 后的滤镜同样会应用在阴影上。

使用场景为在 box-shadow 只能给整个盒子添加盒子阴影,但效果只是想给盒子内的透明图片添加阴影时使用。效果如下:

代码如下:

css
filter: drop-shadow(10px 10px 10px orange);

其原理是把原来的像素点颜色通过算法来计算,计算完后返回新的像素点。

blur

将高斯模糊应用于输入图像。括号内输入像素单位的值,该值表示需要做模糊处理时的参考半径范围,值越大处理的结果越模糊。

代码如下所示:

css
filter: blur(5px);

hue-rotate

应用色相旋转。<angle> 值设定图像会被调整的色环角度值。值为 0deg,则图像无变化。

代码示例:

css
filter: hue-rotate(90deg);

contrast

调整输入图像的对比度。值是 0% 将使图像变灰(即对比度越小);值是 100%,则无影响;若值超过 100% 将增强对比度。

代码语法示例:

css
filter: contrast(200%);

grayscale

将图像转换为灰度图。值为 100% 则完全转为灰度图像,若为初始值 0% 则图像无变化。值在 0%100% 之间,则是该效果的线性乘数。

在特殊纪念日里网站变灰就是用了这个属性,代码如下:

css
filter: grayscale(1);

总体效果