css3 matrix 矩阵
2D矩阵变换
matrix(1,0,0,1,0,0) 对应 matrix (a,b,c,d,e,f)

其中,x, y表示转换元素的所有坐标(变量)了,
3*3矩阵每一行的第1个值与后面1*3的第1个值相乘,第2个值与第2个相乘,第3个与第3个,然后相加
ax+cy+e为变换后的水平坐标,bx+dy+f表示变换后的垂直位置
偏移:e---水平偏移距离 f-----垂直偏移距离 css3单位px
现在,我们根据这个矩阵偏移元素的中心点,假设是(0, 0),即x=0, y=0。
假设 x y 偏移30px
x坐标就是 ax+cy+e = *+*+ =
y坐标就是 bx+dy+f = *+*+ =
缩放:a---缩放X 水平 d----缩放Y垂直 css3单位 num
假设 s 代表 缩放
x' = ax+cy+e = s*x+0*y+0 = s*x;
y' = bx+dy+f = 0*x+s*y+0 = s*y;
也就是matrix(sx, 0, 0, sy, 0, 0);,等同于scale(sx, sy);
拉伸:b---拉伸Y垂直 c-----拉伸X 水平 css3单位弧度angle
matrix(,tan(θy),tan(θx),,,);
tanValY = Math.tan(deg * Math.PI / 180);
tanValX = Math.tan(deg * Math.PI / 180);
x' = x+y*tan(θx)+0 = x+y*tan(θx)
y' = x*tan(θy)+y+0 = x*tan(θy)+y
对应于skew(θx + "deg",θy+ "deg")这种写法
旋转:a b c d 4个值 css3单位弧度angle
matrix(cosθ,sinθ,-sinθ,cosθ,,)
cosVal = Math.cos(deg * Math.PI / 180);
sinVal = Math.sin(deg * Math.PI / 180);
x' = x*cosθ-y*sinθ+0 = x*cosθ-y*sinθ
y' = x*sinθ+y*cosθ+0 = x*sinθ+y*cosθ deg=30; //角度
cos=Math.cos(30 * Math.PI / 180);
deg2=Math.acos(cos) * 180 / Math.PI; // 反三角函数
rotate(θdeg)这种书写形式要比matrix简单多了,首先记忆简单,其次,无需计算。例如,旋转30°
matrix表示则还要计算cos, sin值:transform: matrix(0.866025,0.500000,-0.500000,0.866025,0,0);
css3 直接: transform:rotate(30deg);
镜像对称效果:
轴围绕的那个点就是CSS3中transform变换的中心点,自然,镜像对称也不例外。因为该轴永远经过原点,因此,任意对称轴都可以用y = k * x表示
则matrix表示就是:
matrix((-k*k) / (+k*k), 2k / ( + k*k), 2k / ( + k*k), (k*k - ) / (+k*k), , )
如下图,已经y=kx,并且知道点(x, y)坐标,求其对称点(x’, y’)的坐标?

很简单,一是垂直,二是中心点在轴线上,因此有:
(y-y') / (x - x') = -/ k → ky-ky' = -x+x' //两条直线垂直,它们的斜率互为负倒数
(x + x') / 2 * k = (y + y')/ → kx+kx' = y+y'
很简单的,把x'和y'提出来,就有:
x' = (1-k*k)/(k*k+1) *x + 2k/(k*k+1) *y;
y' = 2k/(k*k+1) *x + (k*k-1)/(k*k+1) *y;
再结合矩阵公式:
x' = ax+cy+e;
y' = bx+dy+f;
我们就可以得到:
a = (-k*k)/(k*k+);
b = 2k/(k*k+);
c = 2k/(k*k+);
d = (k*k-)/(k*k+);
也就是上面matrix方法中的参数值啦!
3D变换中的矩阵
矩阵里头是从3*3变成4*4, 9到16, 2D 变换 加一个 Z轴
matrix3d(sx, 0, 0, 0, 0, sy, 0, 0, 0, 0, sz, 0, 0, 0, 0, 1)

perspective :透视 --- 距离多远看图像
如果父元素 perspective :200px ;(因为元素远去,我们眼睛看到的就会变小);translateZ值越大,该元素也会越来越大,当translateZ值非常接近200像素,但是不超过200像素的时候 (如199像素),该元素的大小就会撑满整个屏幕(如果父辈元素没有类似overflow:hidden的限制的话)。
perspective-origin眼睛看的位置,默认就是所看舞台或元素的中心 ,值为: left center right length % ; perspective-origin: x-axis y-axis;
transform-style: preserve-3d 表示3D透视
backface-visibility: hidden; 后面元素不可见
css3 matrix 矩阵的更多相关文章
- 【CSS3】 理解CSS3 transform中的Matrix(矩阵)
		
理解CSS3 transform中的Matrix(矩阵) by zhangxinxu from http://www.zhangxinxu.com 本文地址:http://www.zhangxinxu ...
 - 理解CSS3 transform中的Matrix(矩阵)
		
一.哥,我被你吓住了 打架的时候会被块头大的吓住,学习的时候会被奇怪名字吓住(如“拉普拉斯不等式”).这与情感化设计本质一致:界面设计好会让人觉得这个软件好用! 所以,当看到上面“Matrix(矩阵) ...
 - css3 matrix 2D矩阵和canvas transform 2D矩阵
		
一看到“2D矩阵”这个高大上的名词,有的同学可能会有种畏惧感,“矩阵”,看起来好高深的样子,我还是看点简单的吧.其实本文就很简单,你只需要有一点点css3 transform的基础就好. 没有前戏,直 ...
 - 理解CSS3 transform中的Matrix(矩阵)——张鑫旭
		
by zhangxinxu from http://www.zhangxinxu.com本文地址:http://www.zhangxinxu.com/wordpress/?p=2427 一.哥,我被你 ...
 - css3 transform中的matrix矩阵
		
CSS3中的矩阵CSS3中的矩阵指的是一个方法,书写为matrix()和matrix3d(),前者是元素2D平面的移动变换(transform),后者则是3D变换.2D变换矩阵为3*3, 如上面矩阵示 ...
 - 前端matrix矩阵的变化
		
css3 transform中的matrix矩阵 CSS3中的矩阵CSS3中的矩阵指的是一个方法,书写为matrix()和matrix3d(),前者是元素2D平面的移动变换(transform), ...
 - HDU5015 233 Matrix(矩阵高速幂)
		
HDU5015 233 Matrix(矩阵高速幂) 题目链接 题目大意: 给出n∗m矩阵,给出第一行a01, a02, a03 ...a0m (各自是233, 2333, 23333...), 再给定 ...
 - String数据转Matrix矩阵
		
String数据转Matrix矩阵 private Matrix String_To_Matrix(string str) { int[] Remove_Num = new int[10]; int ...
 - Leetcode 566. Reshape the Matrix 矩阵变形(数组,模拟,矩阵操作)
		
Leetcode 566. Reshape the Matrix 矩阵变形(数组,模拟,矩阵操作) 题目描述 在MATLAB中,reshape是一个非常有用的函数,它可以将矩阵变为另一种形状且保持数据 ...
 
随机推荐
- Linux系统下Oracle执行SQL脚本后中文出现乱码解决方法
			
先确认Oracle的字符集,sqlplus登录Oracle后执行语句: [sql] select userenv('language') from dual; 返回值例如:AMERICAN_AME ...
 - nginx 限制solr
			
server { listen 80; server_name bai.com www.bai.com; location /solr/ { allow 192.168.0.0/24; allow ...
 - DAY7-面向对象之多态与多态性
			
一.多态 多态指的是一类事物有多种形态 动物有多种形态:人,狗,猪 import abc class Animal(metaclass=abc.ABCMeta): #同一类事物:动物 @abc.abs ...
 - Tornado模板配置
			
#!/usr/bin/env python # -*- coding:utf-8 -*- #tornado模板配置 import tornado.ioloop import tornado.web c ...
 - 201671010127 2016—2017—2 Java学习周结
			
时间真是个最公平东西,只要能够好好地利用它,它可以为我们带来我们我们所想要的东西.学习Java已经有一周了,对于Java基础知识的认识也更进一步,对Java的兴趣也愈来愈浓.实现一个Java程序,主要 ...
 - python 爬虫 下载图片
			
import os#导入操作系统模块from urllib.request import urlretrieve#下载url对应的文件from urllib.request import urlope ...
 - SQL IN, NOT IN, EXISTS, NOT EXISTS
			
IN与EXISTS执行流程 IN:在查询的时候,首先查询子查询的表,然后将内表和外表做一个笛卡尔积,然后按照条件进行筛选.所以相对内表比较小的时候,in的速度较快.(IN时不对NULL进行处理) EX ...
 - Struts2框架01【如果使用struts框架】【利用struts框架写一个 hello world】
			
1 什么是Struts2框架 基于MVC设计模式的web应用框架 Struts2框架是一个轻量级的MVC流程框架 轻量级是指程序的代码不是很多,运行时占用的资源不是很多,MVC流程框架就是说它是支持分 ...
 - EZOJ #78
			
传送门 分析 AC自动机板子题qwq 不过似乎可以哈希(因为所有模式串的长度相同,所以哈希乱搞就可以) 代码 #include<iostream> #include<cstdio&g ...
 - Netty中的Future
			
先看下Future的整个继承体系,还有一个ChannelFuture不在里面: 在并发编程中,我们通常会用到一组非阻塞的模型:Promise,Future 和 Callback.其中的 Fut ...