内容简介:发布日期:2020年4月30日 了解更多请见Verge3D中国:https://verge3d.funjoy.tech/ Verge3D 3.1 for Maya正式版发布了,这是一个面向艺术家和设计师友好的创建3D网络交互的工具包。在此次版本更新中带来的新功能有...
发布日期:2020年4月30日
了解更多请见Verge3D中国:https://verge3d.funjoy.tech/
Verge3D 3.1 for Maya正式版发布了,这是一个面向艺术家和设计师友好的创建3D网络交互的 工具 包。在此次版本更新中带来的新功能有:增加新演示与Maya集成,更多操作VR控制器的手段,为物理引擎添加了许多新功能,为矢量操作新增了更多逻辑模块,提供了更快的基于图像的照明模式,增加了React.js和Vue.js模板,支持拼图中的HTML5指针事件,以及做了许多稳定性方面的改进。
新案例及Maya集成
《农夫之旅》案例现在也有了Maya版本,您可以在桌面PC或移动设备的浏览器上体验这款小巧而有趣的游戏。
《参数化模型》案例向用户展示如何轻松实现可定制的参数化模型。此案例效果多样,包括且不限于尺寸、形状、厚度、孔、轮廓等在内的多种部件,均可在应用运行时实时修改并设置动画。
视频演示:https://www.bilibili.com/video/BV1T4411Z71p/
Maya版本现在可以使用简单的物理演示案例了,可在发行版中查看其源文件。
我们修复了由新版本macOS的Gatekeeper安全特性引起的安装/运行问题。从现在起,如果 Python 3尚未安装,安装程序脚本将调用Python3安装过程。
现在由Verge3D拾取移动摄影机(以前使用的是第一人称摄影机)。
正确支持了对象轴,Verge3D现在可以更好地表示Maya变换了。我们还修正了一些与欧拉角有关的错误。
修复了场景中有两个同名对象导致的错误。
修复了UI中缺失或出现两次Verge3D设置的问题。
修复了着色组没有分配材质时导致的导出崩溃错误。
虚拟现实
虚拟现实方面现在有了新的 traverse controllers(遍历控制器) 和 get controller property(获取控制器属性) 拼图。
拼图 traverse controllers(遍历控制器) 允许您迭代所有连接的控制器 (例如 Oculus Quest 或 HTC Vive 的左右控制器)。在迭代时,您可以使用 get controller property(获取控制器属性) 拼图访问以下信息:
- object(对象) - 关联的 3D 对象名称 (这是表示控制器位置的不可见空/虚拟对象)。
- ray/reticle(射线/十字线) - 控制器发出的射线对象或选定物体时的十字线对象的名称 (例如,您可以通过这种方式更改线的颜色)。
- handedness(惯用手) - “左”、 “右” 或 “无”。
- target ray mode(目标射线模式) - Cardboard设备的“gaze” 或类似 Oculus 的控制器的 “tracked-pointer”。基于此选项的功能,所以我们将 feature available(功能可用) 拼图的Cardboard检测去掉了。
- profiles(配置) -区分HMD设备供应商的设备类型列表。例如,任何 Oculus Quest 控制器都将输出列表 [“oculus-touch-v2” 、 “oculus-touch” 、 “generic-trigger-squeeze-thumbstick”]。
- gamepad index(游戏手柄索引) - 与控制器关联的数值。您可以将此值传递给 get gamepad property(获取游戏手柄属性) 拼图并获取其状态,例如是否按下按钮 (通过 “按钮” 选项),或拇指棒如何移动 (通过 “轴” 选项) 等。
拼图 session event(会话事件) 有了 connected(连接) 和 disconnected(断开) 选项,可用于检测 VR 控制器的连接状态。
您可以使用前面提到的 get controller property(获取控制器属性) 拼图来检测哪个控制器已经连接或断开。通常,您应该在控制器连接后开始为其实现逻辑。
get gamepad(获取游戏手柄)拼图有了一个 debug info(调试信息) 选项。通过它您可以了解连接的VR控制器或游戏手柄上有哪些按钮或摇杆。
现在,VR 控制器发出的射线在与某个对象相交时,会自动调整其长度。
物理引擎更新
物理引擎支持改用浏览器原生技术 WebAssembly (Wasm) ,这将极大提升性能,减少内存占用,并将物理引擎模块的大小减半。
IE 11和旧版iOS Safari并不支持Wasm。因此,如果您需要针对这些浏览器开发应用物理引擎,请启用IE 11兼容模块选项。该选项将启用基于JavaScript的回退( ammo.js )。
增加了新拼图 on before/after simulation(模拟前/模拟后) ,我们建议您使用此拼图时为对象应用力/速度设置及碰撞检测。
使用这个拼图的基本原理是,物理模拟和渲染时间的循环是独立运行的,会产生不同的时间增量。因此借助于此拼图,您可以更好地在这两个循环之间同步,使物理运动更加流畅,碰撞检测看起来更加精确。
如上图所示, get object direction(获取对象方向) 拼图现在可以返回水平方向的矢量。这简化了第一人称视图中的导航。
增加了一个新的非常有用的拼图 body control(实体控制)。
有了这个拼图,你可以覆盖物理实体的状态,例如迫使它成为静态,运动或动态,禁用和恢复物理模拟,重置其力/速度, 让它休眠,等等。
其可用场景之一:您可以通过此拼图来用VR控制器抓取物体,并把它扔出去。
从现在开始,所有物理对象在一段时间不活动后都会进入休眠模式,为您的应用节省性能。如果对象与某些东西碰撞则会被激活,或者如果您特意使用上述 body control(实体控制) 拼图去激活它。
实现了幽灵(ghost)物理对象。
其可用场景之一: 检测拖动的物体 (如房间里的家具模型) 是否重叠,或按下 VR 控制器的按钮等。
为apply vector(应用向量)拼图增加了angular factor(角因数)和linear factor(线性因数)两个选项。使用这两个新选项,您可以为物理对象限制某个轴的运动(通过赋予0值给指定轴)。
可能的用例包括各种陀螺和摇摆,但您也可以使用此拼图来实现其他物理特征。
除了以前可用的动态和静态网格物体外,现在还支持运动学网格(Kinematic mesh)和残影网格(ghost mesh)物体。
新的拼图模块
数字|Numbers 类添加了使用矢量操作的拼图,即 create vector(创建矢量), set/get vector value(设置/获取矢量值)和 vector math(向量数学)。
增加了新的拼图clone animation(克隆动画)。使用此拼图,您可以从一段长动画中截取片段,并作为新的片段使用(通常用于角色动画)。
增加了新的拼图stop sound(停止声音)。除停止播放外,也将声音倒回开始。
现在可以使用拼图将非蒙皮对象的材质应用于蒙皮对象了。
基于图像照明的性能调整
这是一个重要的性能调整改进。从现在开始,您可以选择基于图像的照明算法。过去只可以使用有预过滤的 Mipmaped 辐射环境贴图 (PMREM) ——它可以产生高质量的渲染,但速度相当慢。新版本引入了两种基于light probes的更简单快速的技术,可以在Maya的的导出设置中启用:
- PMREM - 高质量,速度慢。这是默认选项。
- Light Probe + Cubemap - 降低基于图像的镜面反射质量,平均性能。
- Light Probe - 不使用基于图像的镜面反射,速度最快 (可能比 PMREM 快 10 倍)。
因此,如果您的应用有性能问题(低FPS),可以尝试通过切换到Light Probe技术来改善此问题。此外,您可以更换Principled BSDF节点为Diffuse BSDF或Emission BSDF节点来作为进一步的优化。
此外,用户对环境贴图大小的设定现在可以在Verge3D应用中实现了 (aiSkyDomeLight -> Hardware Texturing -> Texture Resolution)。
使用该设定可以有效提高反射质量,但会消耗大量内存和并造成性能下降。 我们建议大多数场景使用256像素即可,如果您需要更好的反射质量(例如渲染珠宝)可设置为512像素。
指针事件拼图
用于处理浏览器中输入设备的指针事件拼图现在采用了最新标准, 为HTML event(HTML事件) 拼图添加了Pointerdown , Pointerup , Pointermove等事件类型。
拼图 get event property(获取事件资产) 新增 isPrimary(例如,检测多点触摸事件的第一根手指) 和 pointerType(鼠标、触控笔或触摸) 选项。
我们也为此拼图新增了一些其他相关的事件属性:button, offsetX 和 offsetY 。其中button为鼠标按键,其值对应关系:0 - 左键,1 - 滚轮,2 - 右键,3 - 回退,4 - 前进。3、4按键仅限多键鼠标。
React.js 和 Vue.js 模板
引入了新的应用模板,Verge3D现在可以更容易地与React.js 和 Vue.js 应用集成。有关详细信息,请参阅本指南。
其他改进
WebGL 画布容器元素的 id 从简单的 “container” 更改为更明显的 “v3d-container”。如果您的项目中已经依赖此名称,请确保及时更新代码。
安装新版Verge3D到旧版同一目录时,已保存的拼图库文件my_library.xml将不会被覆盖。
对WebGL着色器做了一些优化,现在它们的编译速度提高了20~25%,有助于改进场景加载效率。
在JavaScript方法中,为Color类添加了CopyRGBEToLinear()和ConvertRGBEToLinear()。
更新并扩展了文档。更新的部分包括物理、照明和渲染 (适用于所有3个DCC套件),以及新的和以前实现的拼图的帮助页面。
错误修复
修复了一个与非节点材质相关的罕见问题。
修复了当VR控制器的父对象离开摄影机一段时间后会消失的错误。
修复了这些论坛主题中报告如下错误:
修复了screen-space reflection(屏幕空间反射)拼图中的错误。
修复了飞行摄影机或第一人称摄影机是某个对象的子物体时引起的错误。
修复了is visible(可见)拼图在某些情况不可用的问题。
修复了一系列因Windows用户名包含空格或非拉丁字母导致的安装错误问题。
修复了光线投射应用于已隐藏的父对象的错误,这些对象现在会被忽略。
我们修复了拼图中的各种由自动代码检查器发现的小错误。
立即升级!
就这么多啦,快去下载更新你的应用吧!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- NPM包(模块)发布、更新、撤销发布
- 有赞灰度发布与蓝绿发布实践
- 【重磅发布】Linkis 0.10.0 版本发布
- BeetlSQL 3.0.9 发布,Idea 插件发布
- 贝密游戏 0.7.0 发布,发布斗地主
- 【重磅发布】DataSphere Studio 0.9.0 版本发布
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。