GAMESH

游戏美术动画unity资源搬运工!

剧情党,完美控!
桐崎千棘
当前位置:首页 > 学习 > 正文内容

使用Three.js在WebGL中导入Json 3D模型和动画

admin5年前 (2020-04-20)学习71580

当您使用3ds Max创建带有动画的模型时,并且需要快速的工作流来使用Three.js将它们加载到WebGL中时,我建议执行以下步骤:

1.从3ds Max导出模型

通过使用Json Exporter,您将能够轻松地将资产从3ds Max导出到Json 3D Format。导出器支持许多有用的功能,例如程序纹理,皮肤和体形修改器,多个动画剪辑,uv变换等等。

杰德

2.加载模型和动画

下载用于ThreejsJson 3D Loader,将其包含在html中并创建一个加载器:

<script src="three.js"></script><script src="JDLoader.min.js"></script><script>var meshes = [];var mixers = [];var clock = new THREE.Clock; 
var loader = new THREE.JDLoader();// ... the rest of your init code</script>

现在要将模型加载到您的场景中,类THREE.JDLoader将为我们做所有事情,您所需要做的就是指定模型文件路径并定义在加载模型时将调用的回调函数。回调函数具有一个对象参数,其中包含材质,jd_materials,对象和boundingSphere。data.materials是Three.js MeshPhongMaterial数组,而data.jd_materials是原始Json3D材料数组。如果需要创建自己的材质(例如ShaderMaterial),则应该解析data.jd_materials。

loader.load("anim.jd",
            function (data)
            {
                for (var i = 0; i < data.objects.length; ++i)
                {
                     var obj = data.createObject(i);
                     scene.add(obj);                     if (obj.geometry.animations)
                     {
                        var mixer = new THREE.AnimationMixer(obj);
                        mixers.push(mixer);                        var action = mixer.clipAction( obj.geometry.animations[0] );
                        action.play();                     }
                }
            });

最后,我们必须在动画循环中调用其update函数:

function animate(){   var delta = clock.getDelta();
   for (var i = 0; i < mixers.length; ++i)      mixers[i].update(delta); 
  // ... the rest of your code}

就是这样。您可以使用AnimationMixer类添加代码以在多个动画之间混合。


扫描二维码推送至手机访问。

本サイト上に掲載の文章、画像、写真などを無断で複製することは法律で禁じられています。全ての著作権はGAMESHに帰属します。

本文链接:https://pylblog.com/post/177.html

标签: 3dmax插件
分享给朋友:

相关文章

3dmax粒子系统 Particle Flow Presets 源文件下载

3dmax粒子系统 Particle Flow Presets 源文件下载

3ds Max 2015 Particle Flow Presets 粒子系统范例源文件,总共98个!包含各种粒子动画,是学习3dmax粒子动画的宝贵...

3dmax官方免费杀毒工具

3dmax官方免费杀毒工具

3ds Max 杀毒工具是 Autodesk 官方发布的用于安全地检测并移除恶意代码。恶意代码可能会损坏 3ds Max 环境和场景文件,导致数据丢失和不稳定,还有可能通过共享 3ds Max 场景文...

3dmax树经制作插件SplineBrancher

3dmax树经制作插件SplineBrancher

用于从一系列样条线创建分支几何的工具。下载URL适用于免费版本。请按照完整版的主页URL进行操作。附加信息: 设置:要安装,只需将SplineBrancher.zip解压缩到3DS Max目...

maxscript零基础教学写一个批量改名并导出插件

maxscript零基础教学写一个批量改名并导出插件

这篇文章我会用一个案例去讲解如何写一个maxscript脚本,这里我用批量修改max文件的骨骼名称。目标:修改一批max文件的bone00骨骼名称为bone99,然后导出fbx操作方法:1.打开max...

3dmax各种问题解决方案

3dmax各种问题解决方案

做动画已经几年了,一年中大部分的时间都在跟3dmax打交道!每天总会遇到许多奇葩的问题,然后这里我就根据自己经验总结一些决绝解决办法,希望对大家有帮助!   1.0  &...

3dmax gif预览生成插件

3dmax gif预览生成插件

3dmax本身不能生成gif图片,只能生成视频或者序列帧图片!这个插件能帮你实现gif生成。插件可以生成渲染gif和预览gif!适合生成论坛发作品的gif图片,图片体积不大,帧速率保持max源文件一样...