酷毙了!三种风格的全屏幻灯片效果【附源码下载】
今天,我们想向您展示如何创建平铺背景图像的幻灯片效果。其灵感来自于国外的一个工作室网站(围观),这个网站充满了各种有趣和创意效果,一定记得去看看。
这个幻灯片效果是由四个区域的独立移动构成,通过画面分割,同时显示出新的图片。这里需要组合使用 CSS3 的3D转换、过渡和动画功能。除了这种效果我们也将添加两个更多的变化,我们的宗旨是实现超流畅的交互体验。
温馨提示:为保证最佳的效果,请在 IE10+、Chrome、Firefox 和 Safari 等现代浏览器中浏览。
对于幻灯片,我们需要一个特殊的 HTML 结构来实现四个不同的页面区域,每个区域都使用相同的图像,但用了不同的定位,让四个区域拼起来刚好是一张完整的背景图片。我们需要确保内容充满整个页面,因为这是一个全屏幻灯片效果。
我们先定义一个简单的初始结构,能够指定在每个面板(或幻灯片)中哪张图像会显示,然后创建我们的重复结构的片段。所以,最初我们希望是这样的:
1 2 3 4 5 6 | <div id= "boxgallery" class = "boxgallery" data-effect= "effect-1" > <div class = "panel" ><img src= "img/1.jpg" alt= "Image 1" /></div> <div class = "panel" ><img src= "img/2.jpg" alt= "Image 2" /></div> <div class = "panel" ><img src= "img/3.jpg" alt= "Image 3" /></div> <div class = "panel" ><img src= "img/4.jpg" alt= "Image 4" /></div> </div> |
为了能够通过把图片分解成片段来实现动画效果,我们将需要为每个面板定义下面这样的结构:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 | div id= "boxgallery" class = "boxgallery" data-effect= "effect-1" > <div class = "panel current" > <div class = "bg-tile" > <div class = "bg-img" ><img src= "img/1.jpg" /></div> </div> <div class = "bg-tile" > <div class = "bg-img" ><img src= "img/1.jpg" /></div> </div> <div class = "bg-tile" > <div class = "bg-img" ><img src= "img/1.jpg" /></div> </div> <div class = "bg-tile" > <div class = "bg-img" ><img src= "img/1.jpg" /></div> </div> </div> <div class = "panel" > <div class = "bg-tile" > <div class = "bg-img" ><img src= "img/2.jpg" /></div> </div> <div class = "bg-tile" > <div class = "bg-img" ><img src= "img/2.jpg" /></div> </div> <div class = "bg-tile" > <div class = "bg-img" ><img src= "img/2.jpg" /></div> </div> <div class = "bg-tile" > <div class = "bg-img" ><img src= "img/2.jpg" /></div> </div> </div> <div class = "panel" > <!-- ... --> </div> <div class = "panel" > <!-- ... --> </div> <nav> <span class = "prev" ><i></i></span> <span class = "next" ><i></i></span> </nav> </div> |
当然,你可能看上面的结构可能会问为什么不使用背景图片而用图像元素?其实在尝试使用各种方式对比之后,我们在试验后得出结论,使用背景图像与设置背景大小的方式可能会导致过渡效果有问题。例如使用 background-size: cover 会导致转换动画出现颤抖现象。
我们还需要添加一个导航,这样我们就可以通过面板进行浏览。上面我们还用到了数据属性,里面设置了动画的效果。下面,让我们添加一些样式到这个效果中。需要注意的是,这里演示的 CSS 将不包含任何浏览器的前缀,但在源码文件是有的。
首先,我们在全屏模式,所以为了让我们的页面布满窗口,需要设置如下:
1 2 3 | html, body, .container { height : 100% ; } |
主容器和子元素都将绝对定位,面板将占据所有的宽度和高度:
1 2 3 4 5 6 7 8 9 10 11 12 | .js .boxgallery, .js .boxgallery div { position : absolute ; } .js .boxgallery, .js .panel { top : 0 ; left : 0 ; width : 100% ; height : 100% ; } |
由于我们的效果将可能有元素超出自己的区域,我们还需要确保不会溢出:
1 2 3 4 5 | .js .boxgallery, .bg-tile, .bg-img { overflow : hidden ; } |
这个例子有三种效果,下面是用于第一效果的 CSS 动画效果代码:
1 2 3 4 5 6 7 8 9 | .boxgallery[data-effect= "effect-1" ] .panel.active .bg-tile, .boxgallery[data-effect= "effect-2" ] .panel.active .bg-tile { animation: scaleDown 1.1 s ease-in-out; } @keyframes scaleDown { from { transform: translate 3 d( 0 , 0 , 380px ); } to { transform: translate 3 d( 0 , 0 , 0 ); } } |
- 太赞了!超炫的页面切换动画效果【附源码下载】
- 创意无限!一组网页边栏过渡动画【附源码下载】
- 好东西!动感的页面加载动画效果【附源码下载】
- 使用 CSS3 实现3D图片滑块效果【附源码下载】
- 时尚设计!三种奇特网格加载效果【附源码下载】
本文链接:如何创建平铺背景的四格幻灯片效果 via Codrops
作者:山边小溪
主站:yyyweb.com 记住啦:)
欢迎任何形式的转载,但请务必注明出处。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
2013-06-25 分享30个独特的 404 错误页面设计模板
2012-06-25 40个新鲜出炉的 Photoshop 优秀教程
2012-06-25 优秀开发工具:推荐8个在线调试代码的网站
2011-06-25 10款很酷很有用的速查手册壁纸
2011-06-25 精美的水平导航网站作品欣赏(上篇)