15 Star 174 Fork 63

德育处主任/Fabric.js学习资料(中文教程)

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
styles06fontFamily.html 1.40 KB
一键复制 编辑 原始数据 按行查看 历史
德育处主任 提交于 2023-06-06 12:55 +08:00 . 加载自定义字体
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>自定义字体</title>
<style>
@font-face {
font-family: ali;
src: url('../../fonts/AlibabaPuHuiTi-2-35-Thin.ttf');
}
@font-face {
font-family: douyu;
src: url('../../fonts/douyu.ttf');
}
</style>
</head>
<body>
<button onclick="setFont('douyu')">斗鱼</button>
<button onclick="setFont('ali')">阿里</button>
<canvas id="c" width="300" height="300" style="border: 1px solid #ccc"></canvas>
<script src="../../script/fontfaceobserver.js"></script>
<script src="../../script/fabric.js"></script>
<script>
const font = new FontFaceObserver('ali')
const canvas = new fabric.Canvas('c')
font.load()
.then(() => {
const iText = new fabric.IText('雷猴', {
fontFamily: 'ali'
})
canvas.add(iText)
})
function setFont(font) {
let fontFamily = new FontFaceObserver(font)
fontFamily.load()
.then(() => {
let target = canvas.getActiveObject()
if (target) {
target.set("fontFamily", font)
canvas.requestRenderAll()
}
})
.catch(() => {
console.error('字体加载失败')
})
}
</script>
</body>
</html>
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
JavaScript
1
https://gitee.com/k21vin/fabricjs-demo.git
git@gitee.com:k21vin/fabricjs-demo.git
k21vin
fabricjs-demo
Fabric.js学习资料(中文教程)
4dd53fef318d6019cba78e0058663e46ba4a3b0a

搜索帮助