欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Three.js實現(xiàn)繪制字體模型示例代碼

 更新時間:2017年09月26日 09:07:22   作者:專注前端30年  
最近在學習three.js,這篇文章屬于系列文章,下面這篇文章主要給大家介紹了關于Three.js如何繪制字體模型的相關資料,通過文中介紹的方法實現(xiàn)的效果非常的贊,需要的朋友可以參考借鑒,下面來一起看看吧。

前言

本文主要給大家介紹了關于利用Three.js繪制字體模型的相關內容,使用three.js繪制字體模型,沒有想象當中那么難。下面話不多說了,來一起看看詳細的介紹:

  • 首先你需要實例化 THREE.FontLoader() 來進行json格式的文字格式加載,在加載成功的回調函數里面進行創(chuàng)建網格。
  • 然后通過THREE.TextBufferGeometry或者THREE.TextGeometry方法進行網格創(chuàng)建,并將需要設置的問題傳入。
  • 再設置一個紋理,通過THREE.Mesh()函數創(chuàng)建成圖形添加到場景當中即可。

示例代碼:

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); 
 }); 
 } 

最后又調節(jié)了一下位置,就成了現(xiàn)在這個樣子的代碼。

最后放上所有的代碼:

<!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="build/three.js"></script> 
<script src="examples/js/controls/OrbitControls.js"></script> 
<script src="examples/js/libs/stats.min.js"></script> 
<script> 
 var renderer; 
 function initRender() { 
 renderer = new THREE.WebGLRenderer({antialias: true}); 
 renderer.setSize(window.innerWidth, window.innerHeight); 
 document.body.appendChild(renderer.domElement); 
 } 
 
 var camera; 
 function initCamera() { 
 camera = new THREE.PerspectiveCamera(45, window.innerWidth / window.innerHeight, 1, 10000); 
 camera.position.set(0, 0, 400); 
 } 
 
 var scene; 
 function initScene() { 
 scene = new THREE.Scene(); 
 } 
 
 var light; 
 function initLight() { 
 scene.add(new THREE.AmbientLight(0x404040)); 
 
 light = new THREE.DirectionalLight(0xffffff); 
 light.position.set(1, 1, 1); 
 scene.add(light); 
 } 
 
 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); 
 }); 
 } 
 
 //初始化性能插件 
 var stats; 
 function initStats() { 
 stats = new Stats(); 
 document.body.appendChild(stats.dom); 
 } 
 
 //用戶交互插件 鼠標左鍵按住旋轉,右鍵按住平移,滾輪縮放 
 var controls; 
 function initControls() { 
 
 controls = new THREE.OrbitControls(camera, renderer.domElement); 
 
 // 如果使用animate方法時,將此函數刪除 
 //controls.addEventListener( 'change', render ); 
 // 使動畫循環(huán)使用時阻尼或自轉 意思是否有慣性 
 controls.enableDamping = true; 
 //動態(tài)阻尼系數 就是鼠標拖拽旋轉靈敏度 
 //controls.dampingFactor = 0.25; 
 //是否可以縮放 
 controls.enableZoom = true; 
 //是否自動旋轉 
 controls.autoRotate = false; 
 //設置相機距離原點的最遠距離 
 controls.minDistance = 200; 
 //設置相機距離原點的最遠距離 
 controls.maxDistance = 600; 
 //是否開啟右鍵拖拽 
 controls.enablePan = true; 
 } 
 
 function render() { 
 renderer.render(scene, camera); 
 } 
 
 //窗口變動觸發(fā)的函數 
 function onWindowResize() { 
 camera.aspect = window.innerWidth / window.innerHeight; 
 camera.updateProjectionMatrix(); 
 render(); 
 renderer.setSize(window.innerWidth, window.innerHeight); 
 
 } 
 
 function animate() { 
 //更新控制器 
 controls.update(); 
 render(); 
 
 //更新性能插件 
 stats.update(); 
 requestAnimationFrame(animate); 
 } 
 
 function draw() { 
 initRender(); 
 initScene(); 
 initCamera(); 
 initLight(); 
 initModel(); 
 initControls(); 
 initStats(); 
 
 animate(); 
 window.onresize = onWindowResize; 
 } 
</script> 
</html> 

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關文章

  • JavaScript修改css樣式style動態(tài)改變元素樣式

    JavaScript修改css樣式style動態(tài)改變元素樣式

    修改css樣式style在某些情況下還是比較實用的,可以動態(tài)改變一些樣式,接下來為大家介紹下使用JavaScript是如何做到的
    2013-12-12
  • js閉包的9個使用場景

    js閉包的9個使用場景

    這篇文章主要介紹了js 閉包的9個使用場景,幫助大家更好的理解和學習JavaScript 閉包的使用,感興趣的朋友可以了解下
    2020-12-12
  • 解決layui數據表格Date日期格式的回顯Object的問題

    解決layui數據表格Date日期格式的回顯Object的問題

    今天小編就為大家分享一篇解決layui數據表格Date日期格式的回顯Object的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • js相冊效果代碼(點擊創(chuàng)建即可)

    js相冊效果代碼(點擊創(chuàng)建即可)

    利用js 書寫的相冊代碼,點擊創(chuàng)建即可看到效果,感興趣的朋友可以參考下哈,希望對你學習jquery有所幫助
    2013-04-04
  • 微信小程序實現(xiàn)發(fā)微博功能的示例代碼

    微信小程序實現(xiàn)發(fā)微博功能的示例代碼

    這篇文章主要介紹了微信小程序實現(xiàn)發(fā)微博功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • js為新添加元素添加綁定事件的實例代碼

    js為新添加元素添加綁定事件的實例代碼

    我們在開發(fā)中常遇到一種情況,在創(chuàng)建一個元素之后,需要給它綁定事件,這篇文章主要給大家介紹了關于js為新添加元素添加綁定事件的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-06-06
  • ES6新特性之函數的擴展實例詳解

    ES6新特性之函數的擴展實例詳解

    這篇文章主要介紹了ES6新特性之函數的擴展,實例形式較為詳細的分析了ES6針對函數參數、運算符及相關新特性的擴展操作與注意事項,需要的朋友可以參考下
    2017-04-04
  • webpack構建打包的性能優(yōu)化實戰(zhàn)指南

    webpack構建打包的性能優(yōu)化實戰(zhàn)指南

    webpack是前端開發(fā)中比較常用的打包工具之一,另外還有gulp,grunt,下面這篇文章主要給大家介紹了關于webpack構建打包的性能優(yōu)化的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-03-03
  • 小程序云開發(fā)實戰(zhàn)小結

    小程序云開發(fā)實戰(zhàn)小結

    這篇文章主要介紹了小程序云開發(fā)實戰(zhàn)小結,本文詳細的介紹了云開發(fā)以及環(huán)境的搭建和項目實踐,非常具有實用價值,需要的朋友可以參考下
    2018-10-10
  • js簡單判斷移動端系統(tǒng)的方法

    js簡單判斷移動端系統(tǒng)的方法

    這篇文章主要介紹了js簡單判斷移動端系統(tǒng)的方法,通過JavaScript的navigator.userAgent相關屬性判斷訪問端的系統(tǒng)類型,非常簡單實用,需要的朋友可以參考下
    2016-02-02

最新評論