canvas的绘图2

举报
tea_year 发表于 2021/12/29 23:58:52 2021/12/29
【摘要】 <!DOCTYPE html><html> <head> <meta charset="utf-8" /> <title></title> </head> <body> <canvas id="canvas1" width="80...

  
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8" />
  5. <title></title>
  6. </head>
  7. <body>
  8. <canvas id="canvas1" width="800" height="800"></canvas>
  9. <script>
  10. function draw1(){
  11. var c=document.getElementById("canvas1");
  12. var ctx=c.getContext("2d");
  13. ctx.fillStyle='red';
  14. ctx.fillRect(0,0,150,150);
  15. ctx.save();
  16. ctx.fillStyle='green';
  17. ctx.fillRect(15,15,120,120);
  18. ctx.save();
  19. ctx.fillStyle='blue';
  20. ctx.fillRect(30,30,90,90);
  21. ctx.restore();
  22. ctx.fillRect(45,45,60,60);
  23. ctx.restore();
  24. ctx.fillRect(60,60,30,30);
  25. }
  26. window.addEventListener("load",draw1(),true);
  27. </script>
  28. </body>
  29. </html>

在绘图代码上如果不加save属性会怎么样呢?则默认是红色的,保存一次颜色,需要加一次save.



  
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title></title>
  6. </head>
  7. <body>
  8. <canvas id="canvas2" width="800" height="800"></canvas>
  9. <script>
  10. function draw2(){
  11. var c=document.getElementById("canvas2");
  12. var ctx=c.getContext("2d");
  13. ctx.fillStyle="red";
  14. ctx.font="40px 隶书";
  15. ctx.fillText("Hello H5",0,100);
  16. ctx.setTransform(1,-0.5,0,-1,0,2);
  17. ctx.fillText("Hello H5", 0, -100)
  18. }
  19. window.addEventListener("load",draw2(),true);
  20. </script>
  21. </body>
  22. </html>

定义和用法

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

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

a  c  e
b  d  f
0  0  1

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

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

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



JavaScript 语法:

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

参数值

参数 描述
a 水平缩放绘图
b 水平倾斜绘图
c 垂直倾斜绘图
d 垂直缩放绘图
e 水平移动绘图
f 垂直移动绘图

该旋转方法,仍然遵循逆时针为负,顺时针为正的原则


视频课堂https://edu.csdn.net/course/play/7621

文章来源: aaaedu.blog.csdn.net,作者:tea_year,版权归原作者所有,如需转载,请联系作者。

原文链接:aaaedu.blog.csdn.net/article/details/78689332

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。