IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> 2021-11-12 -> 正文阅读

[游戏开发]2021-11-12

css3 transform 3d轮播(张鑫旭大大2012年就发布了的动画,我才学会)

首先将大神链接放出来,非常的通俗易懂
https://www.zhangxinxu.com/wordpress/2012/09/css3-3d-transform-perspective-animate-transition/
其次,放出想要实现的效果。
在这里插入图片描述

首先,要实现类似的效果,必须认识到一个属性:rotate(rotateX, rotateY, rotateZ),除了最中间的卡片,旁边的都有一定的旋转角度,
在这里插入图片描述
很显然,我们的卡片要围绕着Y轴旋转才会有类似的效果,可类比美女跳钢管舞。
因此,我们要用到的重要属性:rotateY

但是仅仅有rotateY属性会达到我们想要的效果吗?显然不会。
在这里插入图片描述
我们给第二个图片一个旋转角度:60deg 它也确实旋转了,但是为什么感觉和我们想要的效果不太一致呢???
原因就是 视角(perspective)。
perspective决定了你的tranform是2d的还是3d的。而透视点就在浏览器的前方。
在这里插入图片描述
(借用张鑫旭大大的图)

除了respective,transalteZ也是一个重要的属性,它会决定元素的大小。translateZ就是元素顺着Z轴的移动,而我们的透视点也在Z轴上。
我们知道近大远小,当translateZ的值越接近(但不超过)perspective的时候,元素越大!就类似于元素已经在你眼前了!
这时最后一件事,还需要给我们舞台元素一个属性:transform-style: preserve-3d; 表示3d透视
最终的基本实现效果如下:
在这里插入图片描述
当我们需要的轮播卡片的数量过多时,并且需要给每个卡片设定不同但是有规律的旋转角度时,这时候写css会显得繁琐,且修改起来也存在很大的困难。
因此可尝试使用LESS。

假设我们希望所有的卡片围成一个圈,一共36张卡片,那么360deg/36 = 10deg,每张卡片相较于前一张转动10deg。有如下代码。

/* 循环函数 每个卡片位置 */
.transform-func(@n, @i:1) when (@i <= @n) {
  &:nth-child(@{i}) {
    @index: @i;
    transform: rotateY(10deg * @index) translateZ(5205px);
  }
  .transform-func(@n, (@i+1))
}

此时我们只需要调用函数的时候将n=36传递过去

@num: 36;
.card {
  .transform-func(@num);
}

并且改变变量n的大小和每一张卡片的旋转角度来调整轮播卡片的个数。是不是方便的很呢?

这时我们已经可以得到一个静态的页面了,并且元素是呈现一个圆环的分布,通过一点自己的css修饰效果就会如下:
在这里插入图片描述
笔者遇到的动画需求如下:

  • 将前面的7张卡片显示出来,后面的是用户看不到的
  • 自动轮播

下面我们就要用到javascript来控制它的显示隐藏和轮播了!!

首先让我们看看如何 将前面的7张卡片显示出来(最中间有特殊样式),隐藏剩下的元素

  1. 我们先给所有元素一个visibility:hidden;让所有的元素都不显示。
  2. 通过show函数来控制前7个元素显示
    /* 控制前面的元素显示 */
    function show() {
      elements.map((item, index) => {
      	//其中current记录7个种最左边元素的编号(从1开始),len是想要显示的元素长度——7
        let end = current + len - 1;
        if (end > NUM) {
          if(item.id >= current || item.id <= end - NUM) {
            item.classList.add('--present')
          } else {
            item.classList.remove('--present');
          }
        } else {
          if(item.id >= current && item.id <= end) {
            item.classList.add('--present');
          } else {
            item.classList.remove('--present');
          }
        }

      })
      elements.map((item, index) => {
      	//activeId是最中间元素的编号
        if (item.id == activeIndex) {
          item.classList.add('--active');
        } else {
          item.classList.remove('--active');
        }
      })
    }

其中,–present控制前7个元素的样式。
&.–present {
visibility: visible;
}
–active控制最中间的特殊样式。
&.–active {

}

轮播是通过setInterval控制的。其中包含了中心卡片的角度旋转,以及current和activeIndex都++,再通过show函数即可变换显示的卡片。

setInterval(() => {
      rotate(); 
      show();
      current = current < NUM ? current+1 : 1;
      activeIndex ++;
      if (activeIndex > NUM) {
        activeIndex = 1;
      }
    }, 3000)

最终即可达到一个走马灯的轮播效果。

  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2021-11-16 19:09:43  更:2021-11-16 19:10:29 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 4:39:18-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码