濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > 詳解canvas在圓弧周圍繪制文本的兩種寫法

詳解canvas在圓弧周圍繪制文本的兩種寫法

熱門標(biāo)簽:中紳電銷智能機(jī)器人 農(nóng)村住宅地圖標(biāo)注 濟(jì)南辦理400電話 漳州人工外呼系統(tǒng)排名 ai電銷機(jī)器人連接網(wǎng)關(guān) 鄭州電銷外呼系統(tǒng)違法嗎 鶴壁手機(jī)自動(dòng)外呼系統(tǒng)怎么安裝 威海營(yíng)銷外呼系統(tǒng)招商 跟電銷機(jī)器人做同事

教程是直接按弧度進(jìn)行編寫的

自己又試著用角度重新編寫了一份,有些差別,總結(jié)起來還是用弧度比較方便,當(dāng)然兩種哪種理解的容易可以自行斟酌

寫代碼有時(shí)候不一定要按照教程一板一眼的寫,最佳實(shí)踐固然是好,但是自己嘗試些別的也許有些別的收獲不是么~

效果如下圖

第一種是直接用弧度的

var canvas=document.getElementById("canvas")
    var context=canvas.getContext("2d")

    var TEXT_FILL_STYLE="rgba(100,130,240,0.5)"
    var TEXT_STROKE_STYLE="rgba(200,0,0,0.7)"
    var TEXT_SIZE=64;
    circle={
        x:canvas.width/2,
        y:canvas.height/2,
        radius:200
    }
    function drawCircularText(string,startAngle,endAngle){
      var radius=circle.radius //圓的半徑
      var angleDecrement=(startAngle-endAngle)/(string.length-1)//每個(gè)字母占的弧度
      var angle=parseFloat(startAngle) //轉(zhuǎn)一下數(shù)字
      var index=0;
      var character;

      context.save()
      context.fillStyle=TEXT_FILL_STYLE;
      context.strokeStyle=TEXT_STROKE_STYLE;
      context.font=TEXT_SIZE+"px Lucida Sans"

      while(index<string.length){
        character=string.charAt(index)
        context.save()
        context.beginPath()
        context.translate(circle.x+Math.cos(angle)*radius,circle.y-Math.sin(angle)*radius)
        context.rotate(Math.PI/2-angle)   //Math.PI/2為旋轉(zhuǎn)90度  Math.PI/180*X為旋轉(zhuǎn)多少度
        context.fillText(character,0,0)
        context.strokeText(character,0,0)
        angle-=angleDecrement
        index++
        context.restore()

      }
      context.restore()
    }
    context.textAlign="center"
    context.textBaseLine="middle"
   drawCircularText("clockwise around the circle",Math.PI*2,Math.PI/8)  //第三個(gè)參數(shù)表示文字首位是否相接 差了多少弧度

第二種是用角度帶入的 請(qǐng)注意drawCircularText的第二個(gè)參數(shù)和第三個(gè)參數(shù)的不同

var canvas=document.getElementById("canvas")
    var context=canvas.getContext("2d")

    var TEXT_FILL_STYLE="rgba(100,130,240,0.5)"
    var TEXT_STROKE_STYLE="rgba(200,0,0,0.7)"
    var TEXT_SIZE=64;
    circle={
        x:canvas.width/2,
        y:canvas.height/2,
        radius:200
    }
    function drawCircularText(string,startAngle,endAngle){
      var radius=circle.radius //圓的半徑
      var angleDecrement=(startAngle-endAngle)/(string.length-1)//每個(gè)字母占的弧度
      var angle=startAngle //
      
      var index=0;
      var character;

      context.save()
      context.fillStyle=TEXT_FILL_STYLE;
      context.strokeStyle=TEXT_STROKE_STYLE;
      context.font=TEXT_SIZE+"px Lucida Sans"

      while(index<string.length){
        character=string.charAt(index)
        context.save()
        context.beginPath()
        context.translate(circle.x+Math.cos((Math.PI/180)*angle)*radius,circle.y-Math.sin((Math.PI/180)*angle)*radius)
        context.rotate((Math.PI/2)-(Math.PI/180)*angle)   //Math.PI/2為旋轉(zhuǎn)90度  Math.PI/180*X為旋轉(zhuǎn)多少度
        context.fillText(character,0,0)
        context.strokeText(character,0,0)
        angle-=angleDecrement
        index++
        context.restore()

      }
      context.restore()
    }
    context.textAlign="center"
    context.textBaseLine="middle"
   drawCircularText("clockwise around the circle",360,10)  //第三個(gè)參數(shù)表示文字首位是否相接 差了多少弧度

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:萍鄉(xiāng) 咸陽(yáng) 文山 蘇州 惠州 甘南 紅河 營(yíng)口

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解canvas在圓弧周圍繪制文本的兩種寫法》,本文關(guān)鍵詞  詳解,canvas,在,圓弧,周圍,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解canvas在圓弧周圍繪制文本的兩種寫法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于詳解canvas在圓弧周圍繪制文本的兩種寫法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    黄山市| 南雄市| 浦江县| 合山市| 广昌县| 福鼎市| 婺源县| 怀宁县| 濮阳市| 溧阳市| 邯郸市| 广平县| 旺苍县| 屯留县| 越西县| 乳源| 白城市| 治县。| 岳普湖县| 页游| 柳林县| 淳化县| 盐池县| 尚义县| 女性| 山阴县| 冀州市| 彰化县| 华坪县| 华池县| 宕昌县| 聂拉木县| 建平县| 旬阳县| 祁门县| 永清县| 黔江区| 新平| 全椒县| 库车县| 观塘区|