成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁(yè) > 知識(shí)庫(kù) > 詳解canvas繪制網(wǎng)絡(luò)字體幾種方法

詳解canvas繪制網(wǎng)絡(luò)字體幾種方法

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

最近在用canvas繪圖時(shí)遇到了一個(gè)令人頭痛的問(wèn)題:canvas繪制網(wǎng)絡(luò)字體時(shí)沒(méi)效果,遂開(kāi)始了一番解決方案查找測(cè)試,中間也碰到了不少坑,于是寫下此篇文章做個(gè)總結(jié),如果大家在用canvas時(shí)遇到了同樣的問(wèn)題,希望對(duì)大家有一定的幫助,接下來(lái)就來(lái)看看有哪幾種解決辦法

服務(wù)端轉(zhuǎn)換

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

webfontloader

webfontloader是一個(gè)由Google和Typekit共同開(kāi)發(fā)的組件庫(kù),提供了一組標(biāo)準(zhǔn)事件監(jiān)聽(tīng)字體的加載,雖然已經(jīng)很長(zhǎng)時(shí)間沒(méi)有更新了,但是對(duì)字體加載的監(jiān)聽(tīng)確實(shí)有效,下面來(lái)看一個(gè)具體的例子怎么使用:

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)
  }
})

首先通過(guò)require引入webfontloader,并且動(dòng)態(tài)插入一個(gè)script標(biāo)簽載入google的字體,然后調(diào)用webfontloader的load方法進(jìn)行配置監(jiān)聽(tīng),當(dāng)字體加載完成后就會(huì)觸發(fā)active鉤子,開(kāi)始繪制對(duì)應(yīng)字體的內(nèi)容,webfontloader提供了一個(gè)完整的事件系統(tǒng)鉤子給開(kāi)發(fā)者調(diào)用:

如果想要了解webfontloader的更多用法可以前往github查看學(xué)習(xí),如果你覺(jué)得為了繪制網(wǎng)絡(luò)字體需要引入一個(gè)js庫(kù)有點(diǎn)得不償失,沒(méi)關(guān)系,接下來(lái)向你接受不用庫(kù)的方法

document.fonts.load

如果你在Google上搜索canvas加載網(wǎng)絡(luò)字體,你一定能搜到下面這個(gè)方案:

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)
}

這個(gè)方案存在一點(diǎn)問(wèn)題,當(dāng)image onerror事件觸發(fā)的時(shí)候,并不能保證字體已經(jīng)加載完成,只能保證css文件已經(jīng)加載完成,因此,在第一次訪問(wèn)的時(shí)候并不會(huì)生效:

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


這是什么原因呢?我們來(lái)看一下刷新瀏覽器的網(wǎng)絡(luò)請(qǐng)求:

可以看到后面的字體走的是緩存,因此可以字體可以繪制出來(lái),但是如果將chrome調(diào)試的Disable cache勾選上,將緩存禁用掉,那么無(wú)論怎么刷新,字體都不會(huì)繪制出來(lái)。

有解決辦法嗎?答案是有的,使用Font Load API進(jìn)行加載,來(lái)看具體代碼:

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文件的加載,然后調(diào)用document.fonts.load看字體是否加載完成,這樣就可以準(zhǔn)確監(jiān)聽(tīng)到字體加載完成,但是這個(gè)api存在兼容性問(wèn)題,來(lái)看具體表格:

想要對(duì)這個(gè)api了解更多,可以前往mdn查看

對(duì)比繪制

對(duì)比繪制是什么意思呢?就是先設(shè)置一個(gè)沒(méi)有的字體,然后在設(shè)置我們需要的字體進(jìn)行對(duì)比,來(lái)看具體代碼:

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()

首先設(shè)置一個(gè)沒(méi)有的字體,繪制上去,然后拿到對(duì)應(yīng)區(qū)域的渲染數(shù)據(jù),然后再將渲染區(qū)域清除然后,然后再設(shè)置我們需要的字體,拿到對(duì)應(yīng)區(qū)域的渲染數(shù)據(jù),然后實(shí)時(shí)對(duì)比,當(dāng)渲染數(shù)據(jù)一樣時(shí),表示繪制的都是系統(tǒng)默認(rèn)字體,我們需要的字體沒(méi)有渲染出來(lái),然后執(zhí)行requestAnimationFrame再執(zhí)行detect檢測(cè)方法,直到渲染數(shù)據(jù)不一樣,就表示我們需要的字體已經(jīng)渲染完成

總結(jié)

這篇文章介紹了幾種canvas繪制網(wǎng)絡(luò)字體時(shí)的常用方法,每個(gè)方法都各有優(yōu)劣,希望對(duì)大家有所幫助,使用時(shí)根據(jù)具體情況選用。

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

標(biāo)簽:阿壩 盤錦 綏化 中山 金昌 萍鄉(xiāng) 赤峰 聊城

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解canvas繪制網(wǎng)絡(luò)字體幾種方法》,本文關(guān)鍵詞  詳解,canvas,繪制,網(wǎng)絡(luò),字體,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解canvas繪制網(wǎng)絡(luò)字體幾種方法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于詳解canvas繪制網(wǎng)絡(luò)字體幾種方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    欧美人与性禽动交精品| 国产一二区在线观看| 91大神在线网站| 欧美乱大交xxxxxbbb| 精品欧美国产一区二区三区不卡| 久久综合色影院| 久久激情av| 香港成人在线视频| 国产婷婷精品av在线| 97久久精品人人做人人爽| 日本中文字幕影院| 日本a口亚洲| 久久综合另类图片小说| 在线视频在线视频7m国产| 人妻偷人精品一区二区三区| 亚洲一区3d动漫同人无遮挡| 日韩av不卡一区二区| 欧美成人免费网站| 亚洲av毛片基地| 好男人看片在线观看免费观看国语| 成人性视频免费看| 伊人精品视频| 欧美精品一本久久男人的天堂| 久草在线看片| 欧美人成免费网站| 欧美激情一级欧美精品| av免费在线免费观看| 97久久超碰精品国产| 天天色天天操天天| 色噜噜日韩精品欧美一区二区| 91综合视频| 国产综合内射日韩久| 国产蜜臀97一区二区三区| 久久久97精品| 丝袜诱惑亚洲看片| 这里只有精品在线播放| 无码人妻精品一区二区蜜桃百度| 天堂资源在线中文精品| 日韩在线播放中文字幕| 亚洲国产古装精品网站| 日日噜噜噜噜人人爽亚洲精品| 中文字幕网在线| 国产精品无码久久久久| 国产一级一片免费播放| 亚洲精品成人区在线观看| 日产电影一区二区三区| 国产精品日日摸夜夜添夜夜av| 91麻豆精品国产91久久久更新时间| 麻豆系列在线观看| 精品www久久久久奶水| 884aa四虎影成人精品一区| 久久综合伊人77777麻豆| 色老头一区二区三区在线观看| 美女被c出白浆| 中文在线播放一区二区| 国产综合av一区二区三区| 国产在线精品一区免费香蕉| 国产精品一二三在线| 福利电影一区二区三区| 黄色视屏免费在线观看| 亚洲成a人片| 一本到一区二区三区| 91在线观看网站| 国产日韩欧美第一页| 九九热hot精品视频在线播放| 一二三区中文字幕| 日韩二区三区在线观看| 久久久电影免费观看完整版| 亚洲一区二区三区中文字幕在线观看| 一个人www欧美| 国产69久久精品成人看| 国产91色在线播放| a级片在线观看视频| 日韩欧国产精品一区综合无码| 一区二区精彩视频| 国产精品一区二区三区在线免费观看| 99久久国产宗和精品1上映| 91精品啪aⅴ在线观看国产| 三级毛片网站| 亚洲网站免费| 亚洲免费在线精品一区| 亚洲欧洲韩国日本视频| 免费91麻豆精品国产自产在线观看| 性网站在线观看| 日日碰狠狠添天天爽| 日韩精品免费一区二区夜夜嗨| 羞羞网站在线观看入口免费| 久久先锋影音av鲁色资源网| 欧美日韩在线精品一区二区三区激情综| ww国产内射精品后入国产| 九色自拍麻豆| 亚洲精品久久在线| 日韩精品丝袜美腿| 国产精品视频你懂的| 日韩欧美在线123| 亚洲国产精品国自产拍av秋霞| 日韩av网站在线免费观看| 欧美日韩综合色| www.色五月.com| 国产系列精品av| 欧美福利视频一区| 一本岛在免费一二三区| 日韩激情久久| 久久久精品免费视频| 国产人妖ts一区二区| 蜜桃视频一日韩欧美专区| 国产成人高清| 日韩1区2区日韩1区2区| 免费影院在线观看一区| 日日碰狠狠添天天爽超碰97| 日韩大片免费观看视频播放| 精品久久久精品| 99久久久无码国产精品性波多| 亚洲国产中文字幕在线视频综合| 精品一区2区三区| 国产精品蜜臀av| 亚洲综合另类| 欧美激情a在线| 亚洲夜夜综合| 国产剧情在线视频| 久久久精品影视| 国产精品久久久久久吹潮| 青青草国产精品| 91九色02白丝porn| 欧日韩在线观看| 久久久久久亚洲精品美女| 中文字幕一区二区在线观看| 日本久久一二三四| 午夜影院韩国伦理在线| 欧美手机在线观看| 一级一片免费看| 午夜伦理精品一区| 77777在线| 香蕉视频一区| 黄色亚洲在线| 欧美日韩高清区| 日韩精品一区二区三区四区视频| 成人福利在线视频| 国产蜜臀av在线播放| 少妇被躁爽到高潮无码文| 国产永久免费视频| 亚洲国产黄色片| 欧美性视频在线播放| 日韩午夜视频在线观看| 国产69精品久久久久9| 亚洲一区国产一区| 国产性生活网站| 噜噜噜久久,亚洲精品国产品| 在线国产视频观看| 欧美日韩亚洲综合一区二区三区激情在线| 一本色道久久亚洲综合精品蜜桃| 欧美 日韩 成人| 亚洲精品tv久久久久久久久| 欧美日韩综合一区二区三区| 在线观看中文字幕| 欧美成人免费| 永久免费看mv网站入口78| 国产成a人亚洲| 日本在线高清视频一区| 欧美男男tv网站在线播放| 亚洲第一黄网| 国产精品一二三在线| 国产激情自拍| 国产一区2区在线观看| 天堂精品高清1区2区3区| 91国语精品自产拍在线观看性色| а√中文在线资源库| 天天操天天射天天色| 日韩欧美一二三区| 国产电影精品久久禁18| 久久www人成免费看片中文| 久热精品视频在线免费观看| 亚洲欧美小视频| 欧美性色aⅴ视频一区日韩精品| 国产一区二区久久| 可以免费看毛片的网站| 不卡一区视频| 日韩中文字幕区一区有砖一区| 91夜夜未满十八勿入爽爽影院| 在线视频亚洲一区| 超级砰砰砰97免费观看最新一期| 丰满人妻中伦妇伦精品app| 久久精品播放| 成人免费在线视频播放| 国产又粗又黄又爽视频| 久久久久人妻一区精品色欧美| 久热精品在线观看视频| 国产欧美综合色| eeuss影院eeuss最新直达| 极品尤物av丝袜美腿在线观看| 久久精品女人毛片国产| 欧美成人三级在线视频| 国产精品高潮呻吟av| 日本免费久久高清视频| 杨钰莹一级淫片aaaaaa播放| 一区视频二区视频| 久久精品视频在线看| 91精品国产综合久久香蕉的用户体验| 91在线导航| 欧美丰满片xxx777| 色偷偷一区二区三区| 成人亚洲欧美日韩在线观看| av大片在线免费观看| 91小视频在线观看| 亚洲成人免费影院| 精品人妻互换一区二区三区| 日韩av网站导航| 亚洲精品一区二区三区99| 丝袜诱惑一区二区| porn亚洲| 午夜3点看的视频| 久久综合久久综合亚洲| 色欲综合视频天天天| 白白色视频在线| 亚洲美女淫视频| 人人狠狠综合久久亚洲| 国产精品99精品久久免费| 激情网站在线观看| 噜噜噜噜噜久久久久久91| 男女激烈动态图| 美女一区二区三区视频| 在线观看日本一区二区| 日本激情一区二区三区| 亚洲第一网中文字幕| 久久久精品动漫| 热久久这里只有| 天堂久久精品忘忧草| 亚洲激情网站免费观看| 少妇精品久久久| 色豆豆成人网| 高清视频在线观看一区| 免费a级毛片在线观看| 欧美剧情电影在线观看完整版免费励志电影| 欧美家庭影院| 欧美日韩免费一区二区| 又长又粗又大又爽| 日韩av电影免费播放| 日韩免费视频播放| 米奇777在线欧美播放| gogogo高清免费观看在线视频| 无码人妻aⅴ一区二区三区有奶水| 欧美成人精品在线观看| 中文字幕+乱码+中文字幕| 精品夜夜澡人妻无码av| 国产精品国产三级国产有无不卡| 性色a∨人人爽网站| 亚洲精品国产一区二| 国产中文字幕日韩| 国产精品视频一区国模私拍| 99成人在线观看| 日韩精品中文字幕一区二区三区| 久久久91精品国产一区二区精品| 精品精品国产高清a毛片牛牛| 中文字幕在线导航| 欧美大胆在线视频| 亚洲精品国产品国语在线app| 国产传媒欧美日韩成人| 亚洲的天堂在线中文字幕| 自拍av在线| 欧美特黄色片| 最新国产在线精品91尤物| 亚洲精品久久久狠狠狠爱| 欧美亚洲专区| 国产在线精品一区二区三区| 又粗又黑又大的吊av| 欧美 国产 小说 另类| 国产一区美女在线| 亚洲国产日韩美| 中文无码久久精品| 九九在线观看免费视频| 欧美极品视频| 最近中文字幕免费mv| 婷婷六月天丁香| 国产真实乱人偷精品人妻| 狠狠干狠狠久久| 狠狠88综合久久久久综合网| 亚洲一区二区免费视频| 中文字幕激情小说| 91欧美一区二区| mm131国产精品| 99re这里都是精品| 污视频网站免费| 国产日韩欧美影视| 91麻豆一二三四在线| 免费观看成人www动漫视频| 欧美黑人巨大xxx极品| 日本wwwcom| 超在线视频97| 亚洲一区综合| 欧美精品黑人性xxxx| 亚洲人成电影在在线观看网色| 欧美办公室脚交xxxx| 精品国产乱子伦| 亚洲韩国一区二区三区| 日韩激情视频在线| 日韩黄色影片| 亚洲天堂网av在线| 国内久久精品视频| 日本视频在线| 日韩电影一二三区| 色综合一区二区| 国内自拍亚洲| 亚洲一级二级片| 欧美亚洲三区| 亚洲精品欧美一区二区三区| 欧美视频免费一区二区三区| 在线观看免费小视频| 国语产色综合| 国产又粗又长又黄| 日批视频在线看| 日韩成人在线播放| 丰满少妇在线观看bd| 欧美三级欧美成人高清www| 国产富婆一级全黄大片| 在线观看亚洲一区二区| 91亚洲国产| 精品人妻少妇AV无码专区| 精品国产精品一区二区夜夜嗨| 久久久精品一区二区| 亚洲欧洲精品一区二区三区波多野1战4| av免费不卡| 国产99久久久久久免费看| 久久久久国产免费| 亚洲精品tv久久久久久久久久| 草草久久久无码国产专区| 国产精品卡一卡二卡三| 日韩成人亚洲| 希岛爱理中文字幕|