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)));
}
}
目录
相关文章
|
2月前
|
机器学习/深度学习 前端开发 JavaScript
|
4天前
|
JavaScript 前端开发
jQuery和CSS3滑动展开菜单按钮插件
这是一款jQuery和CSS3滑动展开菜单按钮插件。该滑动展开菜单按钮在用户点击主菜单按钮之后,子菜单以滑动的方式依次展开
39 21
|
27天前
纯css3实现的百分比渐变进度条加载动画源码
纯css3实现的百分比渐变进度条加载动画特效源码
53 31
|
2月前
|
前端开发 搜索推荐 UED
实现 CSS 动画效果的兼容性
【10月更文挑战第16天】实现 CSS 动画效果的兼容性需要对不同浏览器的特性有深入的了解,并采取适当的策略和方法。通过不断的实践和优化,你可以在各种浏览器上创造出流畅、美观且兼容的动画效果,为用户带来更好的体验。在实际开发中,要密切关注浏览器的发展动态,及时掌握最新的兼容性技巧和解决方案,以确保你的动画设计能够在广泛的用户群体中得到良好的呈现。
113 58
|
12天前
|
Web App开发 移动开发 JavaScript
纯CSS3+SVG实现的节日庆祝五彩纸屑动画效果源码
这是一款基于纯CSS3+SVG实现的节日庆祝五彩纸屑动画效果源码。画面中左下角是一个圆锥形礼炮卡通效果,呈现出节日庆祝时礼花爆破、五彩纸屑纷飞的动画特效。整体动画效果采用纯css3+svg实现,没有引入任何外部图形或js脚本元素。建议使用支持HTML5与css3效果较好的火狐(Firefox)或谷歌(Chrome)等浏览器预览本源码。
30 6
|
22天前
|
前端开发 JavaScript UED
CSS滚动效果和视差滚动的原理、应用及其对用户体验的影响。从平滑滚动到元素跟随,再到滚动触发动画
本文探讨了CSS滚动效果和视差滚动的原理、应用及其对用户体验的影响。从平滑滚动到元素跟随,再到滚动触发动画,这些效果增强了页面的吸引力和互动性。视差滚动通过不同层次元素的差异化移动,增加了页面的深度感和沉浸感。文章还讨论了实现方法、性能优化及案例分析,旨在为设计师和开发者提供实用指导。
50 7
|
27天前
CSS3制作的聚光灯下倒影文字选装动画特效源码
CSS3聚光灯下倒影文字特效是一段基于CSS3实现的聚光灯下带倒影的文字旋转动画效果代码,具有真实的视觉感,同时文字还会在旋转过程中显示出灯光的反射效果,很有意思,欢迎对此段代码感兴趣的朋友前来下载使用。
29 6
|
1月前
|
移动开发 前端开发 JavaScript
除了 CSS3,还有哪些技术可以实现动画效果?
除了 CSS3,还有哪些技术可以实现动画效果?
53 5
|
27天前
纯css3加载loading发光变色动画代码
纯css3加载loading发光变色动画特效代码是一款基于css3 keyframes属性实现的发光变色圆点串联旋转loading加载动画
22 2
|
28天前
|
Web App开发 前端开发 iOS开发
CSS加载动画大全 126种
CSS加载动画大全是一个css Loaders加载动画特效汇总,一共包含126种加载动画效果,不同样式不同图案,简单实用,一览包含所有,会让你在等待的过程中,体验视觉盛宴,给用户不一般的加载体验,欢迎下载试试!代码适用浏览器:搜狗、360、FireFox(建议)、Chrome、Safari、Opera、傲游、世界之窗,是一款不错的的特效插件,希望大家喜欢!
26 2