HTML canvas transform() 方法

定义和用法

画布上的每个对象都拥有一个当前的变换矩阵。

transform() 方法替换当前的变换矩阵。它以下面描述的矩阵来操作当前的变换矩阵:

a  c  e
b  d  f
0  0  1

换句话说,transform() 允许您缩放、旋转、移动并倾斜当前的环境。

주의:该变换只会影响 transform() 方法调用之后的绘图。

주의:transform() 方法的行为相对于由 rotate()scale()translate() 或通过 transform() 完成的其他变换。例如:如果您已经将绘图设置为放大两倍,则 transform() 方法会把绘图放大两倍,您的绘图最终将放大四倍。

提示:请查看 setTransform() 方法,它不会相对于其他变换来发生行为。

实例

绘制一个矩形;通过 transform() 添加一个新的变换矩阵,再次绘制矩形;添加一个新的变换矩阵,然后再次绘制矩形。请注意,每当您调用 transform() 时,它都会在前一个变换矩阵上构建:

您的浏览器不支持HTML5 canvas标签。

JavaScript:

var c=document.getElementById("myCanvas");
var ctx=c.getContext("2d");
ctx.fillStyle="yellow";
ctx.fillRect(0,0,250,100)
ctx.transform(1,0.5,-0.5,1,30,10);
ctx.fillStyle="red";
ctx.fillRect(0,0,250,100);
ctx.transform(1,0.5,-0.5,1,30,10);
ctx.fillStyle="blue";
ctx.fillRect(0,0,250,100);

직접 시도해보세요

문법

context.transform(a,b,c,d,e,f);

파라미터 값

파라미터 설명
a 수평 축소 그래픽
b 수평 기울기 그래픽
c 수직 기울기 그래픽
d 수직 축소 그래픽
e 수평 이동 그래픽
f 수직 이동 그래픽

브라우저 지원

표에서는 각 속성을 최초로 완전히 지원하는 브라우저 버전을 기재했습니다.

Chrome Edge Firefox Safari Opera
Chrome Edge Firefox Safari Opera
4.0 9.0 3.6 4.0 10.1

주의:Internet Explorer 8 및 이전 버전은 <canvas> 요소를 지원하지 않습니다.