亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > HTML5 > 正文

html5 canvas繪制網絡字體的常用方法

2024-09-05 07:23:00
字體:
來源:轉載
供稿:網友

最近在用canvas繪圖時遇到了一個令人頭痛的問題:canvas繪制網絡字體時沒效果,遂開始了一番解決方案查找測試,中間也碰到了不少坑,于是寫下此篇文章做個總結,如果大家在用canvas時遇到了同樣的問題,希望對大家有一定的幫助,接下來就來看看有哪幾種解決辦法

服務端轉換
 

服務端轉換是什么意思呢?直接把內容和需要的字體傳遞給服務端,服務端提供一個文字轉圖片的接口,將字體轉換成圖片,然后在canvas中直接繪制圖片,這樣就能保證繪制網絡字體不會有問題,不會有任何的兼容性問題,但是這樣做也就意味著服務端的工作會變多,同時如果文字內容是可以被用戶編輯修改的,那就意味著用戶每操作一次,都要請求一次接口,然后重新繪制一次圖片,這樣會導致網絡開銷增加,如果不想要服務端的介入,那就看看下面的解決方案

webfontloader
 

webfontloader是一個由Google和Typekit共同開發的組件庫,提供了一組標準事件監聽字體的加載,雖然已經很長時間沒有更新了,但是對字體加載的監聽確實有效,下面來看一個具體的例子怎么使用:

var WebFont = require('webfontloader')var canvas = document.getElementById('canvas')var ctx = canvas.getContext('2d')var link = document.createElement('link')link.rel = 'stylesheet'link.type = 'text/css'link.)[0].appendChild(link)WebFont.load({  custom: {    families: ['Vast Shadow']  },  active: function () {    ctx.font = '50px "Vast Shadow"'    ctx.textBaseline = 'top'    ctx.fillText('123', 20, 10)  }})

首先通過require引入webfontloader,并且動態插入一個script標簽載入google的字體,然后調用webfontloader的load方法進行配置監聽,當字體加載完成后就會觸發active鉤子,開始繪制對應字體的內容,webfontloader提供了一個完整的事件系統鉤子給開發者調用:

 

如果想要了解webfontloader的更多用法可以前往 github 查看學習,如果你覺得為了繪制網絡字體需要引入一個js庫有點得不償失,沒關系,接下來向你接受不用庫的方法

document.fonts.load
 

如果你在Google上搜索canvas加載網絡字體,你一定能搜到下面這個方案:

var canvas = document.getElementById('canvas')var ctx = canvas.getContext('2d')var link = document.createElement('link')link.rel = 'stylesheet'link.type = 'text/css'link.)[0].appendChild(link)var image = document.createElement('img')image.src = link.hrefimage.onerror = () => {  ctx.font = '50px "Vast Shadow"'  ctx.textBaseline = 'top'  ctx.fillText('123', 20, 10)}

這個方案存在一點問題,當image onerror事件觸發的時候,并不能保證字體已經加載完成,只能保證css文件已經加載完成,因此,在第一次訪問的時候并不會生效:

 

但是你再刷新一下瀏覽器之后字體就生效了:

 

這是什么原因呢?我們來看一下刷新瀏覽器的網絡請求:

 
 

可以看到后面的字體走的是緩存,因此可以字體可以繪制出來,但是如果將chrome調試的Disable cache勾選上,將緩存禁用掉,那么無論怎么刷新,字體都不會繪制出來。

 

有解決辦法嗎?答案是有的,使用Font Load API進行加載,來看具體代碼:

var canvas = document.getElementById('canvas')var ctx = canvas.getContext('2d')var link = document.createElement('link')link.rel = 'stylesheet'link.type = 'text/css'link.)[0].appendChild(link)var image = document.createElement('img')image.src = link.hrefimage.onerror = () => {  document.fonts.load('50px Vast Shadow', '123').then(() => {    ctx.font = '50px "Vast Shadow"'    ctx.textBaseline = 'top'    ctx.fillText('123', 20, 10)  })}

 

先用image的onerror事件trick css文件的加載,然后調用document.fonts.load看字體是否加載完成,這樣就可以準確監聽到字體加載完成,但是這個api存在兼容性問題,來看具體表格:

 

想要對這個api了解更多,可以前往 mdn 查看

對比繪制

對比繪制是什么意思呢?就是先設置一個沒有的字體,然后在設置我們需要的字體進行對比,來看具體代碼:

var canvas = document.getElementById('canvas')var ctx = canvas.getContext('2d')var link = document.createElement('link')link.rel = 'stylesheet'link.type = 'text/css'link.)[0].appendChild(link)ctx.font = '50px UNKNOW'ctx.textBaseline = 'top'ctx.fillText('123', 20, 10)var dataDefault = ctx.getImageData(20, 10, 50, 50).datactx.clearRect(20, 10, 100, 100)var detect = () => {  ctx.font = '50px "Vast Shadow"'  ctx.textBaseline = 'top'  ctx.fillText('123', 20, 10)  var dataNow = ctx.getImageData(20, 10, 50, 50).data  if ([].slice.call(dataNow).join('') === [].slice.call(dataDefault).join('')) {    ctx.clearRect(20, 10, 100, 100)    requestAnimationFrame(detect)  }}detect()

首先設置一個沒有的字體,繪制上去,然后拿到對應區域的渲染數據,然后再將渲染區域清除然后,然后再設置我們需要的字體,拿到對應區域的渲染數據,然后實時對比,當渲染數據一樣時,表示繪制的都是系統默認字體,我們需要的字體沒有渲染出來,然后執行requestAnimationFrame再執行detect檢測方法,直到渲染數據不一樣,就表示我們需要的字體已經渲染完成

總結

以上所述是小編給大家介紹的html5 canvas繪制網絡字體的常用方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文字幕在线精品| y97精品国产97久久久久久| 91精品国产精品| 欧美激情xxxx| 亚洲天堂av电影| 日韩毛片在线看| 亚洲伊人久久大香线蕉av| 国产偷亚洲偷欧美偷精品| 亚洲国产欧美一区二区三区同亚洲| 影音先锋日韩有码| 国产精品成人av在线| 57pao成人国产永久免费| 日韩中文字幕欧美| 国产精自产拍久久久久久| 亚洲欧美综合图区| 国产精品电影久久久久电影网| 久久久久久久久国产精品| 日韩一区二区三区国产| 亚洲免费人成在线视频观看| 精品福利免费观看| 精品久久久久久久久久| 中文字幕日韩欧美精品在线观看| 日韩不卡在线观看| 国产精品成人免费电影| 国产精品综合久久久| 亚洲精品永久免费| 日韩精品一区二区三区第95| 欧美在线一级视频| 日韩精品中文字幕有码专区| 97精品视频在线观看| 成人亲热视频网站| 欧美做受高潮电影o| 国产精品扒开腿做爽爽爽的视频| 久久久久国产精品免费网站| 久久精品99无色码中文字幕| 中文字幕av一区| 亚洲性夜色噜噜噜7777| 国产一区视频在线| 九九热这里只有在线精品视| 亚洲国产精品人人爽夜夜爽| 国产精品永久免费视频| 欧美午夜精品在线| 热99精品里视频精品| 久久91亚洲精品中文字幕| 欧美日韩国产成人高清视频| 俺也去精品视频在线观看| 亚洲在线观看视频| 美女久久久久久久久久久| 国自在线精品视频| 97视频国产在线| 日本一区二三区好的精华液| 亚洲mm色国产网站| 欧美黑人国产人伦爽爽爽| 国产精品中文字幕在线| 欧美裸体视频网站| 九九精品在线视频| 91精品国产综合久久香蕉的用户体验| 91在线看www| 久久综合久久八八| 亚洲欧美在线播放| 亚洲欧美日韩久久久久久| 综合国产在线观看| 日韩免费av一区二区| 欧美激情欧美狂野欧美精品| 国产色视频一区| 欧美午夜精品久久久久久久| 国产成人福利视频| 久久精品视频在线| 久久综合九色九九| 久久理论片午夜琪琪电影网| 亲爱的老师9免费观看全集电视剧| 97久久精品人人澡人人爽缅北| 亚洲精品720p| 国产69精品久久久久99| 欧美小视频在线观看| 亚洲男人av在线| 日韩av免费看网站| 久久久久久噜噜噜久久久精品| 91中文字幕在线| 97香蕉超级碰碰久久免费软件| 久久久人成影片一区二区三区观看| 亚洲欧美日韩一区二区在线| 性金发美女69hd大尺寸| 日韩av一区二区在线观看| 大伊人狠狠躁夜夜躁av一区| 美女撒尿一区二区三区| 精品久久久久久国产91| 欧美激情伊人电影| 国模精品视频一区二区| 日韩亚洲第一页| 57pao精品| 国产精品观看在线亚洲人成网| 国产精品三级网站| 91精品在线一区| 亚洲日韩欧美视频| 国产亚洲欧洲在线| 久久精品91久久久久久再现| 精品久久久久久| 亚洲自拍小视频免费观看| 国产精品第1页| 欧美福利在线观看| 欧美精品videosex性欧美| 91精品国产综合久久久久久蜜臀| 中文字幕免费国产精品| 欧美大片在线看免费观看| 日本午夜在线亚洲.国产| 日韩精品在线观看视频| 国产一区二区三区久久精品| 粉嫩av一区二区三区免费野| 国产精品一区二区三区久久| 日韩精品一区二区视频| 国产日韩中文在线| 亚洲成人av中文字幕| 精品香蕉在线观看视频一| 国产精品日日摸夜夜添夜夜av| 欧美一区二区三区四区在线| 在线观看不卡av| 国产综合在线视频| 中文字幕九色91在线| 国内免费精品永久在线视频| 永久免费精品影视网站| 久久香蕉国产线看观看网| 亚洲一区av在线播放| 不卡av电影在线观看| 国产精品igao视频| 国产日韩在线免费| 在线视频欧美性高潮| 亚洲美女av在线播放| 久久久成人精品| 久久久久北条麻妃免费看| 激情成人中文字幕| 国产午夜精品视频| 欧美俄罗斯性视频| 97视频在线观看免费高清完整版在线观看| 久久精品一本久久99精品| 91在线无精精品一区二区| 亚洲精品欧美极品| 91免费人成网站在线观看18| 精品中文视频在线| 国产精品爽黄69| 国产精品一区二区三区在线播放| 中文字幕精品在线| 久久久国产成人精品| 在线播放日韩精品| 欧美午夜视频一区二区| 亚洲专区在线视频| 日本中文字幕成人| 亚洲aⅴ日韩av电影在线观看| 国产亚洲a∨片在线观看| 91久久精品国产91久久| 欧美日产国产成人免费图片| 热99精品里视频精品| 亚洲xxx大片| 精品国产乱码久久久久久虫虫漫画| 欧美激情亚洲精品| 成人免费淫片aa视频免费| 97高清免费视频| 欧美精品一二区| 欧美成人免费网| 高清视频欧美一级| 中文字幕亚洲欧美在线| 久久综合网hezyo| 日本三级韩国三级久久| 欧美大尺度在线观看|