css3和JavaScript实现图片点击散开放大效果
本文介绍如何使用css3和javascript实现点击图片后,周围图片以点击图片为中心散开并放大的交互效果。
核心思想是利用css3的transform属性控制图片位置和大小,JavaScript计算每个图片的位移和缩放比例,并应用到CSS样式中。
首先,为每个图片添加点击事件监听器,触发JavaScript函数(例如spread函数)。html代码示例:
@@##@@</img> @@##@@</img> @@##@@</img>
spread函数获取所有图片元素,根据点击图片的索引计算其他图片的位移量。JavaScript代码示例:
function spread(img) { const images = document.querySelectorAll('img'); const index = Array.from(images).indexOf(img); const centerX = img.offsetLeft + img.offsetWidth / 2; const centerY = img.offsetTop + img.offsetHeight / 2; images.forEach((image, i) => { const dx = image.offsetLeft + image.offsetWidth / 2 - centerX; const dy = image.offsetTop + image.offsetHeight / 2 - centerY; const distance = math.sqrt(dx * dx + dy * dy); const scale = i === index ? 2 : 1; // 点击图片放大两倍 const moveX = dx * (distance / 100); // 100为散开距离,可调整 const moveY = dy * (distance / 100); image.style.transform = `translate(${moveX}px, ${moveY}px) scale(${scale})`; }); }
代码中,Math.sqrt计算距离,100控制散开半径,可根据需求调整。scale变量控制缩放比例,点击图片缩放比例为2,其他图片保持为1。
立即学习“Java免费学习笔记(深入)”;
最后,CSS设置图片初始样式,例如绝对定位和过渡效果:
img { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%) scale(1); transition: transform 0.5s ease-in-out; }
transition属性提供平滑过渡效果。图片初始位置和散开半径需根据实际情况调整。 此代码已优化,使用querySelectorAll和Array.from提高效率,并更准确地计算中心点和位移。 记得替换image1.jpg,image2.jpg,image3.jpg为实际图片路径。
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END