이 글에서는 Three.js가 글꼴 모델을 그리는 방법에 대한 관련 정보를 주로 소개합니다. 글에서 소개한 방법을 통해 얻은 효과는 매우 좋습니다. 도움이 필요한 친구들이 함께 참고해 보세요.
먼저 json 형식의 텍스트를 로드하려면 THREE.FontLoader()를 인스턴스화하고 성공적으로 로드되는 콜백 함수에서 그리드를 생성해야 합니다.
그런 다음 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); }); }
드디어 위치를 조정했더니 지금의 코드는 이렇게 생겼습니다.
마지막으로 모든 코드 삽입:
Title <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 ); // 使动画循环使用时阻尼或自转 意思是否有惯性 controls.enableDamping = true; //动态阻尼系数 就是鼠标拖拽旋转灵敏度 //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); } //窗口变动触发的函数 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>
관련 권장 사항:
html5 캔버스 그리기 글꼴, 그림 및 그래픽의 흐릿한 문제를 해결하는 방법
위 내용은 Three.js 그리기 글꼴 모델 샘플 코드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!