正在召唤神秘力量
导航

萌即是正义!时不时分享一些ACG活动记录与有趣代码的小站!

HTML5 Canvas在预加载完字体后绘图

作者:广树·时间:2021-11-01 20:08:20·分类:JavaScript/jQuery/Vue

有时候在绘制canvas的时候可能会用到一些特殊字体。而中文字体例如是用类似谷歌字体加载的话,可能会是分段加载,DOM不一定会加载过某些字体从而导致在绘制canvas时出现字体缺失。

这个时候可以使用如下代码预加载css中的字体

document.fonts.load

实际使用案例:

const loadTextFont = async (fontSize, text) => {
  await document.fonts.load(`${fontSize}px Noto Sans SC`, text).catch((e) => {
    console.error(e);
  });
};
const writeText = (text, fontSize, color, shadow, x, y, context) => {
  context.fillStyle = color;
  context.textBaseline = "middle";
  context.textAlign = "center";
  context.font = `${fontSize}px Noto Sans SC`;
  const res = context.measureText(text);
  if (shadow) {
    context.shadowBlur = 3;
    context.shadowColor = "black";
    context.strokeText(text, x, y);
  }
  context.fillText(text, x, y);
  return res;
};
const init = async (canvas,loadFont,title,fontSize) => {
  canvas.width = 396;
  canvas.height = 32;
  const context = canvas.getContext("2d");
  if(loadFont){
    await loadTextFont(fontSize, title);
  }
  const titleRes = writeText(
    title,
    fontSize,
    "#ffffff",
    true,
    202,
    15,
    context
  );
};
init(document.getElementById("canvas2"),false,"不预先加载思源字体","28");
init(document.getElementById("canvas"),true,"思源字体预加载","28");


DEMO测试

侧边栏
最新评论
广树
2024-04-24
@粽叶加米:我的体验是不好用还贵,等产品过期了一个个转移
广树
2024-04-24
@test_user:bloghub不是我开发的呢,只不过是收录了我的博客。
test_user
2024-04-24
@广树:不是大佬。。。,相比之下我更敬佩你,我是通过 bloghub 的 rss 订阅收到这条 topic 的,你回复我之后我才看了下, bloghub 是你的作品,你还有一些其他落地的作品,我很喜欢你这这样的实干家。 我前些年才意识到记录的重要性,以前去哪里都不会拍照,现在无论是网上的,还是线下的,都尽可能的记录下来了。。,记忆太不可靠了。。
粽叶加米
2024-04-24
我用了一年他的邮箱服务,不好不坏,后来转到Icloud+自定义邮箱了。
广树
2024-04-24
@Chise Hachiroku:是大佬!膜拜! 百度这样的模式真的不是作茧自缚吗?信息越来越狭小。
正在攻略

圣兽之王.jpg

传颂之物

PSN奖杯卡

PSN奖杯卡

赞助商广告