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>");
    }
}
时间: 2024-11-13 08:07:47

JS画几何图形之二【圆】的相关文章

JS画几何图形之五【过圆外一点作切线】

样例:http://www.zhaojz.com.cn/demo/draw9.html //画切线 //point 圆外的一点 //dot 圆心 //r 半径 function drawCircleTangent(point, dot, r){ //画辅助线-start var color = 'DarkRed'; //切线的颜色 var color2 = "#ccc"; //其它辅助线的颜色 drawLine(dot, [dot[0]+9*r,dot[1]], {color: col

JS画几何图形之一【直线】

JS画图的想法经过大脑的时候,觉得有点意思,所以就实践了一番.JS画图为系列文章,本是讲点.线和面 先看样例:http://www.zhaojz.com.cn/demo/draw5.html 一.点 这里的点我们使用span标签表示 //描点,参数有点的大小,颜色,点的坐标和标签; 很明显opts参数是一个对象 function drawPoint(opts){ document.write("<span id='"+opts.point[0]+""+opts

JS画几何图形之四【饼图】

饼图是将一个圆分割为多个扇形. 样例:http://www.zhaojz.com.cn/demo/draw8.html //饼图 //dot 圆点 //r 半径 //data 数据(一维数组) function drawPie(dot, r, data){ if(data && data.length > 0){ var accumulationAngleOfSlope = new Number(0); //累计偏移角度 var total = new Number(0); var

JS画几何图形之三【正弦曲线】

数学式:y=Asin(ωx+φ)+k 样例:http://www.zhaojz.com.cn/demo/draw7.html JS函数的声明: //画正弦曲线 //dot 原点 //amplitude 振幅 -- A //initialPhase 初相 -- φ //setover 偏距 -- k //palstance 角速度 -- ω //len 周期数 function drawSinusoid(dot, amplitude,initialPhase,palstance,setover,

JS画几何图形之六【过直线外一点作垂线】

样例:http://www.zhaojz.com.cn/demo/draw10.html //过直线外一点画垂线 function drawVerticalLine(point, line){ //画辅助线-start var color = 'DarkRed'; //垂线的颜色 var color2 = "#ccc"; //其它辅助线的颜色 drawPoint({ pw:2,ph:2,color:'DarkRed',point: line[0] }); drawPoint({ pw:

纯CSS画几何图形

<!doctype html> <html> <head> <meta charset="utf-8"> <title>纯CSS画几何图形</title> </head> <body> <!--多彩空心矩形--> <div style="width:100px; height:100px; border-width:20px; border-style:solid

js算法集合(二) javascript实现斐波那契数列 (兔子数列) Javascript实现杨辉三角

js算法集合(二)  斐波那契数列.杨辉三角 ★ 上一次我跟大家分享一下做水仙花数的算法的思路,并对其扩展到自幂数的算法,这次,我们来对斐波那契数列和杨辉三角进行研究,来加深对Javascript的理解. 一.Javascript实现斐波那契数列 ①要用Javascript实现斐波那契数列,我们首先要了解什么是斐波那契数列:斐波那契数列(Fibonacci sequence),又称黄金分割数列.因数学家列昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为

QRCode.js -- 用 Javascript 生产二维码

QRCode.js是一个生成二维码的JS库.QRCode.js支持在DOM中使用跨浏览器Canvas和table标签的. QRCode.js不依赖其他JS库. 基本用法: <div id="qrcode"></div> <script type="text/javascript"> new QRCode(document.getElementById("qrcode"), "http://jindo.

无聊js画了个菱形

function repeat(str, count) { return count < 0 ? '' : (new Array(count)).join(str); } function diamond(sign, size) { var d, s = '' for (var i = 0; i < size*2; i++) { d = Math.abs(size-i-1); console.log(d+1, 2*(size-d)); s += repeat(' ', d+1) + repea