css的transform样式计算-第一节

引言

在使用 css 样式进行样式的缩放、旋转等设置时,思考了一下它的较浅层的原理,恩,这个阶段都 是一些初高的数学计算,从新看这里的时候顺便捡了捡初高中的数学,比如三角函数之类。

通用公式

假设 A * B = Y。其中,A 为 m * n 的 m 行 n 列矩阵,B 为 1 * n 列的矩阵。B 拆分为列向量,并且列向量的维数就是矩阵的行数。

方法

transform(a, b, c, d, e, f) 与 Matrix 的转换。

推导出来

简化后

缩放

推导出来

css 复制代码
.box {
  transform: scale(0.3, 0.6);
}

通过计算

等价于

css 复制代码
.box {
  transform: matrix(0.3, 0, 0, 0.6, 0, 0);
}

平移

推导出来

转旋

推导出来

假设存在点 E 移动至点 F。设 E 坐标为(x1, y1),F 坐标为(x2, y2),D 坐标为(a, b)。

简要图示:

初中数学:

演算:

推导:

验证:

转换为矩阵:

从 css 语法上开始转换

css 复制代码
.box {
  transform: rotate(30deg);
}

这个旋转套用公式

等价于

css 复制代码
.box {
  transform: matrix(0.86, 0.5, -0.5, 0.86, 0, 0);
}

复合

css 复制代码
.box {
  transform: rotate(30deg) scale(0.3, 0.6);
}

复合需要进行矩阵乘法计算

等价于

css 复制代码
.box {
  transform: matrix(0.258, 0.15, -0.3, 0.516, 0, 0);
}

最后,后续本文修正和更新,请参阅:'kangkk.cn/index.php/计...'

相关推荐
东风西巷1 小时前
PDFgear:免费全能的PDF处理工具
前端·pdf·软件需求
森之鸟2 小时前
Mac电脑上如何打印出字体图标
前端·javascript·macos
mCell2 小时前
GSAP 入门指南
前端·javascript·动效
gnip3 小时前
组件循环引用依赖问题处理
前端·javascript
Aotman_4 小时前
el-input textarea 禁止输入中文字符,@input特殊字符实时替换,光标位置保持不变
前端·javascript·vue.js·前端框架·es6
Nan_Shu_6144 小时前
Web前端面试题(1)
前端·面试·职场和发展
lypzcgf4 小时前
Coze源码分析-资源库-创建知识库-前端源码-核心组件
前端·typescript·react·coze·coze源码分析·ai应用平台·agent开发平台
百思可瑞教育4 小时前
在Vue项目中Axios发起请求时的小知识
前端·javascript·vue.js·北京百思教育
患得患失9495 小时前
【个人项目】【前端实用工具】OpenAPI to TypeScript 转换器
前端·javascript·typescript
大前端helloworld5 小时前
前端梳理体系从常问问题去完善-基础篇(html,css,js,ts)
前端·javascript·面试