CSS3滑动轮播动画

简介: CSS3滑动轮播动画
<main>
    <section>
        <div class="carousel-motion">
            <span class="motion-item"><img src="https://www.jq22.com/img/cs/500x500-1.png" alt="500x500-1"></span>
            <span class="motion-item"><img src="https://www.jq22.com/img/cs/500x500-2.png" alt="500x500-2"></span>
            <span class="motion-item"><img src="https://www.jq22.com/img/cs/500x500-3.png" alt="500x500-3"></span>
        </div>
    </section>
</main>
* {
   
    margin:0;
    padding:0;
}
img {
   
    user-select:none;
    -webkit-user-drag:none;
}
img[alt]:after {
   
    content:attr(alt);
    display:block;
    position:absolute;
    inset:0;
    display:inline-grid;
    justify-content:center;
    align-items:center;
    background:inherit;
    border-radius:inherit;
    font-size:1.4em;
    color:#c3c2d4;
    background-color:#454258;
    z-index:2;
}
html,body {
   
    height:100%;
    background-color:#1c1c28;
}
:root {
   
    --perspective:1000px;
}
.carousel-motion {
   
    --size:clamp(8em,40vw,10em);
    --distance:calc(.85 * var(--size));
    --parallax-factor:1.1;
    --rotation:0deg;
    --perspective:100rem;
    margin:10rem auto;
    width:var(--size);
    height:var(--size);
    perspective:var(--perspective);
    transform-style:preserve-3d;
    transform:translateZ(calc(var(--perspective) * (1 - var(--parallax-factor)))) scale(var(--parallax-factor));
    z-index:calc(100 * var(--parallax-factor));
    transition:.5s cubic-bezier(.3,3,.66,1);
    cursor:pointer;
}
.motion-item {
   
    position:absolute;
    width:var(--size);
    height:var(--size);
    filter:brightness(var(--brightness,100%));
    transition:1s cubic-bezier(.5,1.33,.3,1);
    transform:rotateX(-10deg) translateZ(calc(-1 * var(--distance))) rotateY(calc(var(--rotation) + var(--angle))) translateZ(var(--distance)) rotateY(calc(-1 * (var(--rotation) + var(--angle)))) rotateX(10deg);
    border-radius:50%;
    overflow:hidden;
}
.motion-item img {
   
    width:100%;
    height:100%;
}
.carousel-motion:hover>:nth-of-type(3n+1),.carousel-motion:not(:hover)>:nth-of-type(3n+2),.carousel-motion:not(:hover)>:nth-of-type(3n+3) {
   
    --brightness:75%
}
.carousel-motion:hover {
   
    --rotation:180deg;
}
.carousel-motion>:nth-child(3n + 1) {
   
    --angle:0deg;
    transition-delay:.05s;
    transition-duration:1.06s;
}
.carousel-motion>:nth-child(3n + 2) {
   
    --angle:120deg;
    transition-delay:.1s;
    transition-duration:1.12s;
}
.carousel-motion>:nth-child(3n + 3) {
   
    --angle:240deg;
}
.carousel-motion>:nth-child(1n + 4) {
   
    transition:1s ease-in-out;
    transform:translate3d(0,-100vh,calc(-2 * var(--perspective)));
    opacity:0;
}
main {
   
    animation:flyZ 2s backwards;
    display:grid;
    justify-items:center;
    align-items:center;
    height:100%;
    overflow:hidden;
    transform-style:preserve-3d;
}
section {
   
    animation:flyZ 2s backwards;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    transform-style:preserve-3d;
    width:100%;
}
.carousel-motion:active {
   
    transition:.4s 75ms cubic-bezier(.16,1,.3,1);
    transform:scale(.8) rotateX(2deg)
}
@keyframes flyZ {
   
    0% {
   
    transform:scale(0) translateZ(calc(1 * var(--perspective)));
}
}
目录
相关文章
|
1月前
|
机器学习/深度学习 前端开发 JavaScript
|
3月前
|
前端开发
2s 利用 HTML+css动画实现企业官网效果
2s 利用 HTML+css动画实现企业官网效果
|
23天前
|
前端开发 搜索推荐 UED
实现 CSS 动画效果的兼容性
【10月更文挑战第16天】实现 CSS 动画效果的兼容性需要对不同浏览器的特性有深入的了解,并采取适当的策略和方法。通过不断的实践和优化,你可以在各种浏览器上创造出流畅、美观且兼容的动画效果,为用户带来更好的体验。在实际开发中,要密切关注浏览器的发展动态,及时掌握最新的兼容性技巧和解决方案,以确保你的动画设计能够在广泛的用户群体中得到良好的呈现。
|
2天前
|
Web App开发 前端开发 JavaScript
如何在不牺牲动画效果的前提下,优化 CSS3 动画的性能?
如何在不牺牲动画效果的前提下,优化 CSS3 动画的性能?
7 1
|
28天前
|
前端开发 JavaScript API
探索 CSS Houdini:轻松构建酷炫的 3D 卡片翻转动画
本文通过构建一个 3D 翻卡动画深入探讨了 CSS Houdini 的强大功能,展示了如何通过 Worklets、自定义属性、Paint API 等扩展 CSS 的能力,实现高度灵活的动画效果。文章首先介绍了 Houdini 的核心概念与 API,并通过构建一个动态星空背景、圆形进度条以及交互式 3D 翻卡动画的实际示例,展示了如何利用 CSS Houdini 赋予网页设计更多创造力。最后,还演示了如何将这种 3D 翻卡效果集成到公司网站中,提升用户体验。CSS Houdini 的创新能力为网页设计带来了前所未有的灵活性,推动了前端开发迈向新的高度。
24 0
探索 CSS Houdini:轻松构建酷炫的 3D 卡片翻转动画
|
2月前
|
JavaScript 前端开发
JS配合CSS3实现动画和拖动小星星小Demo
本文通过代码示例展示了如何使用JavaScript和CSS3实现动画效果和拖动小星星的交互效果,包括文字掉落动画和鼠标拖动产生小星星动画的实现方法。
44 0
JS配合CSS3实现动画和拖动小星星小Demo
|
1月前
|
前端开发
CSS 动画介绍及语法
CSS 动画介绍及语法
27 0
|
3月前
|
前端开发 UED 开发者
有趣的CSS - 文字加载动画效果
这个文本加载动画简单而有趣,可以在网站标题、广告标语或者关键信息的展示上吸引用户的注意力。开发者可以根据需要调整动画的持续时间、步骤数,或者光标颜色等,来适应特定的设计需求。使用这种动态元素,增强网站的互动性和用户体验,同时也为网站增添了一抹活泼的风格。
72 5
|
3月前
|
前端开发 JavaScript
HTML+CSS如何打造撒花动画效果?3分钟学会,炫酷到爆!
HTML+CSS如何打造撒花动画效果?3分钟学会,炫酷到爆!
|
3月前
|
前端开发
CSS动画霓虹灯闪烁效果
CSS动画霓虹灯闪烁效果

热门文章

最新文章