2D旋转与3D转换

news/2024/11/28 22:43:19/

文章目录

  • 一、2D转换
      • 1.移动: translate
      • 2.旋转: rotate
      • 3.缩放: scale
      • 4.2D 转换综合写法以及顺序问题
      • 5.动画(animation)
        • 5.1.定义动画
        • 5.2.使用动画
        • 5.3.动画常见属性
        • 5.4.动画简写方式
  • 二、3D转换
      • 1.3D位移:translate3d(x, y, z)
      • 2.3D旋转:rotate3d(x, y, z)
      • 3.透视:perspctive
      • 4.3D呈现 transfrom-style


一、2D转换

2D转换是改变标签在二维平面上的位置和形状

1.移动: translate

2D的移动主要是指 水平、垂直方向上的移动

transform: translate(x, y)

知识要点

  • translate 最大的优点就是不影响其他元素的位置
  • translate 中的100%单位,是相对于本身的宽度和高度来进行计算的
  • 行内标签没有效果

2.旋转: rotate

2d旋转指的是让元素在2维平面内顺时针旋转或者逆时针旋转

      transform: rotate(0deg);

重点知识点

  • rotate 里面跟度数,单位是 deg
  • 角度为正时,顺时针,角度为负时,逆时针
  • 默认旋转的中心点是元素的中心点
    旋转中心点(transform-origin)
transform-origin: x y;

知识要点

  • 注意后面的参数 x 和 y 用空格隔开
  • x y 默认旋转的中心点是元素的中心 (50% 50%),等价于 center center
  • 还可以给 x y 设置像素或者方位名词(topbottomleftrightcenter)

3.缩放: scale

transform: scale(x, y)

知识要点

  • 注意,x 与 y 之间使用逗号进行分隔
  • transform: scale(1, 1): 宽高都放大一倍,相当于没有放大
  • transform: scale(2, 2): 宽和高都放大了二倍
  • transform: scale(2): 如果只写了一个参数,第二个参数就和第一个参数一致
  • transform:scale(0.5, 0.5): 缩小
  • scale 最大的优势:可以设置转换中心点缩放,默认以中心点缩放,而且不影响其他盒子

4.2D 转换综合写法以及顺序问题

div:hover {transform: translate(200px, 0) rotate(360deg) scale(1.2)
}

知识要点

  • 同时使用多个转换,其格式为 transform: translate() rotate() scale()
  • 顺序会影响到转换的效果(先旋转会改变坐标轴方向)
  • 但我们同时有位置或者其他属性的时候,要将位移放到最前面

5.动画(animation)

动画是 CSS3 中最具颠覆性的特征之一,可通过设置多个节点来精确的控制一个或者一组动画,从而实现复杂的动画效果

5.1.定义动画

@keyframes 动画名称 { 0% {        width: 100px;    }    100% {        width: 200px    }}

知识要点

  • 0% 是动画的开始,100 % 是动画的完成,这样的规则就是动画序列
  • 在 @keyframs 中规定某项 CSS 样式,就由创建当前样式逐渐改为新样式的动画效果
  • 动画是使元素从一个样式逐渐变化为另一个样式的效果,可以改变任意多的样式任意多的次数
  • 用百分比来规定变化发生的时间,或用 fromto,等同于 0% 和 100%

5.2.使用动画

div {/* 调用动画 */animation-name: 动画名称;/* 持续时间 */animation-duration: 持续时间;
}

5.3.动画常见属性

div {width: 100px;height: 100px;background-color: aquamarine;/* 动画名称 */animation-name: move;/* 动画花费时长 */animation-duration: 2s;/* 动画速度曲线 */animation-timing-function: ease-in-out;/* 动画等待多长时间执行 */animation-delay: 2s;/* 规定动画播放次数 infinite: 无限循环 */animation-iteration-count: infinite;/* 是否逆行播放 */animation-direction: alternate;/* 动画结束之后的状态 */animation-fill-mode: forwards;
}div:hover {/* 规定动画是否暂停或者播放 */animation-play-state: paused;
}

5.4.动画简写方式

/* animation: 动画名称 持续时间 运动曲线 何时开始 播放次数 是否反方向 起始与结束状态 */
animation: name duration timing-function delay iteration-count direction fill-mode

知识要点

  • 简写属性里面不包含 animation-paly-state
  • 暂停动画 animation-paly-state: paused; 经常和鼠标经过等其他配合使用
  • 要想动画走回来,而不是直接调回来:animation-direction: alternate
  • 盒子动画结束后,停在结束位置:animation-fill-mode: forwards

二、3D转换

3D 的特点

  • 近大远小
  • 物体和面遮挡不可见

1.3D位移:translate3d(x, y, z)

3D 移动就是在 2D 移动的基础上多加了一个可以移动的方向,就是 z 轴方向

2.3D旋转:rotate3d(x, y, z)

3D 旋转指可以让元素在三维平面内沿着 x 轴、y 轴、z 轴 或者自定义轴进行旋转

3.透视:perspctive

如果想要网页产生 3D效果需要透视(理解成 3D物体投影的 `2D` 平面上),实际上模仿人类的视觉位置,可视为安排一直眼睛去看

知识要点

  • 透视需要写在被视察元素的父盒子上面
  • 透视的单位是像素
  • 透视也称为视距,所谓的视距就是人的眼睛到屏幕的距离
  • 距离视觉点越近的在电脑平面成像越大,越远成像越小

4.3D呈现 transfrom-style

控制子元素是否开启三维立体环境

知识要点

  • transform-style: flat 代表子元素不开启 3D 立体空间,默认的
  • transform-style: preserve-3d 子元素开启立体空间
  • 代码写给父级,但是影响的是子盒子


http://www.ppmy.cn/news/249756.html

相关文章

02[并非3D的3D]

第二集 并非3D的3D 我们开始展示3D的世界了, 好好复习一下几何吧。 2.1 从来都没有3D的游戏 2.1.1 3D pipeline 3D pipeline, 应该翻译成3D流水线比较能让大家清楚, 它和汽车制造厂的流水线是有共性的. 在我们编写演示3D的例子前, 我们简单的了解一下3D pipeline, 如…

3d位移效果

前言:3d坐标系 X 轴 往右为正值, 否则反之 Y 轴 往下为正值,否则反之 Z轴 指向我们为正值,否则反之 3d位移 1、X轴正值位移(向右): transform: translateX(100px); 示例: 设置一个…

3D视觉

我们生活在三维空间中,如何智能地感知和探索外部环境一直是个热点难题。2D视觉技术借助强大的计算机视觉和深度学习算法取得了超越人类认知的成就,而3D视觉则因为算法建模和环境依赖等问题,一直处于正在研究的前沿。近年来,3D视觉…

Daydream播放3D视频(视频左右分屏3D效果)

需求分析: 因为VR项目需求,要实现3D视频的播放,即左右分屏视频播放。如下图所示类型视频。 使用GoogleVRForUnity插件实现VR功能效果。项目刚开始使用的是0.8的老版本插件,可以轻松实现3D视频的播放效果,但升级GoogleV…

[乐意黎原创] 左右格式的3D电影怎么播放

播放左右分屏显示的影片时,此时影片是属于3D格式, 了解决“左右格式的3D电影怎么看”这个问题,我们需要先来说明一下什么是左右格式。 左右格式和上下格式只是3D立体电影的一种存储方式,和拍摄方式,播放设备无关。如果…

为项目添加 HibernateValidator

HibernateValidatorhttps://hibernate.org/validator/ 引入依赖项 首先&#xff0c;确保已将Hibernate Validator添加到Maven或Gradle依赖项中&#xff1a; <!-- Maven 依赖 --> <dependency><groupId>org.hibernate.validator</groupId><artifa…

计算机系统相机怎么卸载,WinXP系统如何删除“扫描仪和照相机”功能?XP系统“扫描仪和照相机”的删除方法...

Winxp系统中有许多用户通常不会用到的功能&#xff0c;“扫描仪和照相机”就是其中一种。对于不常用的功能&#xff0c;小编建议可以对它们进行删除&#xff0c;因为这样可以很好地缓解系统空间压力。下面&#xff0c;小编就分享XP系统“扫描仪和照相机”的具体删除方法。 详细…

HTML+CSS+JS实现 ❤️照相机快门图片动画特效❤️

效果演示&#xff1a; 代码目录&#xff1a; 主要代码实现&#xff1a; 部分CSS样式&#xff1a; html {height: 100%;overflow: hidden; }body {min-height: 100%; }.container {cursor: pointer;background-position: center center;background-size: cover;background-im…