GAMESH

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

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

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

admin6年前 (2020-04-20)学习86970

当您使用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插件
分享给朋友:

相关文章

unity环境资源包SUNTAIL - Stylized Fantasy Village

unity环境资源包SUNTAIL - Stylized Fantasy Village

Suntail - 是一个软件包,其中包含创建幻想中世纪村庄所需的一切:模型,纹理,FX,着色器,声音等。完全可定制且灵活。可编程渲染管线(SRP)兼容性描述235个预制件和84个声音,使一个完整的中...

3dmax gif预览生成插件

3dmax gif预览生成插件

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

3dmax自动存储辅助插件

3dmax自动存储辅助插件

如果您在工作时厌倦了3dsmax 自动保存和冻结,则此脚本适合您。它基于Vincent Lacour的想法。安装:将文件放在3dsmax安装的Scripts / startup文件夹中。重启...

unity3d特效资源包 Ultimate VFX V3.1

unity3d特效资源包 Ultimate VFX V3.1

需要Unity 5.5.0及以上版本制作真正的火焰、烟雾、闪电、狂暴风暴、冲击波等! AAA质量的效果,一个大集合(600MB)使用超高分辨率纹理,精灵表和先进的粒子系统配置为您的游戏...

免费看各网站VIP视频解析安卓客户端和浏览器插件

免费看各网站VIP视频解析安卓客户端和浏览器插件

你还在为视频网站需要会员发愁吗?每个月都要购买各个网站的会员需要一大笔钱,有时候买的会员网站没有你想看的视频,还需要购买其他网站的会员觉得很麻烦!其实网上有视频解析的网站,直接输入地址就可以观看,但是...

skin模式下隐藏模型

skin模式下隐藏模型

在蒙皮处理过程中,您可以隐藏和取消隐藏顶点或元素 (仅限多边形对象)   下载文件...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。