transform() 是 Canvas 2D API 使用矩陣多次疊加當(dāng)前變換的方法,矩陣由方法的參數(shù)進行描述。你可以縮放、旋轉(zhuǎn)、移動和傾斜上下文。
繪制一個矩形,使用transform()添加一個新的變換矩陣,再次繪制該矩形,添加一個新的變換矩陣,然后再次繪制該矩形。請注意,每次調(diào)用transform()時,它都基于先前的轉(zhuǎn)換矩陣:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>HTML canvas transform()方法使用-菜鳥教程(cainiaoplus.com)</title> </head> <body> <canvas id="myCanvas" width="300" height="150" style="border:1px solid #d3d3d3;"> 您的瀏覽器不支持 HTML5 canvas 標(biāo)簽。 </canvas> <script> var c=document.getElementById("myCanvas"); var ctx=c.getContext("2d"); ctx.fillStyle="green"; 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); </script> </body> </html>測試看看 ?/?
IEFirefoxOperaChromeSafari
Internet Explorer 9、Firefox、Opera、Chrome 和 Safari 支持 transform() 方法。
注意:Internet Explorer 8 及之前的版本不支持 <canvas> 元素。
畫布上的每個對象都擁有一個當(dāng)前的變換矩陣。
transform() 方法替換當(dāng)前的轉(zhuǎn)換矩陣。它將當(dāng)前變換矩陣與以下描述的矩陣相乘:
a | c | e |
b | d | f |
0 | 0 | 1 |
換句話說,transform() 允許您縮放、旋轉(zhuǎn)、移動并傾斜當(dāng)前的環(huán)境。
注意:該變換只會影響 transform() 方法調(diào)用之后的繪圖。
注意:transform() 方法的行為相對于由 rotate()、scale()、translate() 或 transform() 完成的其他變換。 例如:如果您已經(jīng)將繪圖設(shè)置為放到兩倍,則 transform() 方法會把繪圖放大兩倍,您的繪圖最終將放大四倍。
提示:請查看 setTransform() 方法,它不會相對于其他變換來發(fā)生行為。
JavaScript 語法: | context.transform(a,b,c,d,e,f); |
---|
參數(shù) | 描述 |
---|---|
a | 水平縮放繪圖。 |
b | 水平傾斜繪圖。 |
c | 垂直傾斜繪圖。 |
d | 垂直縮放繪圖。 |
e | 水平移動繪圖。 |
f | 垂直移動繪圖。 |