在《js绘制两个相交的矩形并且其中有一个包含透明度》中我们给大家介绍了怎么用javascript绘制两个相交的矩形并且其中一个具有alpha透明度,今天继续给大家介绍一个好玩的实现方法~
正如标题所述,“戴眼镜的笑脸”!javascript可谓是无所不能啊~
首先我给大家一个图片示例:
大家可以根据这个图来编写代码,看看怎么样才能实现这样的图?方法肯定不止一种,大家可以在本地先试试~
下面我给大家介绍一种方法,是使用moveto()函数来实现。
完整代码如下:
<!doctype html><html lang="en"><head> <meta charset="utf-8"> <title></title></head><body onload="draw();"><canvas id="canvas" width="250" height="250"></canvas><script> function draw() { var canvas = document.getelementbyid('canvas'); if (canvas.getcontext) { var context = canvas.getcontext('2d'); context.beginpath(); // 外圆 context.arc(75,75,50,0,math.pi*2,true); context.moveto(110,75); // 嘴巴 context.arc(75,75,35,0,math.pi,false); // 左眼和右眼 context.moveto(55,65); context.arc(60,65,5,0,math.pi*2,true); context.arc(90,65,5,0,math.pi*2,true); context.stroke(); } } </script></body></html>
搞定!运行该代码会出现跟上图一样的效果。
那么在这段代码中,要介绍2个重要的方法moveto()和arc()方法。
moveto() 方法用于把路径移动到画布中的指定点,不创建线条,其js语法是“context.moveto(x,y);”,参数x表示路径的目标位置的 x 坐标,y表示路径的目标位置的 y 坐标。
arc()方法用于创建弧/曲线(用于创建圆或部分圆),其js语法是“context.arc(x,y,r,sangle,eangle,counterclockwise);”,注意如需通过 arc() 来创建圆,请把起始角设置为 0,结束角设置为 2*math.pi。
其中参数x圆的中心的 x 坐标;
y表示圆的中心的 y 坐标;
r表示圆的半径;
sangle表示起始角,以弧度计。(弧的圆形的三点钟位置是 0 度);
eangle表示结束角,以弧度计。
counterclockwise可选,规定应该逆时针还是顺时针绘图。false = 顺时针,true = 逆时针。
最后给大家推荐本平台经典的课程《javascript极速入门_玉女心经系列》,公益免费的~欢迎大家学习~
以上就是js的趣味实现:给你一个戴眼镜的笑脸的详细内容。