透过 three.js 在 Forge Viewer 里头创建 3D 文字(使用部份 r81 的功能)

2024-03-15 23:59

本文主要是介绍透过 three.js 在 Forge Viewer 里头创建 3D 文字(使用部份 r81 的功能),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

图片描述

对于 Forge Viewer 比较熟悉的朋友可能知道 Forge Viewer 使用了一个自定的 three.js 第 r71 版,但最新版的 three.js 版号已经来到 r81,所以在这两版号间已经有不少新功能被加到了 r81 版,是先前版本没有的。但很不幸的,新功能要加入 Forge Viewer里头这件事对于 Viewer 开发团队而言绝非一件易事,是需要一些时间来完成的;这篇文章将带领大家用最少的工作量将 r81 上的新功能拿来 Forge Viewer 上使用。

这篇文章是从How can you add text to the Forge Viewer with three.js? 得到的灵感,这个开发者想要在 Forge Viewer 的 Scene 里头通过Three.js的 TextGeometry加入 3D 文字,但 Forge Viewer 所使用的 three.js 里头有少一些相依的代码或资源,这里我们使用 Webpack 这个代码打包工具和 threejs-full-es6 这个套包来解决这个问题,通过这两个工具将 r81 或新版号的 three.js 功能引入你的 Forge 应用里,当然这边不是把整个 r81 的代码搬过来,而是只引入我们需要的部份。在这个案例里头,我们可以只将 TextGeometry 、Font和其他相依文档引入(例如Facetype.json)。

为了验证这个概念,下面是一个简单的 ES6 样例,用来创建我们的 TextGeometry :

import { Font, TextGeometry } from 'threejs-full-es6'
import FontJson from './helvetiker_bold.typeface.json'export default class TextExtensionextends Autodesk.Viewing.Extension {/// Adds a color material to the viewer///constructor (viewer, options) {super()this.viewer = viewer}load () {return true}unload () {return true}/// Adds a color material to the viewer///createColorMaterial (color) {const material = new THREE.MeshPhongMaterial({specular: new THREE.Color(color),side: THREE.DoubleSide,reflectivity: 0.0,color})const materials = this.viewer.impl.getMaterials()materials.addMaterial(color.toString(),material,true)return material}/// Wraps TextGeometry object and adds a new mesh to// the scene/createText (params) {const geometry = new TextGeometry(params.text,Object.assign({}, {font: new Font(FontJson),params}))const material = this.createColorMaterial(params.color)const text = new THREE.Mesh(geometry , material)text.position.set(params.position.x,params.position.y,params.position.z)this.viewer.impl.scene.add(text)this.viewer.impl.sceneUpdated(true)}
}Autodesk.Viewing.theExtensionManager.registerExtension('Viewing.Extension.Text', TextExtension)

他的使用方法是:

import './Viewing.Extension.Test'// ...// 载入扩展
viewer.loadExtension('Viewing.Extension.Test').then((extension) => {// 创建 3D 文字extension.createText({position: {x: -150, y: 50, z: 0},bevelEnabled: true,curveSegments: 24,bevelThickness: 1,color: 0xFFA500,text: 'Forge!',bevelSize: 1,height: 1,size: 1})
})

如果想要创建自个的 Facetype.json,可以透过这个网站来帮忙:http://gero3.github.io/facety...

这篇关于透过 three.js 在 Forge Viewer 里头创建 3D 文字(使用部份 r81 的功能)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/813693

相关文章

Git打标签从本地创建到远端推送的详细流程

《Git打标签从本地创建到远端推送的详细流程》在软件开发中,Git标签(Tag)是为发布版本、标记里程碑量身定制的“快照锚点”,它能永久记录项目历史中的关键节点,然而,仅创建本地标签往往不够,如何将其... 目录一、标签的两种“形态”二、本地创建与查看1. 打附注标http://www.chinasem.cn

Android实现图片浏览功能的示例详解(附带源码)

《Android实现图片浏览功能的示例详解(附带源码)》在许多应用中,都需要展示图片并支持用户进行浏览,本文主要为大家介绍了如何通过Android实现图片浏览功能,感兴趣的小伙伴可以跟随小编一起学习一... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

在Android中使用WebView在线查看PDF文件的方法示例

《在Android中使用WebView在线查看PDF文件的方法示例》在Android应用开发中,有时我们需要在客户端展示PDF文件,以便用户可以阅读或交互,:本文主要介绍在Android中使用We... 目录简介:1. WebView组件介绍2. 在androidManifest.XML中添加Interne

Java Stream流与使用操作指南

《JavaStream流与使用操作指南》Stream不是数据结构,而是一种高级的数据处理工具,允许你以声明式的方式处理数据集合,类似于SQL语句操作数据库,本文给大家介绍JavaStream流与使用... 目录一、什么是stream流二、创建stream流1.单列集合创建stream流2.双列集合创建str

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java