AxeSlide软件项目梳理   canvas绘图系列知识点整理

画布操作介绍

画布绘图的环境通过translate(),scale(),rotate(), setTransform()和transform()来改变,它们会对画布的变换矩阵产生影响。

函数 方法 描述
translate dx,dx 转换的量的 X 和 Y 大小
scale sx,sy 水平和垂直的缩放因子
rotate angle 旋转的量,用弧度表示。正值表示顺时针方向旋转,负值表示逆时针方向旋转。
setTransform a,b,c,d,e,f 水平缩放,水平倾斜(与旋转有关),垂直倾斜(与旋转有关,-水平倾斜),垂直缩放,水平移动,垂直移动
transform a,b,c,d,e,f 水平缩放,水平倾斜,垂直倾斜,垂直缩放,水平移动,垂直移动

translate() 方法为画布的变换矩阵添加水平的和垂直的偏移。参数 dx 和 dy 添加给后续定义路径中的所有点。

scale() 方法为画布的当前变换矩阵添加一个缩放变换。缩放通过独立的水平和垂直缩放因子来完成。例如,传递一个值 2.0 和 0.5 将会导致绘图路径宽度变为原来的两倍,而高度变为原来的 1/2。指定一个负的 sx 值,会导致 X 坐标沿 Y 轴对折,而指定一个负的sy 会导致 Y 坐标沿着 X 轴对折。

rotate() 方法通过指定一个角度,改变了画布坐标和 Web 浏览器中的 <Canvas> 元素的像素之间的映射,使得任意后续绘图在画布中都显示为旋转的。它并没有旋转 <Canvas> 元素本身。注意,这个角度是用弧度指定的。

setTransform() 会将当前的变换矩阵重置为单位矩阵,然后构建新的矩阵。

transform() 添加一个新的变换矩阵,再次绘制矩形,调用 transform() 时,它都会在前一个变换矩阵上构建。

具体使用范例

我们在画布上绘制一个矩形。

 1 <!DOCTYPE html>
 2 <html>
 3 <body>
 4
 5 <canvas id="myCanvas" width="300" height="150" style="border:1px solid #d3d3d3;">
 6 Your browser does not support the HTML5 canvas tag.
 7 </canvas>
 8
 9 <script>
10
11 var c=document.getElementById("myCanvas");
12 var ctx=c.getContext("2d");
13
14 ctx.fillStyle="yellow";
15 ctx.fillRect(0,0,250,100)
16
17 </script>
18
19 </body>
20 </html>

然后画出的图形如下图所示:绘制范围就是从坐标(0,0)开始画一个宽高分别为250,100的矩形。

下面对这个矩形进行平移,缩放,旋转等操作。

1 平移

如果往中间平移的话,我们可以改变它的坐标值例如ctx.fillRect(25,25,250,100),就将矩形起始位置移动到了(25,25)。绘制出的效果如下图:

另外还有一种方法,我们可以通过context的translate方法移动画布,来达到同样的视觉效果。未变换前画布的原点在左上角,使用translate方法后相当于整个坐标系在平移。

注:在操作画布变换矩阵时,最好在变换前使用save方法保存记录画布当前状态,完成绘制后可以使用restore方法恢复变换前的矩阵状态。

1 ctx.save();
2 ctx.translate(25,25);
3 ctx.fillStyle="yellow";
4 ctx.fillRect(0,0,250,100)
5 ctx.restore();

2 缩放

缩放矩形当然可以通过调整宽高的方式这里不再举例说明。

这里主要介绍通过context的scale方法缩放画布的方法,通过以下代码就可以将黄色矩形所缩小到原来的一半(如下图)。

1 ctx.save();
2 ctx.scale(0.5,0.5);
3 ctx.fillStyle="yellow";
4 ctx.fillRect(25,25,250,100);
5 ctx.restore();

3 旋转

旋转图中矩形,就需要把画布矩阵状态通过rotate方法变换下了。rotate(Math.PI/6)就是将画布顺时针旋转30度,画出的矩形如下图。

1 ctx.save();
2 ctx.rotate(Math.PI/6);
3 ctx.fillStyle="yellow";
4 ctx.fillRect(25,25,250,100)
5 ctx.restore();

4 确定中心点

通过图可以看出上面的缩放和旋转都是以画布左上角为中心进行的,如果我们需要以画布中心点为中心进行变换,需要在rotate和scale方法调用前去修正画布的坐标原点位置到画布占位的中心位置ranslate(width/2,height/2),然后进行缩放变换,之后再用ranslate(-width/2,-height/2)修正坐标系。如下代码:

1 ctx.save();
2 ctx.translate(width/2,height/2);//将画布坐标系原点移至中心
3 ctx.rotate(0.5,0.5);//如果是缩放,这里是缩放代码
4 ctx.translate(-width/2,-height/2);//修正画布坐标系
5 ctx.fillStyle="yellow";
6 ctx.fillRect(25,25,250,100)
7 ctx.restore();

效果如下图:

5 设置矩阵

方法setTransform的六个参数上面已经提到,其实可以理解为缩放、旋转、移动的复合方法。当您调用 setTransform() 时,它都会重置前一个变换矩阵然后构建新的矩阵,因此在下面的例子中,不会显示红色矩形,因为它在蓝色矩形下面。

 1 var c=document.getElementById("myCanvas");
 2 var ctx=c.getContext("2d");
 3
 4 ctx.fillStyle="yellow";
 5 ctx.fillRect(0,0,250,100)
 6
 7 ctx.setTransform(1,Math.PI/6,-Math.PI/6,1,30,10);//两个1代表画布进行缩放,Math.PI/6表示顺时针旋转30度,(30,10)表示平移
 8 ctx.fillStyle="red";
 9 ctx.fillRect(0,0,250,100);
10
11 ctx.setTransform(1,Math.PI/6,-Math.PI/6,1,30,10);
12 ctx.fillStyle="blue";
13 ctx.fillRect(0,0,250,100);

和setTransform类似的还有一个方法transform(),它们都有六个参数。但是不同的是每次调用 transform() 时,它都会在前一个变换矩阵上构建。如下代码中先绘制的红色矩形和上图的位置是一致的,画完红色矩形后,再次调用transform(1,Math.PI/6,-Math.PI/6,1,30,10)改变画布,这次变换是在当前画布状态上变换的所以画的蓝色矩形不会和红色的重叠。如下图看上去,红色和黄色的相对位置 与 蓝色和红色的相对位置 是一样的。

 1 var c=document.getElementById("myCanvas");
 2 var ctx=c.getContext("2d");
 3
 4 ctx.fillStyle="yellow";
 5 ctx.fillRect(0,0,250,100)
 6
 7 ctx.transform(1,Math.PI/6,-Math.PI/6,1,30,10);
 8 ctx.fillStyle="red";
 9 ctx.fillRect(0,0,250,100);
10
11 ctx.transform(1,Math.PI/6,-Math.PI/6,1,30,10);
12 ctx.fillStyle="blue";
13 ctx.fillRect(0,0,250,100);

对canvas绘图感兴趣的,还可以参看此博文  http://www.cnblogs.com/fangsmile/p/5644611.html

转载于:https://www.cnblogs.com/fangsmile/p/5647390.html

软件项目技术点(2)——Canvas之平移translate、旋转rotate、缩放scale相关推荐

  1. 软件项目技术点(2)——Canvas之获取Canvas当前坐标系矩阵

    AxeSlide软件项目梳理   canvas绘图系列知识点整理 前言 在我的另一篇博文 Canvas坐标系转换 中,我们知道了所有的平移缩放旋转操作都会影响到画布坐标系.那在我们对画布进行了一系列操 ...

  2. 软件项目技术点(21)——自动保存和恢复

    AxeSlide软件项目梳理   canvas绘图系列知识点整理 自动保存的基本思路 1)软件每次打开都会创建一个保存画布元素信息的文件,文件名是在打开软件时生成的唯一字符串.可同时打开多个窗口,所以 ...

  3. 软件项目技术路线图_创建基本的项目路线图

    软件项目技术路线图 Continuing from my previous article, at this checkpoint, I have two things with me: 上一篇文章的 ...

  4. 软件项目技术路线图_为您的项目创建路线图

    软件项目技术路线图 Scrum has a tool for roadmap and release planning as well. We use two different mechanisms ...

  5. mesh threejs 属性_threeJS创建mesh,创建平面,设置mesh的平移,旋转、缩放、自传、透明度、拉伸...

    这个小案例是当初我在学习的时候,小的一个小案例,代码还需要进一步优化:还请谅解~~:主要用到了threeJS创建mesh,创建平面,设置mesh的平移,旋转.缩放.自传.透明度.拉伸等这些小功能: 采 ...

  6. WebGL入门(六)-通过坐标计算实现图形的平移、旋转和缩放变换

    通过坐标计算实现图形的平移.旋转和缩放变换 1.图形的平移 1.1平移效果说明 1.2平移原理说明 1.3平移图形的实现步骤 1.3.1在顶点着色器中声明存放平移信息的uniform变量u_Trans ...

  7. 偏移shaderuv_Unity Shader UV平移、旋转、缩放效果

    平移.旋转.缩放.扭曲这几个效果在很多游戏场景中都会运用到,本篇文章就给大家分享下在Unity中基于Shader实现UV平移.旋转.缩放效果. 平移效果: 旋转: 缩放: 扭曲效果: shader代码 ...

  8. Matlab图像的平移,旋转,缩放,裁剪

    %%------------------------Matlab图像的平移,旋转,缩放,裁剪------------------------------- %-------------------头文 ...

  9. 计算机图形与OpenGL学习五(二维几何变换1.平移、旋转、缩放)

    二维几何变换(平移.旋转.缩放) 本章涉及数学变换比较多,代码是次要的,数学理论可自己推导一下. [二维平移] 通过将二维量加到一个点的坐标上来生成一个新的坐标位置,可以实现一次平移.将平移距离加到原 ...

最新文章

  1. php mysql特殊符号过滤微信小程序_微信小程序数据过滤(filter)方法
  2. akka es/cqrs_在Akka中实现主从/网格计算模式
  3. 总结C++中取成员函数地址的几种方法
  4. 详解vue静态资源打包中的坑与解决方案
  5. ubuntu16.04初安装,ROS kinetic,安装ros,配置ros环境
  6. Instruments-Automation: 通过命令行执行测试用例
  7. VMware5.5的序列号
  8. 2021年井冈山中学高考成绩查询入口,【高考成绩】2019年高考成绩揭晓,井冈山中学取得好成绩!...
  9. 如何解决仓库无线网络覆盖问题?
  10. Python数据分析:柱形图的绘制方法
  11. 木纹标识lisp_Lisp 中的 string 和 symbol 的区别?
  12. 神经网络权重是什么意思,神经网络权重调整方法
  13. 示波器软件NS-Scope,可任意添加测量数据介绍
  14. R语言相关性分析及步骤
  15. 6、Spring Boot:自定义Servlet Filters
  16. [盘点]现今热门的h5网游
  17. Invalid data found when processing input
  18. 怎样让android系统消失,谷歌本以为断供安卓可以让华为手机消失,结果断送了安卓系统的前程...
  19. selenium中添加cookies的方法 python
  20. CC1101/CC1100、stc单片机模拟2262-2272解码

热门文章

  1. Python如何绘制六角星
  2. 奴才是没有创造力的,而996会磨灭激情
  3. 北京公司车牌指标转让注意事项
  4. Programming Differential Privacy第五章
  5. c语言录取分数线问题,2018中考录取分数线公布!!
  6. java运行linux命令时报错
  7. SpringBootWeb应用源码解析:遗失的web.xmI
  8. HG532固件路由器仿真——QEMU
  9. 球弹跳高度的计算(C语言)
  10. 上班坐坐族应该学的瑜珈