首页 前端知识 html5基础入门教程之canvas变型,前端系统工程师面试宝典

html5基础入门教程之canvas变型,前端系统工程师面试宝典

2024-06-04 10:06:50 前端知识 前端哥 658 795 我要收藏

var ctx=canvas.getContext(‘2d’);

ctx.fillRect(10,10,100,50);

ctx.translate(70,70);

ctx.fillRect(10,10,100,50);

}

}

上面的例子先是绘制了一个100*50的矩形,它的原点位置是(10,10)。然后用translate()方法将其原点移至(70,70)。接着又绘制了一个100*50的矩形,它距离原点的位置是(10,10),所以,第二个矩形开始绘制的位置就应该是(80,80);

旋转

rotate()方法用以实现以原点为中心的旋转。

rotate(angle);

该方法只接受一个参数,表示要旋转的角度,以弧度为单位。如果传入的参数是正数,则表示顺时针旋转;如果是负数,则表示逆时针旋转。

默认情况下,旋转的中心始终是原点(0,0),如果想改变旋转的中心,则必须使用translate()将原点移动到指定的位置,再进行旋转。

来看一个rotate()方法的例子:

function draw(){

var canvas=document.getElementById(‘test_rotate’);

if(canvas.getContext){

var ctx=canvas.getContext(‘2d’);

ctx.fillRect(150,50,50,50);

ctx.rotate(Math.PI/6);

ctx.fillRect(150,50,50,50);

}

}

这个例子,在画布没旋转之前,先绘制了一个距离原点位置为(150,50)、大小为50*50的正方形。然后旋转画布30°即Matb.PI/6,再绘制一个一样的正方形。从上图中可以看到两者的区别。注意,这里的原点是(0,0)。

缩放

scale()方法用于实现画布的缩放。

scale(x,y);

该方法接受两个参数,分别表示x方向和y方向缩放的比例。它们必须都是正值。值小于1,表示缩小;值大于1,表示放大;值等于1时,表示没有缩放。

来看一个scale()方法的例子:

function draw(){

var canvas=document.getElementById(‘test_scale’);

if(canvas.getContext){

var ctx=canvas.getContext(‘2d’);

ctx.fillRect(10,10,50,50);

ctx.scale(0.5,1.5);

ctx.fillRect(150,10,50,50);

}

}

上面的例子显示绘制了一个距离原点(10,10)、大小50*50的正方形。然后进行缩放操作,将x方向缩小,y方向放大。然后再在离原点(75,15)(这里坐标已经做了缩放,150*0.5=75,10*1.5=15)的位置绘制一个25*75(50*0.5=25,50*1.5=75)的矩形。二者进行对比,就可以看出scale()是怎样变化的了。

变形

最后一个方法是变形。

transform(m11,m12,m21,m22,dx,dy);

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

调用transform()方法必须将当前的变换矩阵乘以传入的变换矩阵,对上面介绍的参数而言,传入的变形矩阵是这样的:

其中,m11表示水平缩放绘制;m12表示水平倾斜绘制;m21表示垂直倾斜绘制;m22表示垂直缩放绘制;dx表示水平移动绘制;dy表示垂直移动绘制。

换句话说,transform允许缩放、移动、旋转、倾斜当前环境。其实transform就是这几种的组合变换。当然,我们可以把这transform拆分上述三种变换,对应的矩阵计算公式如下:

还有一点需要注意,改变换只会影响调用transform()方法之后所绘制的图形。

来看一个例子:

transform

function draw(){

var canvas=document.getElementById(‘test_transform’);

if(canvas.getContext){

var ctx=canvas.getContext(‘2d’);

ctx.fillStyle=“yellow”;

ctx.fillRect(100,100,250,100);

ctx.transform(1,0.2,-0.2,1,30,10);

ctx.fillStyle=“red”;

ctx.fillRect(100,100,250,100);

ctx.transform(1,0.2,-0.2,1,30,10);

ctx.fillStyle=“blue”;

ctx.fillRect(100,100,250,100);

}

}

针对上面的这个例子,我们来分析一下图形的绘制过程。首先,画布上绘制了一个250*100的黄色矩形。然后为下一个同样大小同样位置的红色矩形做了变形。我们根据transform()各参数可以得出以下矩阵:

然后对应各参数的含义,我们可以得知,红色矩形没有进行缩放,但是进行了旋转和移动。那么我们将这两个过程分成两步来分析,便于理解。我们将上面得到的矩阵中的dx和dy的值置0,即把30和10变成0就得到了下面矩阵:

那么我们怎么计算图形旋转的角度呢?上面的矩阵其实和下面的矩阵是对应的:

根据上面的矩阵对应关系,很容易算出旋转的角度大约为10度。如下图所示:

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

刷面试题

刷题的重要性,不用多说。对于应届生或工作年限不长的人来说,刷面试题一方面能够尽可能地快速自己对某个技术点的理解,另一方面在面试时,有一定几率被问到相同或相似题,另外或多或少也能够为自己面试增加一些自信心,可见适当的刷题是很有必要的。

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

  • 前端字节跳动真题解析

  • 【269页】前端大厂面试题宝典

,可见适当的刷题是很有必要的。

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

  • 前端字节跳动真题解析

  • 【269页】前端大厂面试题宝典

最后平时要进行自我分析与评价,做好职业规划,不断摸索,提高自己的编程能力和抽象思维能力。大厂面试远没有我们想的那么困难,摆好心态,做好准备,你也可以的。

转载请注明出处或者链接地址:https://www.qianduange.cn//article/10753.html
标签
评论
发布的文章

JQuery中的load()、$

2024-05-10 08:05:15

大家推荐的文章
会员中心 联系我 留言建议 回顶部
复制成功!