首页 > web前端 > js教程 > 正文

使用js画图之圆、弧、扇形_javascript技巧

php中文网
发布: 2016-05-16 16:20:52
原创
2595人浏览过

半径为r的圆上的点p(x,y)与圆心o(x0,y0)的关系: x = x0+rcosa;  y = y0+rsina ,a为弧度

样例:http://www.zhaojz.com.cn/demo/draw6.html

一、圆

复制代码 代码如下:

//圆形/椭圆
//dot 圆点
//r 半径
//compressionRatio 垂直压缩比
function drawCircle(dot, r, compressionRatio, data){
    var pstart = [dot[0]+r, dot[1]]; //起点
    var pre = pstart;
    for(var i=0; i         rad = i*Math.PI/180; //计算弧度
        //r*Math.cos(rad) 弧线的终点相对dot的水平偏移
        //r*Math.sin(rad) 弧线的终点相对dot的垂直偏移
        //compressionRatio 垂直压缩比例
        var cur = [r*Math.cos(rad)+dot[0], compressionRatio*r*Math.sin(rad)+dot[1]];
        drawLine(pre,cur);
        pre = cur; //保存当前点的坐标
    }
    drawLine(pre,pstart);//使闭合
    //描圆点
    drawPoint({
        pw:2,ph:2,color:'DarkRed',point:dot
    });
}

二、弧

  就在画出圆的一部分,算法与圆相似

立即学习Java免费学习笔记(深入)”;

AutoGLM沉思
AutoGLM沉思

智谱AI推出的具备深度研究和自主执行能力的AI智能体

AutoGLM沉思 239
查看详情 AutoGLM沉思

复制代码 代码如下:

//画弧
//dot 圆点
//r 半径
//angle 圆心角
//angleOfSlope 与x轴的夹角
//pop 是否弹出
//title 标签
function drawArc(dot, r, angle, angleOfSlope, pop, title){
    var newDot = [dot[0], dot[1]];
    var a = (angleOfSlope+angle/2)*Math.PI/180;
    if(pop){ //计算圆心的新坐标
        newDot[0] = dot[0]+10*Math.cos(a);
        newDot[1] = dot[1]+10*Math.sin(a);
    }
    if(!angleOfSlope){
        angleOfSlope = 0;
    }
    var aos = angleOfSlope*Math.PI/180;
    var aos2 = (angleOfSlope+angle)*Math.PI/180;
    var pstart = [newDot[0]+r*Math.cos(aos), newDot[1]+r*Math.sin(aos)]; //弧线的起点
    var pend = [newDot[0]+r*Math.cos(aos2), newDot[1]+r*Math.sin(aos2)]; //弧线的终点
    var pre = pstart;
    for(var i=0; i         rad = (i+angleOfSlope)*Math.PI/180;
        var cur = [r*Math.cos(rad)+newDot[0], r*Math.sin(rad)+newDot[1]];
        drawLine(pre,cur);
        pre = cur;
    }
}

三、扇形

  将弧的两端与圆心相连

复制代码 代码如下:

//扇形
//dot 圆点
//r 半径
//angle 圆心角
//angleOfSlope 与x轴的夹角,确定扇形的方向
//pop 是否弹出,即是否偏离圆心
//title 标签
function drawSector(dot, r, angle, angleOfSlope, pop, title){
    var newDot = [dot[0], dot[1]];
    var a = (angleOfSlope+angle/2)*Math.PI/180;
    if(pop){ //计算圆心的新坐标
        newDot[0] = dot[0]+10*Math.cos(a);
        newDot[1] = dot[1]+10*Math.sin(a);
    }
    if(!angleOfSlope){
        angleOfSlope = 0;
    }
    var aos = angleOfSlope*Math.PI/180;
    var aos2 = (angleOfSlope+angle)*Math.PI/180;
    var pstart = [newDot[0]+r*Math.cos(aos), newDot[1]+r*Math.sin(aos)]; //弧线的起点
    var pend = [newDot[0]+r*Math.cos(aos2), newDot[1]+r*Math.sin(aos2)]; //弧线的终点
    drawLine(newDot,pstart); //连接圆心与起点
    var pre = pstart;
    for(var i=0; i         rad = (i+angleOfSlope)*Math.PI/180;
        var cur = [r*Math.cos(rad)+newDot[0], r*Math.sin(rad)+newDot[1]];
        drawLine(pre,cur);
        pre = cur;
    }
    drawPolyline([pre, pend, newDot]); //使闭合
    //描圆心
    drawPoint({
        pw:2,ph:2,color:'DarkRed',point:dot
    });
    //标签
    if(title){
        document.write(""+title+"");
    }
}

是不是很震撼,原来js也能做如此炫酷的事情。。。

相关标签:
js
java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号