时间:2021-05-26
效果如下:
实现这样通过圆画实现这样一个8的形状,首先我们要会画圆。我们可以通过角度转成弧度:
radian = angle/180 * Math.PI;再通过弧度获取当前的点的位置,这样最基础的圆的位置在-1到1的位置内
var x = Math.sin(radian);var y = Math.cos(radian);当画完一个完整的圆以后,另一个圆的x轴绘制和当前的x轴的位置是相同的,但是y轴需要改变,所以,我们就判断一下,是否画完一整个圆(画完一整个8需要720度),如果大于360度,就代表当前正在绘制的是第二个圆,所以,在绘制第二个圆的时候,我们调整一下y的位置,这样就实现的两个圆的绘制:
if(angle%720 > 360){ y = -y+2;}案例代码
<!doctype html><html><head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>实现一个点在二维平面上面画8</title> <style> #canvas{ display: block; margin:0 auto; } </style></head><body><canvas id="canvas" width="300" height="600"></canvas></body><script>var canvas = document.querySelector("#canvas");var ctx = canvas.getContext("2d");var angle = 0; //角度var radian = 0; //弧度function draw() { angle += 2; radian = angle/180 * Math.PI; var x = Math.sin(radian); var y = Math.cos(radian); if(angle%720 > 360){ y = -y+2; } var left = x*150+150; var top = y*150+150; ctx.arc(left, top, 1, 0, Math.PI*2); ctx.strokeStyle = "green"; ctx.stroke(); requestAnimationFrame(draw);}requestAnimationFrame(draw);</script></html>以上这篇js 实现在2d平面上画8的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
红外人脸识别和tof3d有什么区别哪个好 3D和2D的区别还是比较大的,2D主要是平面,3D能够有纵深感,从安全性来看,3D要比2D高。 以上就是&ldqu
小米电视可以看3d电影。小米电视支持3D显示技术。与普通2D画面显示相比,3D技术可以使画面变得立体逼真,图像不再局限于屏幕的平面上,仿佛能够走出屏幕外面,让观
AxureRP8设计软件中可以利用2D图转换成3D图形,设置3D图形边框、填充色、阴影等属性,这样更让3D图形有立体感。下面利用一个具体的实例说明2D图形转换成
前言CSS3提供了2D转换功能,能够对元素进行移动、缩放和转动等功能。2D转换的属性名为transform,使用方法为transform:method(valu
pytorch中的2D卷积层和2D反卷积层函数分别如下:classtorch.nn.Conv2d(in_channels,out_channels,kernel