主頁 > 知識庫 > 詳解canvas在圓弧周圍繪制文本的兩種寫法

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

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

教程是直接按弧度進行編寫的

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

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

效果如下圖

第一種是直接用弧度的

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)//每個字母占的弧度
      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)  //第三個參數(shù)表示文字首位是否相接 差了多少弧度

第二種是用角度帶入的 請注意drawCircularText的第二個參數(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)//每個字母占的弧度
      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)  //第三個參數(shù)表示文字首位是否相接 差了多少弧度

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

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解canvas在圓弧周圍繪制文本的兩種寫法》,本文關(guān)鍵詞  詳解,canvas,在,圓弧,周圍,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解canvas在圓弧周圍繪制文本的兩種寫法》相關(guān)的同類信息!
  • 本頁收集關(guān)于詳解canvas在圓弧周圍繪制文本的兩種寫法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章