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)));
}
}
目录
相关文章
|
前端开发 JavaScript
CSS 过渡和动画
CSS过渡和动画是用于为网页元素添加动态效果的两种重要技术
631 143
|
8月前
|
自然语言处理 前端开发 JavaScript
用 通义灵码 一键生成“水波纹按钮”,连 CSS 动画都不用自己写了!
通义灵码是一款智能编程辅助工具,它可以根据自然语言指令自动生成高质量的代码。例如,只需输入“生成一个按钮,点击时带水波纹动画,模拟 Material Ripple 效果”,它就能生成具备完整交互逻辑、CSS 动画和良好性能的按钮组件。不仅如此,它还支持拓展功能,如长按触发提示、添加图标等,并能自动优化样式适配不同场景。通过通义灵码,开发者可以大幅提升效率,专注于创意实现,而不必纠结于繁琐的代码细节。
|
5月前
|
前端开发 算法 Java
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
Animation属性 css3为Animation动画提供的几个属性如下: 属性名 属性值 animation-name 指定动画名称,该属性指定一个已有的关键帧定义。 animation-duration 指定动画持续时间。 animation-timing-funtion 指定动画变化速度。 animation-delay 指定动画延迟多长时间才开始执行。 animation-iteration-count 指定动画的循环执行次数。 animation:这是一个复合属性。
405 3
|
机器学习/深度学习 前端开发 JavaScript
CSS动画知识点
CSS动画知识点
|
JavaScript 前端开发
CSS3 动画和 JavaScript 动画的性能比较
具体的性能表现还会受到许多因素的影响,如动画的复杂程度、浏览器的性能、设备的硬件条件等。在实际应用中,需要根据具体情况选择合适的动画技术。
465 154
css3 svg制作404页面动画效果HTML源码
css3 svg制作404页面动画效果HTML源码
278 34
|
移动开发 前端开发 JavaScript
除了 CSS3,还有哪些技术可以实现动画效果?
除了 CSS3,还有哪些技术可以实现动画效果?
470 63
|
前端开发 搜索推荐 UED
实现 CSS 动画效果的兼容性
【10月更文挑战第16天】实现 CSS 动画效果的兼容性需要对不同浏览器的特性有深入的了解,并采取适当的策略和方法。通过不断的实践和优化,你可以在各种浏览器上创造出流畅、美观且兼容的动画效果,为用户带来更好的体验。在实际开发中,要密切关注浏览器的发展动态,及时掌握最新的兼容性技巧和解决方案,以确保你的动画设计能够在广泛的用户群体中得到良好的呈现。
418 58
jQuery+CSS3实现404背景游戏动画源码
jQuery+CSS3实现404背景游戏动画源码
246 22

热门文章

最新文章

  • 1
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
    405
  • 2
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
    315
  • 3
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
    282
  • 4
    (CSS)使用Flex布局,帮助你快速了解各种基本的Flex布局属性以及帮你让元素快速达到布局中的指定位置!
    196
  • 5
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
    406
  • 6
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
    600
  • 7
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
    681
  • 8
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(三):元素继承关系、层叠样式规则、字体属性、文本属性;针对字体和文本作样式修改
    201
  • 9
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
    573
  • 10
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(一):CSS发展史;CSS样式表的引入;CSS选择器使用,附带案例介绍
    351