html5 - 请问利用font-face定义的字体怎么在canvas里应用?
问题描述
请问利用font-face定义的字体怎么在canvas里应用?
问题解答
回答1:<style> @font-face { font-family: '_________'; //下划线填字体名称 src: url('_________'); //下划线填字体文件 }</style><script type='text/javascript'> function draw() { var ctx = document.getElementById(’canvas’).getContext(’2d’); var img = new Image(); img.onload = function(){ ctx.drawImage(img,0,0); ctx.beginPath(); ctx.fillStyle = ’#000’; ctx.font = '60px Automania'; ctx.textBaseline = ’top’; ctx.fillText(’what this font looks’, 0, 5); ctx.stroke();}img.src = ’img.png’; }</script><input onclick='draw()' type='button' value='test' /><canvas height='800'></canvas>
不过不建议在canvas中使用自定义字体,因为字体文件加载太慢。。
回答2:1.必须再等到字体下载完成之后再去渲染canvas,字体才能有作用 2.canvas中所引用的字体必须在文档流中有标签(span,p等)引用改字体!!!这就是最大的坑了!!!
相关文章:
1. angular.js - protractor初学 参考案例运行测试文件 报Error: Timeout2. css - 移动端 盒子内加overflow-y:scroll后 字体会变大3. angular.js - angular post的Content-Type被设置,导致不能上传图片,求助!!4. 关docker hub上有些镜像的tag被标记““This image has vulnerabilities””5. android - 如何缩小APK的体积6. position:absolute、float、display:inline-block 都能实现相同效果,区别是什么?7. javascript - JS new Date() 保存到 mongodb 中会早8个小时,我们这里是东八区,mongodb 保存的是格林尼治时间8. javascript - 奇怪的Symbol的问题9. javascript - 在vue-cli引入vux后 使用报错10. node.js - 问个问题 Uncaught (in promise)

网公网安备