字体
由于 iCraft Editor 的绘图字体是基于 WebGL 的,所以字体资源需要单独加载,特别是在内网环境,字体资源需要提前下载到您的项目中。
如不主动设置字体资源,默认使用iCraft Editor 服务器以及谷歌的字体资源。
设置字体资源
iCraft Editor 内置了一些系统字体,默认字体为 AlibabaPuHuiTi,可以通过 defineConfig 静态方法设置字体资源, fontUrl 或者 fonts 二选一。
fontUrl
可通过 fontUrl 设置全局字体资源,优先级高于 fonts,适用于场景只有一种字体的情况
import { ICraftPlayer } from "@icraft/player";
ICraftPlayer.defineConfig({
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/AlibabaPuHuiTi/Bold.ttf",
});fonts
可通过 fonts 设置字体资源,优先级低于 fontUrl,适用于场景有多种字体的情况
import { ICraftPlayer } from "@icraft/player";
ICraftPlayer.defineConfig({
fonts: [
{
name: "AlibabaPuHuiTi",
styles: [
{
weight: "Bold",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/AlibabaPuHuiTi/Bold.ttf",
},
],
},
],
});⚠️
注意:defineConfig是静态方法,注意需要在最外层、最前面调用
系统字体资源
定义
interface FontFamily {
name: string;
styles: {
weight: string;
fontUrl: string;
}[];
}const FONTS: FontFamily[] = [
{
name: "AlibabaPuHuiTi",
styles: [
{
weight: "Regular",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/AlibabaPuHuiTi-3-55-Regular.ttf",
},
{
weight: "Bold",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/AlibabaPuHuiTi-3-85-Bold.ttf",
},
],
},
{
name: "Roboto",
styles: [
{
weight: "Regular",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Roboto/Regular.ttf",
},
{
weight: "Bold",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Roboto/Bold.ttf",
},
{
weight: "Italic",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Roboto/Italic.ttf",
},
{
weight: "BoldItalic",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Roboto/BoldItalic.ttf",
},
{
weight: "Black",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Roboto/Black.ttf",
},
{
weight: "BlackItalic",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Roboto/BlackItalic.ttf",
},
],
},
{
name: "Caveat",
styles: [
{
weight: "Regular",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Caveat/Regular.ttf",
},
{
weight: "Bold",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Caveat/Bold.ttf",
},
],
},
{
name: "Chakra Petch",
styles: [
{
weight: "Regular",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/ChakraPetch/Regular.ttf",
},
{
weight: "Bold",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/ChakraPetch/Bold.ttf",
},
],
},
{
name: "Dancing Script",
styles: [
{
weight: "Regular",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/DancingScript/Regular.ttf",
},
{
weight: "Bold",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/DancingScript/Bold.ttf",
},
],
},
{
name: "Fredoka",
styles: [
{
weight: "Regular",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Fredoka/Regular.ttf",
},
{
weight: "Bold",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Fredoka/Bold.ttf",
},
],
},
{
name: "Josefin Sans",
styles: [
{
weight: "Regular",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/JosefinSans/Regular.ttf",
},
{
weight: "Bold",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/JosefinSans/Bold.ttf",
},
],
},
{
name: "Noto Sans JP",
styles: [
{
weight: "Regular",
fontUrl: `https://unpkg.com/@icraft/engine/public/fonts/NotoSansJP/Regular.ttf`,
},
{
weight: "Bold",
fontUrl: `https://unpkg.com/@icraft/engine/public/fonts/NotoSansJP/Bold.ttf`,
},
],
},
{
name: "Noto Sans KR",
styles: [
{
weight: "Regular",
fontUrl: `https://unpkg.com/@icraft/engine/public/fonts/NotoSansKR/Regular.ttf`,
},
{
weight: "Bold",
fontUrl: `https://unpkg.com/@icraft/engine/public/fonts/NotoSansKR/Bold.ttf`,
},
],
},
{
name: "Noto Sans",
styles: [
{
weight: "Regular",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/NotoSans/Regular.ttf",
},
{
weight: "Bold",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/NotoSans/Bold.ttf",
},
],
},
{
name: "Noto Sans Hebrew",
styles: [
{
weight: "Regular",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/NotoSansHebrew/Regular.ttf",
},
{
weight: "Bold",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/NotoSansHebrew/Bold.ttf",
},
],
},
{
name: "Orbitron",
styles: [
{
weight: "Regular",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Orbitron/Regular.ttf",
},
{
weight: "Bold",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Orbitron/Bold.ttf",
},
],
},
{
name: "Oswald",
styles: [
{
weight: "Regular",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Oswald/Regular.ttf",
},
{
weight: "Bold",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Oswald/Bold.ttf",
},
],
},
{
name: "Philosopher",
styles: [
{
weight: "Regular",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Philosopher/Regular.ttf",
},
{
weight: "Bold",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Philosopher/Bold.ttf",
},
],
},
{
name: "Playfair Display",
styles: [
{
weight: "Regular",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/PlayfairDisplay/Regular.ttf",
},
{
weight: "Bold",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/PlayfairDisplay/Bold.ttf",
},
],
},
{
name: "Poppins",
styles: [
{
weight: "Regular",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Poppins/Regular.ttf",
},
{
weight: "Bold",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Poppins/Bold.ttf",
},
],
},
{
name: "Quicksand",
styles: [
{
weight: "Regular",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Quicksand/Regular.ttf",
},
{
weight: "Bold",
fontUrl: "https://unpkg.com/@icraft/engine/public/fonts/Quicksand/Bold.ttf",
},
],
},
];下载
AlibabaPuHuiTi
RegularBold
Roboto
RegularBoldItalicBoldItalicBlackBlackItalic
Caveat
RegularBold
Chakra Petch
RegularBold
Dancing Script
RegularBold
Fredoka
RegularBold
Josefin Sans
RegularBold
Noto Sans JP
RegularBold
Noto Sans KR
RegularBold
Noto Sans
RegularBold
Noto Sans Hebrew
RegularBold
Orbitron
RegularBold
Oswald
RegularBold
Philosopher
RegularBold
Playfair Display
RegularBold
Poppins
RegularBold
Quicksand
RegularBold
More Fonts: Google Fonts