前言
本文主要给大家介绍了关于利用Three.js绘制字体模型的相关内容,使用three.js绘制字体模型,没有想象当中那么难。下面话不多说了,来一起看看详细的介绍:
- 首先你需要实例化
THREE.FontLoader()
来进行json格式的文字格式加载,在加载成功的回调函数里面进行创建网格。 - 然后通过THREE.TextBufferGeometry或者
THREE.TextGeometry
方法进行网格创建,并将需要设置的问题传入。 - 再设置一个纹理,
通过THREE.Mesh()
函数创建成图形添加到场景当中即可。
示例代码:
var fontModel; function initModel() { var font; var loader = new THREE.FontLoader(); loader.load("examples/fonts/gentilis_regular.typeface.json", function (res) { font = new THREE.TextBufferGeometry("fdsfasd", { font: res, size: 100, height: 60 }); font.computeBoundingBox(); // 运行以后设置font的boundingBox属性对象,如果不运行无法获得。 //font.computeVertexNormals(); var map = new THREE.TextureLoader().load("examples/textures/UV_Grid_Sm.jpg"); var material = new THREE.MeshLambertMaterial({map:map,side:THREE.DoubleSide}); fontModel = new THREE.Mesh(font,material); //设置位置 fontModel.position.x = - (font.boundingBox.max.x - font.boundingBox.min.x)/2; //计算出整个模型的宽度的一半 fontModel.position.y = - 50; fontModel.position.z = - 30; scene.add(fontModel); }); }
最后又调节了一下位置,就成了现在这个样子的代码。
最后放上所有的代码:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style type="text/css"> html, body { margin: 0; height: 100%; } canvas { display: block; } </style> </head> <body onload="draw();"> </body> <script src="/UploadFiles/2021-04-02/three.js">总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“Three.js实现绘制字体模型示例代码”评论...
更新动态
2024年05月10日
2024年05月10日
- 群星《妖神令 影视原声专辑》[320K/MP3][85.23MB]
- 逆水寒手游五子棋第二十三关怎么过 逆水寒手游残局攻略大全
- 逆水寒手游五子棋第二十二关怎么过 逆水寒手游残局攻略大全
- 欢乐钓鱼大师最稀有的鱼是什么 欢乐钓鱼大师最稀有的鱼攻略
- ABC唱片-《蔡琴.三十周年纪念版》6N纯银镀膜[WAV+CUE]
- ABC唱片-《汉斯.德斯辛克.心中布鲁斯》6N纯银镀膜[WAV+CUE]
- 群星《DJ·夜色魅影HQ》头版限量[低速原抓WAV+CUE]
- 《如龙》桐生声优被警察拦下盘问:你有犯罪记录吗?
- 游族2023年净利润0.91亿元 《少年西游记2》即将公测
- 曝快手北京游戏事业部全数被裁 项目测试数据未达标
- 李雨寰.2012-我可是天使【有凰音乐】【WAV+CUE】
- 刘美君.1991-听我细诉【BMG】【WAV+CUE】
- 群星.2016-滚石爱情故事3CD【滚石】【WAV+CUE】
- 欢乐钓鱼大师怎么解锁全地图 欢乐钓鱼大师全地图解锁方法
- 欢乐钓鱼大师锦标赛在哪里进 欢乐钓鱼大师锦标赛入口位置介绍