引言
在使用 css 样式进行样式的缩放、旋转等设置时,思考了一下它的较浅层的原理,恩,这个阶段都 是一些初高的数学计算,从新看这里的时候顺便捡了捡初高中的数学,比如三角函数之类。
通用公式
data:image/s3,"s3://crabby-images/ccb05/ccb05bb1c47619d1dba4fa2e8bd770314eb9c9ab" alt=""
假设 A * B = Y。其中,A 为 m * n 的 m 行 n 列矩阵,B 为 1 * n 列的矩阵。B 拆分为列向量,并且列向量的维数就是矩阵的行数。
方法
transform(a, b, c, d, e, f) 与 Matrix 的转换。
data:image/s3,"s3://crabby-images/bef05/bef053dad3b0e187ad6d81179e851bc82aafc8b7" alt=""
推导出来
data:image/s3,"s3://crabby-images/3aff7/3aff7231bcd48196d2afe1186a7db078c6cb1d95" alt=""
简化后
data:image/s3,"s3://crabby-images/52405/52405939c19379f1489ba044843022dfb8aaccce" alt=""
缩放
data:image/s3,"s3://crabby-images/494e4/494e4b9f7bc0dcb7200982afa1887b794b85e430" alt=""
推导出来
data:image/s3,"s3://crabby-images/e0b9a/e0b9ae2d90af082b2d86da26ee7c6eecc7be8fff" alt=""
css
.box {
transform: scale(0.3, 0.6);
}
通过计算
data:image/s3,"s3://crabby-images/24da7/24da797e9c191744e6d57681a96d9230bf9dd012" alt=""
等价于
css
.box {
transform: matrix(0.3, 0, 0, 0.6, 0, 0);
}
data:image/s3,"s3://crabby-images/eb74e/eb74e7ef31987829528bb13a345aab88b0ae6fe6" alt=""
平移
data:image/s3,"s3://crabby-images/f3e24/f3e24e53a50d04e40b939d7f6778c47d8c2c2a94" alt=""
推导出来
data:image/s3,"s3://crabby-images/94268/94268b43e35d263b0ce928c1a3065581e9309738" alt=""
转旋
data:image/s3,"s3://crabby-images/9d8e4/9d8e4a69f4a455a64f4ec46af92479d38a59506c" alt=""
推导出来
data:image/s3,"s3://crabby-images/9532e/9532e25c1e2c3bde9f19d95319413d67e2d7b4e5" alt=""
假设存在点 E 移动至点 F。设 E 坐标为(x1, y1),F 坐标为(x2, y2),D 坐标为(a, b)。
简要图示:
data:image/s3,"s3://crabby-images/cba72/cba72ebf3efafcf4ee498e130c6b5130e78f1991" alt=""
初中数学:
data:image/s3,"s3://crabby-images/b681b/b681b53f430348cfb1b3b7c1ea88083f7fbbb937" alt=""
演算:
data:image/s3,"s3://crabby-images/30e35/30e359a334be705069241fc1884acd1d7e59ade3" alt=""
推导:
data:image/s3,"s3://crabby-images/af115/af115a43554039ea4d458f62912ce84b7342fffa" alt=""
data:image/s3,"s3://crabby-images/839af/839afa8623e59c71c2ac131bdc7e20b850ed28d0" alt=""
验证:
data:image/s3,"s3://crabby-images/9ee43/9ee430eaf009c482249c4ff26872da7ff760e2b5" alt=""
转换为矩阵:
data:image/s3,"s3://crabby-images/cf6a3/cf6a399367fc19681e497471e7227262279c2af0" alt=""
从 css 语法上开始转换
css
.box {
transform: rotate(30deg);
}
这个旋转套用公式
data:image/s3,"s3://crabby-images/86ae2/86ae256c131b061e0cf062805ff4192c7c44e7f8" alt=""
等价于
css
.box {
transform: matrix(0.86, 0.5, -0.5, 0.86, 0, 0);
}
data:image/s3,"s3://crabby-images/1ea5b/1ea5b0fe8a8dc771dc159afe67208c09457f6c98" alt=""
复合
css
.box {
transform: rotate(30deg) scale(0.3, 0.6);
}
复合需要进行矩阵乘法计算
data:image/s3,"s3://crabby-images/88591/885917d3ffa161ff4f88f501307e0146ff88ed67" alt=""
等价于
css
.box {
transform: matrix(0.258, 0.15, -0.3, 0.516, 0, 0);
}
最后,后续本文修正和更新,请参阅:'kangkk.cn/index.php/计...'