canvas通过三角函数中获得圆上某点的坐标

canvas通过三角函数中获得圆上某点的坐标

月光魔力鸭

2018-09-25 17:15 阅读 3313 喜欢 2 获得圆上的坐标 canvas 三角函数

在我们通过canvs画图的时候经常会用到圆,且需要计算出圆上某点的坐标,由于我数学没学好,总是记不得怎么获取,这里记录下,加深记忆。

这里面用到了我们以前学过的三角函数,可以通过三角函数来计算圆上的位置。

如下:在直角坐标系中圆点O(0,0) ,半径为OP,求圆上点P的坐标x,y.

直角坐标系

我们可以通过sinθ = y/r . cosθ = x/r 两个公式来分别获得坐标x和y.

那么 x = cosθ * r ,然后对于角度的计算则是 θ = Math.PI * 2 / 360 * 度数(0-360) ,那么可以得到

下面,我们根据这个公式来画一个圆,以圆上的点为圆心画多个小圆。 如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>canvas练习</title>
    <style type="text/css">
        html,body{width:100%;height:100%;margin:0px;padding:0px;overflow:hidden;}
        canvas{background-color:#49e;}
    </style>
</head>
<body></body>
</html>
<script type="text/javascript">
    var canvas = {
        init () {
            this.ele = document.createElement('canvas');
            document.body.appendChild(this.ele);
            this.ctx = this.ele.getContext('2d');
            this.width = this.ele.width = window.innerWidth;
            this.height = this.ele.height = window.innerHeight;
            return this;
        },
        //画圆与小圆
        draw (){
            let r = 150,//半径50
                lr = 5;//小圆半径
            this.ctx.strokeStyle = 'white';
            this.ctx.arc(this.width/2,this.height/2,r,0,Math.PI * 2);
            this.ctx.stroke();
            //画小圆,i 为度数,共有360°
            for(let i=0;i<=360;i+= 30){
                //获得圆上坐标
                this.ctx.beginPath();
                let x= Math.cos(Math.PI * 2 / 360 * i) * r,
                    y = Math.sin(Math.PI * 2 / 360 * i) * r;
                this.ctx.arc(this.width/2+x,this.height/2 + y,lr,0,Math.PI * 2);
                this.ctx.stroke();
                this.ctx.closePath();
            }
        }
    };
    canvas.init().draw();
</script>

噔噔噔噔,效果出来啦..虽然很简单,但是初学的时候总是有莫名的成就感.. 哈哈

效果图

三角函数还有很多用途,可以用在动画效果上,后面学习中...。


以上知识比较基础,大神请轻拍!

转载请注明出处: https://chrunlee.cn/article/canvas-get-circle-position.html


感谢支持!

赞赏支持
提交评论
评论信息 (请文明评论)
暂无评论,快来快来写想法...
推荐
jsQR 是一款纯粹的由javascript实现的二维码识别库,可以在浏览器端使用,也可以在后端node.js环境使用。我之前使用过其他的识别库,例如:qrcode-reader 或其他,在使用上都比较麻烦,而且识别率并不高。jsQR是后来发现的,感觉(没有实际对比验证)jsQR识别率要更高些,使用起来也更简单,不需要安装其他依赖软件。
java 对象中有很多引用,甚至会出现循环引用,比如 user 对象中有 school 对象,school 对象中又有 user 对象,这样在对 user 对象序列化的时候,就会出现死循环,导致内存溢出。通过一定的方式,将每个对象增加ID 和 REF 引用标识最终可以解决这个问题
在今天之前,我对canvas中rotate其实是一脸蒙逼的... 虽然之前有做过图片旋转,但那是在他人的基础上直接修改的,至于为啥会这样..讲真,还真没注意过,但是今天又需要用到这块了,实在搞不定了,找了各种资料,终于明白了.. 坐标系的问题。
在通过chrome浏览器来调用摄像头的时候发现getUserMedia报错,但是本地开发却没有问题,主要原因是https环境的问题。chrome 不允许在非https和非localhost下的非安全环境进行调用。
之前一直没面试过前端,今天有一个,先整理下需要问的问题和答案。这里都是一些简单的问题,关于当下比较流行的框架并没有涉及到..
近期需求:将一棵树导出到excel中,树是ztree,通过插件Table2excel导出table到excel中。
通过jspdf ,我们可以将页面或图片生成pdf下载下来,如果是一些复杂的页面,我们可以将页面转成图片,然后把图片加入到pdf中,生成并下载。
做作业的时候,需要在手机上预览下,但是发现如果想在移动端上展示A4样子的作业还是挺麻烦的,最后还是准备通过图片来展示,然后移动端缩放呗。。