导航

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

侧边栏
热门文章
1页面
程序员老黄历&求签
热度
259
2博文
360度带你《我们仍未知道那天所看见的花的名字》秩父圣地巡礼
热度
169
3博文
3DS模拟器简体中文字库 | Citra3ds字库 | 符文工房4乱码解决字库 | shared_font.bin
热度
117
4推文
今日份新宿,期待接下来的《龙女仆》剧场版。
热度
78
5博文
探访日本的废校:《悠哉日常大王/悠悠哉哉少女日和》圣地巡礼之旧小川小学校下里分校
热度
78
6推文
2025年3月8日去看了哆啦A梦的最新剧场版《哆啦A梦:大雄的绘世界物语》。 近两年的两部哆啦A梦在萝莉女主的塑造上下了不少功夫,软萌萌的,都好可爱呀! 剧情方面,座位合家欢的一部作品,依然能相当不错的照顾到各个年龄层的观众。有欢快有热血,也有些许感动。当然依然有些地方不能深入推敲。 虽然这次的题材选择了画,和上一部同属艺术类的题材,一开始有些担心表现形式的同质化,但是非常意外,这次编剧在剧情的变现形式上完全没有和前作有所重叠,这点好评。 不过这次的伏笔依然和上一部差不多是同一类型的伏笔,这点感觉有一点感受到了编剧对于伏笔设计上的创意匮乏。 虽然大致的剧情走向依然还是能从开头就猜到结尾的样子,不过还是有意外的内容存在。 另外此次的特典是小册子,里面包含了内容介绍以及和这次电影中提到的道具漫画。 总之还是非常推荐这部《哆啦A梦:大雄的绘世界物语》。
热度
78
7博文
如何使用1Panel搭建猛男自用的维基萌博客
热度
65
8博文
Live2d模型合集分享 | FaceRig | 海王星系列 | 初音未来 | 雷姆 | 凉风青叶 | 尼禄 | 薇尔莉特 | 小埋 | 樱花庄 | 玉藻前
热度
65
9页面
关于
热度
65
10页面
友链
热度
65
最新评论
广树管理员
2025-06-14 21:17
@阿卡林:对 我最近也有耳闻温州开了东方的咖啡,哪年回国去看看
阿卡林
2025-06-14 21:15
@Mimosa:雾雨咖啡店吧,最近温州也开了个车万风格的咖啡店 车万凉了这话听了好多年了,怎么感觉现在慢慢好起来了,连车万咖啡店都有了🤔
Temp Mail
2025-06-14 00:28
这篇文章勾起了我那该死的回忆,致敬曾经看哭的动漫
广树管理员
2025-06-13 22:18
@Zrzzz:🫡能治愈到大佬倍感荣幸
Zrzzz
2025-06-13 22:17
@广树:被这篇更新治愈到了🥺
攻略中
符文工房龙之天地
暂无评分
Steam符文工房龙之天地
2025年6月10日 20时 ~ 攻略中
已累计游玩6天
体验奇幻冒险与日常生活的 RPG《符文工房》系列最新作。 玩家可以在日常生活中种田、钓鱼和复兴村庄,也可以在冒险的过程中邂逅各种各样的角色。打造属于自己的“村庄”,享受全新的冒险与生活吧!
fault - StP - LIGHTKRAVTE
暂无评分
Steamfault - StP - LIGHTKRAVTE
2025年5月29日 20时 ~ 攻略中
已累计游玩2周4天
全球累计销量超过50万份的“fault”系列最新作!故事的舞台是一个融合了奇幻与科幻的超前世界——卢森海德王国。本作讲述了生活在此地的一个平凡又平庸的究极普通市民——名为果子的少年的故事。
PSN奖杯卡

PSN奖杯卡

归档
赞助商广告

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

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

有时候在绘制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测试

donate.png

1210 x 50(蓝底).png

cloudcone