首页 > web前端 > css教程 > 正文

如何在CSS中制作图片滤镜渐变_filter @keyframes平滑过渡

P粉602998670
发布: 2025-11-30 13:55:02
原创
340人浏览过
使用@keyframes和filter可实现图片滤镜平滑过渡,如从模糊黑白到清晰彩色;通过定义0%到100%关键帧,配合ease-in-out缓动和forwards保持状态,确保函数顺序一致,实现自然动画效果。

如何在css中制作图片滤镜渐变_filter @keyframes平滑过渡

想让图片的CSS滤镜实现平滑渐变过渡,比如从模糊到清晰、黑白到彩色或亮度变化,可以通过 @keyframes 配合 filter 属性来实现。虽然 filter 本身不支持直接渐变,但结合动画可以做到视觉上的平滑过渡。

1. 使用 @keyframes 定义滤镜动画

通过 keyframes 设置不同阶段的 filter 值,浏览器会自动插值实现过渡效果。

例如:实现图片从模糊黑白到清晰彩色的过渡:

@keyframes fadeInSharp {
  0% {
    filter: blur(5px) grayscale(100%) brightness(0.5);
  }
  100% {
    filter: blur(0) grayscale(0) brightness(1);
  }
}

img {
  animation: fadeInSharp 2s ease-in-out forwards;
}
登录后复制

这段代码会让图片在2秒内逐渐变得清晰、彩色并恢复正常亮度。

立即学习前端免费学习笔记(深入)”;

2. 控制过渡的平滑性

使用 ease-in-out 或自定义贝塞尔曲线(如 cubic-bezier(0.4, 0, 0.2, 1))可以让过渡更自然。

关键点:

BibiGPT-哔哔终结者
BibiGPT-哔哔终结者

B站视频总结器-一键总结 音视频内容

BibiGPT-哔哔终结者 871
查看详情 BibiGPT-哔哔终结者
  • 避免使用 step() 类缓动函数,会导致跳跃式变化
  • 推荐用 easeease-in-outlinear 实现流畅感
  • 添加 forwards 保持动画结束后的最终状态

3. 按需触发滤镜动画

你可以通过 hover、JavaScript 添加/移除类名等方式控制动画播放。

示例:鼠标悬停时启动滤镜变化

img {
  filter: contrast(75%) saturate(50%);
  transition: filter 0.3s ease;
}

img:hover {
  filter: contrast(100%) saturate(100%);
}
登录后复制

注意:这里用了 transition 而非 animation,适合简单交互场景。复杂多阶段变化仍推荐使用 @keyframes

4. 可动画的 filter 函数列表

CSS 中以下 filter 函数支持平滑过渡:

  • blur(px)
  • brightness(%)
  • contrast(%)
  • grayscale(%)
  • hue-rotate(deg)
  • opacity(%)
  • saturate(%)
  • sepia(%)

组合使用时,确保起始和结束的 filter 函数顺序与数量一致,避免插值异常。

基本上就这些。只要结构清晰、函数匹配、缓动合理,就能做出很自然的滤镜渐变效果。

以上就是如何在CSS中制作图片滤镜渐变_filter @keyframes平滑过渡的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号