婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > html5 canvas繪制網絡字體的常用方法

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

熱門標簽:ok電銷機器人 高德地圖標注商戶怎么標 智能電銷機器人被禁用了么 欣鼎電銷機器人 效果 地圖標注軟件打印出來 電話機器人技術 黃石ai電銷機器人呼叫中心 惡搞電話機器人 如何查看地圖標注

最近在用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.
document.getElementsByTagName('head')[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.
document.getElementsByTagName('head')[0].appendChild(link)
var image = document.createElement('img')
image.src = link.href
image.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.
document.getElementsByTagName('head')[0].appendChild(link)
var image = document.createElement('img')
image.src = link.href
image.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.
document.getElementsByTagName('head')[0].appendChild(link)
ctx.font = '50px UNKNOW'
ctx.textBaseline = 'top'
ctx.fillText('123', 20, 10)
var dataDefault = ctx.getImageData(20, 10, 50, 50).data
ctx.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繪制網絡字體的常用方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

標簽:盤錦 萍鄉 金昌 聊城 綏化 中山 赤峰 阿壩

巨人網絡通訊聲明:本文標題《html5 canvas繪制網絡字體的常用方法》,本文關鍵詞  html5,canvas,繪制,網絡,字體,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《html5 canvas繪制網絡字體的常用方法》相關的同類信息!
  • 本頁收集關于html5 canvas繪制網絡字體的常用方法的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美剧在线免费观看网站| 最好看的中文字幕久久| 91精品国产综合久久久久久久久久 | 亚洲高清在线视频| 久久久国产精品麻豆| 一本色道久久综合亚洲精品按摩| 麻豆精品一区二区三区| 欧美精品久久一区| 成人免费不卡视频| 欧美精品丝袜中出| 欧美日韩一区二区三区免费看 | 久久国产精品区| av亚洲精华国产精华| 91在线视频观看| 色嗨嗨av一区二区三区| 日韩和欧美一区二区三区| 欧美电影一区二区三区| 欧美主播一区二区三区美女| 蜜桃视频一区二区| 国产精品国产三级国产普通话蜜臀| 国产精品电影一区二区| 欧美日韩亚洲综合在线| 懂色av一区二区在线播放| 成人一二三区视频| 国产河南妇女毛片精品久久久| 欧美亚洲一区二区三区四区| 岛国精品在线观看| 亚洲第一主播视频| 99re热这里只有精品免费视频| 欧美一区二区在线免费播放| 成人欧美一区二区三区白人| 91精品久久久久久久91蜜桃| 奇米888四色在线精品| 亚洲第一激情av| 色婷婷综合中文久久一本| 欧美日韩一区二区三区在线 | 777亚洲妇女| 蜜臀a∨国产成人精品| 一卡二卡三卡日韩欧美| 国产精品污www在线观看| 精久久久久久久久久久| 视频一区二区三区在线| 4438成人网| 972aa.com艺术欧美| 成人永久aaa| 成人综合在线观看| 91在线视频播放| 国产乱码字幕精品高清av| 色噜噜狠狠色综合欧洲selulu| 欧美视频在线播放| 日av在线不卡| 国产精品另类一区| 久久综合色鬼综合色| 欧美激情综合网| 欧美一区二区视频观看视频| 久久亚洲综合av| 国产一区二区三区蝌蚪| 国内精品久久久久影院薰衣草 | 国产裸体歌舞团一区二区| 中文字幕乱码亚洲精品一区| 成人免费视频播放| 亚洲欧美日本在线| 中文字幕乱码久久午夜不卡 | 亚洲国产成人精品视频| 欧美精品乱人伦久久久久久| 欧美人狂配大交3d怪物一区| 一区二区在线电影| 日韩午夜在线播放| 欧美日韩国产123区| 美国毛片一区二区三区| 亚洲国产欧美在线人成| 在线播放91灌醉迷j高跟美女 | 91视频你懂的| 免费在线一区观看| 欧美一区二区三区影视| 欧美日本高清视频在线观看| 欧美一区二区三区爱爱| 精品久久久久av影院| 26uuu精品一区二区| 91精品免费在线| 日韩精品影音先锋| 美女精品一区二区| 中文字幕一区二区三区在线观看| 成人a级免费电影| 久久综合网色—综合色88| 国产日韩欧美一区二区三区综合| 精品一区二区三区免费毛片爱| 成人午夜激情影院| 激情图区综合网| 不卡在线视频中文字幕| 久久综合av免费| 在线不卡免费欧美| 亚洲国产三级在线| 国产精品国产自产拍高清av| 成人精品国产一区二区4080| 秋霞国产午夜精品免费视频 | 91精品国产乱码| 欧美在线视频不卡| 国产精品无遮挡| 国产成人精品免费| 狠狠色综合日日| 樱花影视一区二区| 欧美日韩黄色一区二区| 裸体在线国模精品偷拍| 69p69国产精品| 国产激情一区二区三区桃花岛亚洲| 国产精品久久久久影院| 国产精品视频免费| 久久电影国产免费久久电影| 欧美日韩中文一区| 欧美一级艳片视频免费观看| 国产乱码精品一区二区三区忘忧草| 欧美日本免费一区二区三区| 奇米影视一区二区三区| 欧美变态tickle挠乳网站| 成人激情动漫在线观看| 国产精品免费观看视频| 欧美在线色视频| 欧美一区二区三区在线视频| 欧美极品美女视频| 欧美日韩国产系列| 精品欧美一区二区久久 | 热久久久久久久| 亚洲男人的天堂网| 91污在线观看| 国产一区二区女| 丝袜a∨在线一区二区三区不卡| 欧美精品一区二区三区一线天视频| 亚洲国产精品一区二区久久恐怖片| 高清日韩电视剧大全免费| 91亚洲精品久久久蜜桃网站| 久久久久九九视频| 91精品国产色综合久久ai换脸| 色综合天天性综合| 免费在线观看一区二区三区| 国产午夜亚洲精品午夜鲁丝片| 99精品国产一区二区三区不卡| 国产精品久久久久久久久晋中 | 久久免费美女视频| 国产人成亚洲第一网站在线播放| 欧美电影免费观看高清完整版 | 免费欧美在线视频| 亚洲国产成人av| 夜夜爽夜夜爽精品视频| 欧美一级二级三级乱码| 日韩精品一区二区三区中文不卡| a亚洲天堂av| 91精品国产欧美一区二区| 日日摸夜夜添夜夜添国产精品| 2024国产精品| 精品国产乱码久久久久久老虎| 艳妇臀荡乳欲伦亚洲一区| 国产成人综合自拍| 精品国产免费人成在线观看| 久久影院视频免费| 亚洲一区国产视频| www成人在线观看| 国产亚洲精品超碰| 91久久免费观看| 国产成人精品亚洲午夜麻豆| 国产99久久久国产精品免费看| 最好看的中文字幕久久| 成人av影院在线| 欧美一级高清片在线观看| 国产精品久线在线观看| 亚洲一区二区黄色| 一区二区三区在线视频观看58| 精品福利一二区| 久久国产精品色| 极品销魂美女一区二区三区| 经典三级一区二区| 成人爽a毛片一区二区免费| 精品国产91乱码一区二区三区| 国产91精品一区二区麻豆亚洲| 欧美一区二区在线免费观看| 成人午夜私人影院| 国产精品久久久久四虎| 亚洲色图欧美激情| 国产精品三级av在线播放| 日本不卡中文字幕| 亚洲一区二区成人在线观看| 蜜臀av亚洲一区中文字幕| 国产精品午夜在线观看| 99re这里只有精品6| 成人看片黄a免费看在线| 国产日韩欧美精品综合| 欧美激情中文字幕| 91精品国产黑色紧身裤美女| 日本欧美在线观看| 精品视频在线免费| 国产午夜精品一区二区| 91国偷自产一区二区三区观看| 久久久精品免费网站| 蜜臀99久久精品久久久久久软件| 日韩欧美激情在线| 精品一区二区精品| 成人污污视频在线观看| 国产精品久久一级| 91蜜桃免费观看视频| 日韩黄色在线观看|