[CSS3]2D与3D变换技术详解

news2024/9/23 17:24:39

Kevin的技术博客.png

文章目录

  • 2D变换(2D Transform)
  • 3D变换(3D Transform)
      • 结语

CSS3中的2D变换与3D变换是指通过transform属性对HTML元素进行几何操作,使其在二维或三维空间中进行移动、旋转、缩放和倾斜等变换。这些变换为前端开发者提供了创建复杂动画和视觉效果的能力,丰富了网页设计的表现力。

2D变换(2D Transform)

2D变换是指在二维平面内对元素进行的几何操作。CSS3中的2D变换主要包括以下几种:

  1. translate() - 平移
    • 功能:将元素在水平和垂直方向上移动。
    • 语法:
      | **值 ** | 含义 |
      | — | — |
      | translateX | 设置水平方向位移,需指定长度值;若指定的是百分比,是参考自身宽度
      的百分比。 |
      | translateY | 设置垂直方向位移,需指定长度值;若指定的是百分比,是参考自身高度
      的百分比。 |
      | translate | 一个值代表水平方向,两个值代表:水平和垂直方向。 |
transform: translate(x, y);
  • 示例:transform: translate(50px, 100px); 将元素在水平方向移动50px,在垂直方向移动100px。
  1. 位移与相对定位很相似,都不脱离文档流,不会影响到其它元素。
  2. 与相对定位的区别:相对定位的百分比值,参考的是其父元素;定位的百分比值,参考的是
    其自身。
  3. 浏览器针对位移有优化,与定位相比,浏览器处理位移的效率更高。
  4. transform 可以链式编写,例如:transform: translateX(30px) translateY(40px);
  5. 位移对行内元素无效。
  6. 位移配合定位,可实现元素水平垂直居中
  1. rotate() - 旋转

2D 旋转是指:让元素在二维平面内,顺时针旋转或逆时针旋转,具体使用方式如下:

  1. 先给元素添加 **转换属性 **transform
  2. 编写 transform 的具体值,相关可选值如下
**值 **含义
rotate设置旋转角度,需指定一个角度值( deg ),正值顺时针,负值逆时针。
  • 功能:围绕元素的中心点旋转元素。
  • 语法:
transform: rotate(angle);
  • 示例:transform: rotate(45deg); 将元素顺时针旋转45度。
  1. scale() - 缩放

  2. 先给元素添加 **转换属性 **transform

  3. 编写 transform 的具体值,相关可选值如下:

**值 **含义
scaleX设置水平方向的缩放比例,值为一个数字, 1 表示不缩放,大于 1 放大,小
于 1 缩小。
scaleY设置垂直方向的缩放比例,值为一个数字, 1 表示不缩放,大于 1 放大,小
于 1 缩小。
scale同时设置水平方向、垂直方向的缩放比例,一个值代表同时设置水平和垂直缩
放;两个值分别代表:水平缩放、垂直缩放。
  • 功能:按指定的比例缩放元素的大小。
  • 语法:
transform: scale(sx, sy);
  • 示例:transform: scale(2, 1.5); 将元素在X轴方向缩放2倍,Y轴方向缩放1.5倍。
  1. skew() - 倾斜
    • 功能:沿X轴或Y轴倾斜元素。
    • 语法:
transform: skew(ax, ay);
  • 示例:transform: skew(30deg, 20deg); 将元素在X轴方向倾斜30度,Y轴方向倾斜20度。
  1. matrix() - 矩阵
    • 功能:通过矩阵参数对元素进行复杂的2D变换。
    • 语法:
transform: matrix(a, b, c, d, e, f);
  • 示例:transform: matrix(1, 0.5, 0.5, 1, 30, 20); 结合平移、缩放、旋转等效果的2D变换。

3D变换(3D Transform)

3D变换是在三维空间内对元素进行的几何操作。相比2D变换,3D变换更加复杂,可以在Z轴(深度)上对元素进行操作。CSS3中的3D变换主要包括以下几种:

使用 transform-style 开启 3D 空间,可选值如下:
flat : 让子元素位于此元素的二维平面内( 2D 空间)—— 默认值
preserve-3d : 让子元素位于此元素的三维空间内( 3D 空间)

  1. translate3d() - 3D平移
    • 功能:在X、Y、Z三个方向上移动元素。
    • 语法:
transform: translate3d(x, y, z);
  • 示例:transform: translate3d(50px, 100px, 200px); 将元素在X轴上移动50px,Y轴上移动100px,Z轴上移动200px。
  1. rotateX() - 绕X轴旋转
    • 功能:围绕X轴旋转元素。
    • 语法:
transform: rotateX(angle);
  • 示例:transform: rotateX(45deg); 将元素绕X轴旋转45度。
  1. rotateY() - 绕Y轴旋转
    • 功能:围绕Y轴旋转元素。
    • 语法:
transform: rotateY(angle);
  • 示例:transform: rotateY(45deg); 将元素绕Y轴旋转45度。
  1. rotateZ() - 绕Z轴旋转
    • 功能:围绕Z轴旋转元素(与2D变换中的rotate相同)。
    • 语法:
transform: rotateZ(angle);
  • 示例:transform: rotateZ(45deg); 将元素绕Z轴旋转45度。
  1. scale3d() - 3D缩放
    • 功能:在X、Y、Z三个方向上缩放元素。
    • 语法:
transform: scale3d(sx, sy, sz);
  • 示例:transform: scale3d(2, 1.5, 1); 将元素在X、Y、Z方向分别缩放。
  1. perspective() - 视角
    • 功能:设置3D变换的视角距离,使元素在3D空间中有深度感。
    • 语法:
perspective: distance;
  • 示例:
perspective: 500px;
transform: rotateY(45deg);

为元素设置500px的视角,并将其绕Y轴旋转45度。

结语

2D和3D变换为Web设计和开发提供了丰富的视觉效果。掌握这些变换技术,不仅能增强网页的互动性,还能为用户带来更直观、生动的体验。在实际应用中,可以将这些变换与CSS动画结合,创造出更加复杂和有趣的效果。
image.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2038656.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

秒通多语种!2024年超实用的4款翻译在线工具,真心好用

互联网时代让沟通变得没有界限。不论是和邻居闲聊家常,还是与远在海外的朋友畅谈,现在都非常容易。特别是对于正在学习外语的人来说,在线翻译工具就像是超级英雄的披风一样重要。我研究了很多资料,找到了几款性价比非常高的翻译在…

Java虚拟机:类的加载机制

大家好,我是栗筝i,这篇文章是我的 “栗筝i 的 Java 技术栈” 专栏的第 034 篇文章,在 “栗筝i 的 Java 技术栈” 这个专栏中我会持续为大家更新 Java 技术相关全套技术栈内容。专栏的主要目标是已经有一定 Java 开发经验,并希望进…

【BUU】[Dest0g3 520迎新赛]Really Easy SQL

2024/8/14 [Dest0g3 520迎新赛]Really Easy SQL 题目标题说明是SQL注入 题目首页 页面title显示是钓鱼站点。 钓鱼站点主要为将我们的输入信息保存在数据库。后台应该是插入语句。 这里无论输入什么都显示密码错误, 只能尝试盲注,基于时间的盲注, 这里经过测试p…

OPC DAY-上海场提前预告:Softing带您探索“智能工厂中的OPC应用”

(图片来源于:OPC基金会官网) 时间:2024年9月25日 14:00-14:30 | OPC DAY-上海站 地点:上海国家会展中心-5.1H M5-03会议室 2024年9月24-28日,第二十四届中国国际工业博览会将于国家会展中心(上…

Linux 中的同步机制

代码基于:Kernel 6.6 临界资源:指哪些在同一时刻只允许被一个线程访问的软件或硬件资源。这种资源的特点是,如果有线程正在使用,其他进程必须等待直到该线程释放资源。 临界区:指在每个线程中访问临界资源的那段代码。…

vue3结合海康WEB开发包,开发web在线预览视频

我们这里选择V3.3版本 文档地址:https://open.hikvision.com/download/5cda567cf47ae80dd41a54b3?type20&id4c945d18fa5f49638ce517ec32e24e24 解压过后,会有三个文件夹 在docs中,点开Demo使用说明,按照流程先测试下&…

赋能基层,融合创新:EasyCVR视频汇聚平台构建平安城市视频共享系统

一、雪亮工程建设的意义 雪亮工程的核心在于通过高清视频监控、环境监测和智能预警等先进技术手段,构建一个高效、智能、安全、便捷的社会安全防控体系。这一工程的建设不仅代表了现代化科技手段在城市治安管理中的应用,更是提升社会安全保障能力、推动…

树形结构查找(B树、B+树)

平衡树结构的树高为 O(logn) ,平衡树结构包括两种平衡二叉树结构(分别为 AVL 树和 RBT)以及一种树结构(B-Tree,又称 B 树,它的度大于 2 )。AVL 树和 RBT 适合内部存储的应用,而 B 树…

CompreFace Study

系列文章目录 第一章 CompreFace Installation 第二章 Face verification POC 文章目录 系列文章目录前言一、What is the ComreFace?二、How to install the CompreFace? 1.On Linux for CompreFace 1.2.02.Troubleshooting总结 前言 此文旨在记录学习CompreF…

萤石取流播放失败自助排障及常见错误码解决方案

一、在使用播放地址播放时遇到播放失败的情况,可使用排障工具排查具体原因,以下具体介绍排障工具的使用方法 1、在浏览器里打开排障工具,地址:萤石开放平台-提供持续稳定的以音视频为主的全场景、多功能综合性服务 2、在第一行输入…

安全无忧!Windows7全补丁旗舰版:集成所有补丁!

今日,系统之家小编给大家分享集成所有补丁的Windows7旗舰版系统,集成至2023.12所有官方补丁,修复了系统高危漏洞,让大家时刻都能舒心地展开操作。系统基于微软 Windows 7 2009 SP1 旗舰版进行离线制作,全新升级的优化方…

本地环境VMware使用代理解决 Docker 镜像拉取问题

引言 本文将分享我在 Windows 10 环境下,通过 VMware 运行的 CentOS 7.8 虚拟机中配置 Docker 代理,成功解决了镜像拉取问题的经验。 问题描述 在尝试启动一个依赖 Docker 的 GitHub 项目时,拉取 Docker 镜像的失败。尝试配置了几个国内源…

(附源码)基于springboot的智慧社区管理系统-计算机毕设 06797

基于springboot的智慧社区管理系统 摘 要 SpringBoot智慧社区管理系统是一款基于SpringBoot框架开发的智能化社区管理软件,致力于提升社区管理效率和服务质量。该系统涵盖了社区入住管理、物业费管理、公共设施预约等功能,支持在线报修、信息发布、社区活…

Java语言程序设计——篇十三(2)

🌿🌿🌿跟随博主脚步,从这里开始→博主主页🌿🌿🌿 欢迎大家:这里是我的学习笔记、总结知识的地方,喜欢的话请三连,有问题可以私信🌳🌳&…

【运维】报错Resource averaged_perceptron_tagger_eng not found.

文章目录 报错信息解决报错信息 able of handling various complex tasks. Please report the progress of this project to the team members.> ========================<

回溯算法探索篇Ⅲ

Leetcode93——复原IP地址 题目描述&#xff1a; 有效 IP 地址 正好由四个整数&#xff08;每个整数位于 0 到 255 之间组成&#xff0c;且不能含有前导 0&#xff09;&#xff0c;整数之间用 . 分隔。 例如&#xff1a;"0.1.2.201" 和 "192.168.1.1" 是…

PyTorch — 初学者教程

一、说明 在本文中,我将编译 PyTorch 的初学者教程。本教程大量使用了官方 PyTorch 教程中的材料。

Java SE--IO流

一.File类型 如果我们想在程序中操作或者描述一个文件夹或文件&#xff0c;可以使用File类型 File类型在java.io包下 File可以新建&#xff0c;删除&#xff0c;移动&#xff0c;修改&#xff0c;重命名文件夹&#xff0c;也可以对文件或者文件夹的属性进行访问&#xff1b;…

嵌入式软件--模电基础 DAY 2

强电和弱电&#xff0c;简单一点是以电死人为标准的&#xff0c;交流电36伏特以下&#xff0c;直流电24V以下&#xff0c;为安全电压&#xff0c;是为弱电&#xff0c;反则强电。 市电进入家庭&#xff0c;连接你的电脑&#xff0c;220V的电压为什么没有让你感到危险&#xff…

【TiDB】09-修改tidb客户端访问密码

目录 1、修改配置文件 2、停止tidb-server 3、以root方式启动脚本 4、修改密码 5、停止脚本重启服务 1、修改配置文件 进入tidb-server默认部署位置 #切换tidb账号 su tidb# 进入tidb-server部署路径 cd /tidb-deploy/tidb-4000# 修改配置 vim ./conf/tidb.toml添加内容…