当前位置: 首页 > news >正文

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

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

相关文章:

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

文章目录 2D变换(2D Transform)3D变换(3D Transform)结语 CSS3中的2D变换与3D变换是指通过transform属性对HTML元素进行几何操作,使其在二维或三维空间中进行移动、旋转、缩放和倾斜等变换。这些变换为前端开发者提供了…...

大恒相机通过Line2或Line3直接给出3.3V触发,形成分时曝光

大恒相机通过Line2或Line3直接给出3.3V触发,形成分时曝光 一、分时曝光需求二、3.3V信号分时曝光设计 写在前面 上班了,没多少时间再去精度论文了,大多是项目上的事情。 一、分时曝光需求 一般的12V光源通过光源控制器与大恒相机Line1线连接…...

electronjs实现打开的网页密码自动保存

在 Electron 中实现自动保存网页密码的功能涉及到几个步骤,以下是一个基本的实现思路: 1. 监听登录事件 首先,你需要监听用户的登录事件。当用户在一个网页上登录后,通常会有一个 POST 请求发送到服务器验证凭据。你可以监听这个…...

观测云的自动化监控:CRD 资源与自动发现

在云原生技术快速发展的今天,Kubernetes已成为企业容器化应用的中心舞台。随着应用的规模化和动态化,传统的监控方法已经难以满足需求。自动化监控,以其高效性和准确性,成为云原生监控的新趋势。观测云平台通过与Kubernetes的深度…...

九、OpenCVSharp 中的图像形态学操作

文章目录 简介一、腐蚀1. 腐蚀的原理和数学定义2. 结构元素的形状和大小选择3. 腐蚀操作的代码实现和效果展示二、膨胀1. 膨胀的概念和作用2. 与腐蚀的对比和组合使用(如开运算、闭运算)三、开运算1. 开运算的定义和用途(去除小的明亮区域)2. 开运算在去除噪声和分离物体方…...

http和websocket

http和websocket是什么 网络通信的协议 区别 http: 只能客户端发送,服务端接收。 websocket: 客户端和服务端都可以发送和接收数据。 链接...

Go 语言错误处理

不管使用哪种语言,程序代码都可能包含各种错误,例如语法错误、逻辑错误、除 0 错误和文件缺失等。因此,每种编程语言都有处理错误的内置机制。 1. Go 程序中的错误 需要指出的是,错误有多种类型。语法错误通常是开发人员在编写代…...

LVS部分配置1

LVS nat服务器(作时间服务器) [rootlocalhost ~]# systemctl stop firewalld [rootlocalhost ~]# setenforce 0 [rootlocalhost ~]# yum -y install ntpdate [rootlocalhost ~]# ntpdate cn.ntp.org.cn [rootlocalhost ~]# which ntpdate [rootlocalhost…...

datax和datax-web打包成docker运行

概述 datax和datax-web从一台机器迁移到另一台时,要重新搭建一套运行环境,比较麻烦;打包成docker镜像后迁移就方便多了; 因为我的mysql版本是8,需要在datax的read和write中手动添加8的jdbc驱动 所以我先各自下载好了datax和data…...

命令行参数环境变量

目录 前言: 命令行参数: 现象: 这些参数的意义: 为什么要这么做? 这些事是谁做的呢? 环境变量 现象: 创建环境变量: 结合程序理解: 前言: 我们在前…...

『大模型笔记』WizardLM:使大型预训练语言模型能够遵循复杂的指令

WizardLM: Empowering Large Pre-Trained Language Models to Follow Complex Instructions 文章目录 一. WizardLM:使大型预训练语言模型能够遵循复杂的指令二. Evolve-Instruct(优化版)2.1. 概述2.2. 实施二. 参考文献WizardLM:使大型预训练语言模型能够遵循复杂的指令:…...

编程-设计模式 2:抽象工厂模式

设计模式 2:抽象工厂模式 定义与目的 定义:抽象工厂模式提供一个接口,用于创建一系列相关或相互依赖的对象,而无需指定它们具体的类。目的:该模式的主要目的是解耦客户端代码与产品类之间的关系,并确保一…...

阿里云智能大数据演进

本文根据7月24日飞天发布时刻产品发布会、7月5日DataFunCon2024北京站:大数据大模型.双核时代实录整理而成,演讲信息如下: 演讲人:徐晟 阿里云研究员/计算平台产品负责人 主要内容: Overview - 阿里云大数据 AI 产品…...

Java面试题———Spring篇①

目录 一,谈谈你对SpringIOC的理解 二,Spring中有哪些依赖注入方式 三,你用过哪些Spring注解 四,SpringBean的作用域有几种 五,Spring中的bean线程安全吗 六,谈谈你对SpringAOP的理解 七,…...

4章10节:用R做数据重塑,变体函数应用详解和可视化的数据预处理介绍

数据重塑(Data Reshaping)是将数据从一种结构转换为另一种结构的过程,是清理、分析和可视化数据的重要步骤。R语言作为数据科学的强大工具,提供了许多包来帮助我们进行数据重塑,其中最常用的就是dplyr包。dplyr包以其简洁的语法和高效的操作速度著称,它不仅可以帮助我们进…...

Socks5代理IP在跨境电商和网络爬虫领域的实战应用

在现代互联网环境中,Socks5代理IP因其强大的灵活性和隐私保护功能,成为了跨境电商和网络爬虫领域的重要工具。本文将探讨Socks5代理IP的基本原理,并详细介绍其在跨境电商和网络爬虫中的实际应用。 1. Socks5代理IP简介 Socks5代理IP是一种网…...

农业上的目标跟踪论文汇总

文章目录 2022Multi-object tracking using Deep SORT and modified CenterNet in cotton seedling counting (Computers and Electronics in Agriculture)A novel apple fruit detection and counting methodology based on deep learning and trunk tracking in modern orcha…...

gpxt 小程序:轨迹合并与管理的高效工具

引言 在户外探险和运动追踪领域,GPXT小程序以其独特的轨迹管理和合并功能脱颖而出,成为徒步、骑行等运动爱好者不可或缺的工具。本文将详细介绍GPXT小程序的核心功能及其对户外活动爱好者的实用性。 核心功能概览 轨迹合并 GPXT小程序允许用户将多个…...

elasticsearch集成springboot详细使用

1.es下载&配置 配置JVM 配置跨域 配置https和密码 2.es启动 .\elasticsearch.bat 或 后台启动: nohup ./bin/elasticsearch& 浏览器访问:https://localhost:9200 输入账户:elastic / 123456 3.重置es密码 .\elasticsearch-r…...

html+css网页制作 化妆品电商4个页面

htmlcss网页制作 化妆品电商4个页面 网页作品代码简单,可使用任意HTML编辑软件(如:Dreamweaver、HBuilder、Vscode 、Sublime 、Webstorm、Text 、Notepad 等任意html编辑软件进行运行及修改编辑等操作)。 获取源码 1&#xff…...

springboot+vue基于web的高校学生宿舍报修系统

目录同行可拿货,招校园代理 ,本人源头供货商高校学生宿舍报修系统功能分析(SpringBootVue)系统角色划分核心功能模块学生端功能维修端功能管理端功能系统管理功能技术实现要点扩展功能建议数据安全考虑项目技术支持源码获取详细视频演示 :文章…...

如何突破Cursor AI编程助手的使用限制:技术原理与实践指南

如何突破Cursor AI编程助手的使用限制:技术原理与实践指南 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reached your…...

WPF 实现windows文件压缩文件解压过程动画

目标:最终实现:整体拆分,分步实现:1.控件的基底,是一个实心的矩形2.在基底上绘制绿色网格线,类似棋盘的效果3.有进度条显示,进度条是长度可变的浅绿色的矩形块4.有实时速度显示,速度…...

短视频 SEO 如何提高网站的搜索排名

为什么短视频 SEO 是提高网站搜索排名的关键 在当今数字化时代,短视频平台已经成为人们获取信息和娱乐的主要渠道。短视频的流行不仅改变了人们的观看习惯,还深刻影响了网络营销的方式。如何利用短视频 SEO(搜索引擎优化)来提高网…...

【飞控】QGroundControl与Mission Planner:如何根据项目需求选择最佳地面站

1. 两款地面站软件的核心定位差异 第一次接触无人机开发时,我也曾被QGroundControl和Mission Planner搞得晕头转向。这两款软件就像工具箱里的不同工具,关键是要知道什么时候该用哪一把。QGroundControl(简称QGC)给我的第一印象是…...

手把手教你用Matlab把PLL相噪曲线算成Jitter(附三种方法源码)

从PLL相噪曲线到Jitter计算的Matlab实战指南 在射频系统设计中,锁相环(PLL)的相位噪声性能直接影响通信质量与系统稳定性。频谱分析仪虽能捕捉相噪曲线,但工程师常需将其转换为更直观的时间抖动(Jitter)指标。本文将系统介绍三种Matlab实现方案&#xff…...

抽象推理终极指南:10个ARC经典案例解析助你掌握核心技巧

抽象推理终极指南:10个ARC经典案例解析助你掌握核心技巧 【免费下载链接】ARC-AGI The Abstraction and Reasoning Corpus 项目地址: https://gitcode.com/GitHub_Trending/ar/ARC-AGI 抽象与推理语料库(ARC)是一个专门用于评估通用人…...

Qwen3.5-9B-AWQ-4bit实战教程:用‘概括最重要信息’提示词压缩冗余输出

Qwen3.5-9B-AWQ-4bit实战教程:用"概括最重要信息"提示词压缩冗余输出 1. 认识Qwen3.5-9B-AWQ-4bit模型 Qwen3.5-9B-AWQ-4bit是一个强大的多模态AI模型,它能同时理解图片和文字。想象一下,你给这个AI看一张照片,然后问…...

SpeedyBee F405 V4 55A飞塔到手后,这5个关键步骤和3个常见坑点你必须知道

SpeedyBee F405 V4 55A飞塔实战指南:从开箱到首飞的深度解析 穿越机玩家拿到新飞塔的兴奋感,就像赛车手拿到新引擎——但这份喜悦往往伴随着"如何正确启动"的焦虑。SpeedyBee F405 V4 55A飞塔作为当前中高端穿越机的热门选择,其性能…...

保姆级教程:用ColabFold在线版AlphaFold2,5分钟搞定你的第一个蛋白质结构预测

零门槛玩转蛋白质结构预测:ColabFold极简指南 蛋白质结构预测曾是生物信息学领域的"圣杯",直到AlphaFold2的出现彻底改变了游戏规则。但传统方法需要复杂的本地环境配置和命令行操作,让许多感兴趣的非专业人士望而却步。现在&…...