使用js画图之圆、弧、扇形

 更新时间:2015年01月12日 15:18:14   投稿:hebedich  
这篇文章主要介绍了使用js绘制几何图形教程,本文主要是教大家绘制圆、弧、扇形,需要的朋友可以参考下

半径为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 < 360; i+=5){
        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
    });
}

二、弧

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

复制代码 代码如下:

//画弧
//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 < angle; i+=2){ //在angle范围内画弧
        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 < angle; i+=2){ //在angle范围内画弧
        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("<span style='height: 24px; line-height: 24px; width: 80px; text-align: center; color: RED; position: absolute; left:"+(newDot[0]+r*(2/4)*Math.cos(a)-40)+"px; top: "+(newDot[1]+r*(2/4)*Math.sin(a)-12)+"'>"+title+"</span>");
    }
}

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

您可能感兴趣的文章:

相关文章

  • 下载站常用的点击下载地址提示设hao123为首页的js代码

    下载站常用的点击下载地址提示设hao123为首页的js代码

    最近很多下载站下载文件的时候都提示设置hao123为首页,这里我们来分享下具体的实现方法,需要的朋友可以参考下
    2013-10-10
  • 在微信小程序中保存网络图片

    在微信小程序中保存网络图片

    这篇文章主要介绍了在微信小程序中保存网络图片,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-02-02
  • countup.js实现数字动态叠加效果

    countup.js实现数字动态叠加效果

    这篇文章主要为大家详细介绍了countup.js实现数字动态叠加效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10
  • Javascript刷新窗口方法小结

    Javascript刷新窗口方法小结

    这篇文章主要介绍了Javascript刷新窗口方法,以实例形式分析了JavaScript刷新窗口的四种常用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-10-10
  • JavaScript.Encode手动解码技巧

    JavaScript.Encode手动解码技巧

    往往在网页上有JS加密代码的解码方法,但是由于代码中存在转义字符,无法正确的进行解码。
    2010-07-07
  • javascript 读取xml,写入xml 实现代码

    javascript 读取xml,写入xml 实现代码

    javascript xml读取,写入xml 实现代码
    2009-07-07
  • js常见遍历操作小结

    js常见遍历操作小结

    这篇文章主要介绍了js常见遍历操作,结合实例形式分析了javascript for循环、for in、for each、each及map遍历简单操作技巧,需要的朋友可以参考下
    2019-06-06
  • uniapp小程序开发组件封装之自定义轮播图效果

    uniapp小程序开发组件封装之自定义轮播图效果

    这篇文章主要介绍了uniapp小程序开发组件封装之自定义轮播图,本文主要展示小程序端封装轮播图组件,使用的是uniapp进行的开发,主要使用的是uniapp官网提供的swiper组件,需要的朋友可以参考下
    2023-02-02
  • 详解JS中如何终止foreach循环

    详解JS中如何终止foreach循环

    forEach专门用来循环数组,可以直接取到元素,同时也可以取到index值,终止forEach存在局限性,不能continue跳过或者break终止循环,所以本文给大家详细介绍了在JS中如何终止foreach循环,需要的朋友可以参考下
    2024-01-01
  • JavaScript 匿名函数(anonymous function)与闭包(closure)

    JavaScript 匿名函数(anonymous function)与闭包(closure)

    JavaScript 匿名函数(anonymous function)与闭包(closure) ,学习js的朋友可以参考下。
    2011-10-10

最新评论