0

0

使用 SVG 遮罩实现滚动时图像放大效果教程

DDD

DDD

发布时间:2025-09-28 19:15:35

|

917人浏览过

|

来源于php中文网

原创

使用 svg 遮罩实现滚动时图像放大效果教程

本教程将引导你使用 SVG 遮罩技术,实现当页面滚动时,SVG 遮罩区域内的图像逐渐放大并填充视口的效果。我们将提供详细的代码示例和解释,帮助你理解和应用这种动态视觉效果。通过本教程,你将掌握如何利用 SVG 遮罩、JavaScript 和 CSS,创建引人入胜的滚动动画。

1. 准备工作

首先,我们需要准备一个包含图像和 SVG 遮罩的 HTML 结构。以下是一个基本的示例:

这段代码定义了一个 container 容器,其中包含一个 SVG 元素。SVG 内部定义了一个遮罩 m1,它由两个路径组成,形成字母 "XG" 的形状。 image 元素使用这个遮罩来显示部分图像。

2. CSS 样式

为了使滚动效果正常工作,我们需要一些基本的 CSS 样式:

body {
  margin: 0;
  height: 400vh; /* 确保页面可以滚动 */
}

.container {
    margin-top: 100vh; /* 容器距离顶部100vh,使得初始状态不在viewport */
}

这里我们将 body 的高度设置为 400vh,以便页面可以滚动。 container 设置 margin-top: 100vh;,这样初始状态下容器不会出现在viewport,保证初始状态是遮罩未放大的状态。

Cutout.Pro抠图
Cutout.Pro抠图

AI批量抠图去背景

下载

3. JavaScript 滚动处理

现在,我们需要使用 JavaScript 来监听滚动事件,并根据滚动位置动态调整 SVG 遮罩的缩放。

window.addEventListener('scroll', function() {
  var container = document.querySelector('.container');
  let s = (container.offsetTop + container.clientHeight*.5 - window.scrollY)/container.clientHeight;
  s = (s > 1) ? 0 : 1-s;
  var maskgroup = document.querySelector('#m1 g');
  maskgroup.setAttribute('transform', `translate(1500 750) scale(${1 + s * 90})`);
});

这段代码做了以下几件事:

  1. 监听滚动事件: window.addEventListener('scroll', ...) 监听浏览器的滚动事件。
  2. 计算缩放比例: s = (container.offsetTop + container.clientHeight*.5 - window.scrollY)/container.clientHeight; 计算一个基于滚动位置的缩放比例 s。 这个比例基于容器的 offsetTop (容器顶部距离文档顶部的距离), 容器的高度,以及当前的 scrollY (垂直滚动距离)。
    • (container.offsetTop + container.clientHeight*.5 - window.scrollY) 计算的是容器中心点距离视口顶部的距离。
    • /container.clientHeight 将这个距离除以容器高度,得到一个相对比例。
    • s = (s > 1) ? 0 : 1-s; 对 s 进行限制,使其在 0 和 1 之间。 如果 s 大于 1,则设置为 0。然后,用 1 - s 得到最终的缩放比例。 这样,当容器滚动到视口中心时,s 接近 1,遮罩放大到最大。
  3. 应用缩放: maskgroup.setAttribute('transform', \translate(1500 750) scale(${1 + s * 90})`);获取遮罩内部的元素(maskgroup),并设置其transform` 属性。
    • translate(1500 750) 将遮罩移动到 SVG 的中心。
    • scale(${1 + s * 90}) 根据计算出的缩放比例 s 动态缩放遮罩。 1 + s * 90 确保缩放比例从 1 开始,并且最大放大 90 倍。

4. 代码优化与注意事项

  • 性能优化: 频繁的滚动事件处理可能会影响性能。 可以考虑使用 requestAnimationFrame 来优化滚动处理,减少不必要的计算和渲染。
  • 缩放比例调整: 缩放比例的计算和最大缩放倍数需要根据实际情况进行调整,以达到最佳的视觉效果。
  • SVG 坐标系: 理解 SVG 的 viewBox 属性和坐标系非常重要,这有助于你更好地控制遮罩的位置和大小。
  • 兼容性: 确保代码在不同的浏览器和设备上都能正常工作。

5. 总结

通过本教程,你学习了如何使用 SVG 遮罩和 JavaScript 实现滚动时图像放大的效果。 这种技术可以用于创建各种引人入胜的滚动动画,提升用户体验。 记住,理解 SVG 的基本概念和 JavaScript 的滚动事件处理是实现这种效果的关键。 通过不断实践和尝试,你可以创造出更多令人惊艳的动态视觉效果。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
margin在css中是啥意思
margin在css中是啥意思

在CSS中,margin是一个用于设置元素外边距的属性。想了解更多margin的相关内容,可以阅读本专题下面的文章。

436

2023.12.18

PHP 高并发与性能优化
PHP 高并发与性能优化

本专题聚焦 PHP 在高并发场景下的性能优化与系统调优,内容涵盖 Nginx 与 PHP-FPM 优化、Opcode 缓存、Redis/Memcached 应用、异步任务队列、数据库优化、代码性能分析与瓶颈排查。通过实战案例(如高并发接口优化、缓存系统设计、秒杀活动实现),帮助学习者掌握 构建高性能PHP后端系统的核心能力。

102

2025.10.16

PHP 数据库操作与性能优化
PHP 数据库操作与性能优化

本专题聚焦于PHP在数据库开发中的核心应用,详细讲解PDO与MySQLi的使用方法、预处理语句、事务控制与安全防注入策略。同时深入分析SQL查询优化、索引设计、慢查询排查等性能提升手段。通过实战案例帮助开发者构建高效、安全、可扩展的PHP数据库应用系统。

89

2025.11.13

JavaScript 性能优化与前端调优
JavaScript 性能优化与前端调优

本专题系统讲解 JavaScript 性能优化的核心技术,涵盖页面加载优化、异步编程、内存管理、事件代理、代码分割、懒加载、浏览器缓存机制等。通过多个实际项目示例,帮助开发者掌握 如何通过前端调优提升网站性能,减少加载时间,提高用户体验与页面响应速度。

30

2025.12.30

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

59

2026.01.31

高干文在线阅读网站大全
高干文在线阅读网站大全

汇集热门1v1高干文免费阅读资源,涵盖都市言情、京味大院、军旅高干等经典题材,情节紧凑、人物鲜明。阅读专题下面的文章了解更多详细内容。

43

2026.01.31

无需付费的漫画app大全
无需付费的漫画app大全

想找真正免费又无套路的漫画App?本合集精选多款永久免费、资源丰富、无广告干扰的优质漫画应用,涵盖国漫、日漫、韩漫及经典老番,满足各类阅读需求。阅读专题下面的文章了解更多详细内容。

60

2026.01.31

漫画免费在线观看地址大全
漫画免费在线观看地址大全

想找免费又资源丰富的漫画网站?本合集精选2025-2026年热门平台,涵盖国漫、日漫、韩漫等多类型作品,支持高清流畅阅读与离线缓存。阅读专题下面的文章了解更多详细内容。

12

2026.01.31

漫画防走失登陆入口大全
漫画防走失登陆入口大全

2026最新漫画防走失登录入口合集,汇总多个稳定可用网址,助你畅享高清无广告漫画阅读体验。阅读专题下面的文章了解更多详细内容。

13

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

CSS教程
CSS教程

共754课时 | 25.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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