亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用js畫圖之圓、弧、扇形

 更新時(shí)間:2015年01月12日 15:18:14   投稿:hebedich  
這篇文章主要介紹了使用js繪制幾何圖形教程,本文主要是教大家繪制圓、弧、扇形,需要的朋友可以參考下

半徑為r的圓上的點(diǎn)p(x,y)與圓心O(x0,y0)的關(guān)系: x = x0+rcosA;  y = y0+rsinA ,A為弧度

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

一、圓

復(fù)制代碼 代碼如下:

//圓形/橢圓
//dot 圓點(diǎn)
//r 半徑
//compressionRatio 垂直壓縮比
function drawCircle(dot, r, compressionRatio, data){
    var pstart = [dot[0]+r, dot[1]]; //起點(diǎn)
    var pre = pstart;
    for(var i=0; i < 360; i+=5){
        rad = i*Math.PI/180; //計(jì)算弧度
        //r*Math.cos(rad) 弧線的終點(diǎn)相對dot的水平偏移
        //r*Math.sin(rad) 弧線的終點(diǎn)相對dot的垂直偏移
        //compressionRatio 垂直壓縮比例
        var cur = [r*Math.cos(rad)+dot[0], compressionRatio*r*Math.sin(rad)+dot[1]];
        drawLine(pre,cur);
        pre = cur; //保存當(dāng)前點(diǎn)的坐標(biāo)
    }
    drawLine(pre,pstart);//使閉合
    //描圓點(diǎn)
    drawPoint({
        pw:2,ph:2,color:'DarkRed',point:dot
    });
}

二、弧

  就在畫出圓的一部分,算法與圓相似

復(fù)制代碼 代碼如下:

//畫弧
//dot 圓點(diǎn)
//r 半徑
//angle 圓心角
//angleOfSlope 與x軸的夾角
//pop 是否彈出
//title 標(biāo)簽
function drawArc(dot, r, angle, angleOfSlope, pop, title){
    var newDot = [dot[0], dot[1]];
    var a = (angleOfSlope+angle/2)*Math.PI/180;
    if(pop){ //計(jì)算圓心的新坐標(biāo)
        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)]; //弧線的起點(diǎn)
    var pend = [newDot[0]+r*Math.cos(aos2), newDot[1]+r*Math.sin(aos2)]; //弧線的終點(diǎn)
    var pre = pstart;
    for(var i=0; i < angle; i+=2){ //在angle范圍內(nè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;
    }
}

三、扇形

  將弧的兩端與圓心相連

復(fù)制代碼 代碼如下:

//扇形
//dot 圓點(diǎn)
//r 半徑
//angle 圓心角
//angleOfSlope 與x軸的夾角,確定扇形的方向
//pop 是否彈出,即是否偏離圓心
//title 標(biāo)簽
function drawSector(dot, r, angle, angleOfSlope, pop, title){
    var newDot = [dot[0], dot[1]];
    var a = (angleOfSlope+angle/2)*Math.PI/180;
    if(pop){ //計(jì)算圓心的新坐標(biāo)
        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)]; //弧線的起點(diǎn)
    var pend = [newDot[0]+r*Math.cos(aos2), newDot[1]+r*Math.sin(aos2)]; //弧線的終點(diǎn)
    drawLine(newDot,pstart); //連接圓心與起點(diǎn)
    var pre = pstart;
    for(var i=0; i < angle; i+=2){ //在angle范圍內(nè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
    });
    //標(biāo)簽
    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也能做如此炫酷的事情。。。

相關(guān)文章

  • JavaScript數(shù)組reduce常見實(shí)例方法

    JavaScript數(shù)組reduce常見實(shí)例方法

    reduce方法在數(shù)組的每個(gè)元素上執(zhí)行用戶提供的回調(diào)函數(shù),即"reducer",它傳入對前一個(gè)元素進(jìn)行計(jì)算的返回值,結(jié)果是單個(gè)值,它是在數(shù)組的所有元素上運(yùn)行reducer的結(jié)果,下面這篇文章主要給大家介紹了關(guān)于JavaScript數(shù)組reduce常見實(shí)例方法的相關(guān)資料,需要的朋友可以參考下
    2022-05-05
  • 原生JS實(shí)現(xiàn)滑動按鈕效果

    原生JS實(shí)現(xiàn)滑動按鈕效果

    這篇文章主要為大家詳細(xì)介紹了原生JS實(shí)現(xiàn)滑動按鈕效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • echarts地圖區(qū)域顯示不同顏色代碼示例

    echarts地圖區(qū)域顯示不同顏色代碼示例

    地圖在我們?nèi)粘5臄?shù)據(jù)可視化分析中是很常見的一種展示手段,不僅美觀而且很大氣,這篇文章主要給大家介紹了關(guān)于echarts地圖區(qū)域顯示不同顏色的相關(guān)資料,需要的朋友可以參考下
    2023-10-10
  • AJAX異步從優(yōu)酷專輯中采集所有視頻及信息(JavaScript代碼)

    AJAX異步從優(yōu)酷專輯中采集所有視頻及信息(JavaScript代碼)

    上次寫了一個(gè) .NET從優(yōu)酷專輯中采集所有視頻及信息(VB.NET代碼)
    2010-11-11
  • php gethostbyname獲取域名ip地址函數(shù)詳解

    php gethostbyname獲取域名ip地址函數(shù)詳解

    php gethostbyname獲取域名ip地址函數(shù),需要根據(jù)域名得到ip地址的朋友有福了。
    2010-01-01
  • document.selection.createRange方法與實(shí)例

    document.selection.createRange方法與實(shí)例

    document.selection.createRange() 根據(jù)當(dāng)前文字選擇返回 TextRange 對象,或根據(jù)控件選擇返回 ControlRange 對象
    2006-10-10
  • 微信小程序使用template標(biāo)簽實(shí)現(xiàn)五星評分功能

    微信小程序使用template標(biāo)簽實(shí)現(xiàn)五星評分功能

    這篇文章主要為大家詳細(xì)介紹了微信小程序使用template標(biāo)簽實(shí)現(xiàn)五星評分功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • 淺談setTimeout 與 setInterval

    淺談setTimeout 與 setInterval

    實(shí)際上,setTimeout和setInterval的語法相同。它們都有兩個(gè)參數(shù),一個(gè)是將要執(zhí)行的代碼字符串,還有一個(gè)是以毫秒為單位的時(shí)間間隔,當(dāng)過了那個(gè)時(shí)間段之后就將執(zhí)行那段代碼。不過這兩個(gè)函數(shù)還是有區(qū)別的
    2015-06-06
  • 微信小程序?qū)崿F(xiàn)文件、圖片上傳功能

    微信小程序?qū)崿F(xiàn)文件、圖片上傳功能

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)文件、圖片上傳功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-05-05
  • 鼠標(biāo)懸浮停留三秒后自動顯示大圖js代碼

    鼠標(biāo)懸浮停留三秒后自動顯示大圖js代碼

    這篇文章主要介紹了鼠標(biāo)懸浮停留三秒后顯示大圖,在網(wǎng)頁中還是比較實(shí)用的,下面是示例代碼
    2014-09-09

最新評論