需要的环境
1.安装unity3d 4.x版本,推荐4.7.1,暂时不兼容5.x版本。
2.运行环境配置:将Setting目录内DLL解压缩,将包中Dll文件置于C:\Windows\System32目录下。
3.对应Egret3D引擎代码为3.2.0,如果低于此功能会有部分功能无法使用或者出现bug。
unity示例场景
1.打开插件内容Egret3D/Example内示例场景Example。
Mesh导出
1.将场景中Example_Mesh的active勾选为为可见,如下图所示:
data:image/s3,"s3://crabby-images/570ab/570ab678c8e7e78244172bf8870313c0665f8a2b" alt=""
2.进行导出前需要注意的是,由于unity shader的多样性,很难完全适配,所以推荐使用Egret3D下的shader对相应导出场景进行替换,也在MaterialShader中添加自己
所需要对应的类型,diffuseTexture支持Tiling和Offset功能(仅支持单张贴图)。
data:image/s3,"s3://crabby-images/99f32/99f32d78256b166fa2e4630f9df18fe7913ff254" alt=""
3.点击工具栏,选取场景导出按钮,即可导出。
data:image/s3,"s3://crabby-images/a294e/a294ee1ba6a890f6ae42981a815ba33327d8963d" alt=""
4.导出内容将自动保存在Egret3D/Egret3DSence目录下,可以点击查看导出内容。
data:image/s3,"s3://crabby-images/a8c54/a8c54da7ca7c9cc66c42f2a434878615b7914d35" alt=""
5.Egret3D引擎使用示例资源展示。
data:image/s3,"s3://crabby-images/ec901/ec901d4b78430609906ba4dda1f5929041f07de1" alt=""
6.注意事项:
a.由于引擎的不同,导出mesh对象的scale缩放值不能小于0。
b.关于尺寸大小的调节,如果为fbx文件导入unity,推荐使用Import Setting中scale factor的大小进行缩放,
c.由于unity中坐标单位是米,故导入Egret3D相关参数已经已经进行了缩放处理。
d.支持多Material导出
SkinnedMesh导出##
1.将场景中Example_SkinnedMesh勾选为为可见,如下图所示:
data:image/s3,"s3://crabby-images/a496f/a496fb2750d0d9afc7aef78ce2045358486f5179" alt=""
2.调整模型shader,可以参考mesh的调整方案。调整完毕后,点击SkinnedMeshRendererExport按钮,每个导出的shinnedmesh都包含动画列表,skinned列表,
根骨骼列表和骨骼binding列表。其中根骨骼必须拖选,少选或者不选会造成错误。骨骼binding是可选,根据需求进行绑定。这里我们演示手指绑定一个cube。
data:image/s3,"s3://crabby-images/9c921/9c9213d2442e7daeb50301450c53e61779f498e6" alt=""
3.确认无误后导出,运行至Egret3D引擎,如下所示
data:image/s3,"s3://crabby-images/fccd8/fccd88e9b507104b053c208141017ab2ee660be8" alt=""
4.注意事项:
a.现阶段骨骼动画支持animator组件,暂不支持animation组件,请确认后导出。
b.可以指定多个根节点。
c.骨骼的scale缩放暂时还不支持,需要置一后才能导出。
d.现阶段骨骼binding仅支持绑定mesh资源,其他内容需要拓展。
e.支持资源换装处理。
f.导出资源将自动重置坐标至(0,0,0)坐标点。
5.代码示例 Class_SkeletonAnimationEx:
module egret3d {
export class Class_SkeletonAnimationEx extends Class_View3D {
protected role: Role;
protected view1: View3D;
protected cameraCtl: LookAtController;
public constructor() {
super();
this.view1 = new View3D(0, 0, window.innerWidth, window.innerHeight);
this.view1.camera3D.lookAt(new Vector3D(0, 100, -100), new Vector3D(0, 0, 0));
this.view1.backColor = 0xff888888;
this._egret3DCanvas.addView3D(this.view1);
this.cameraCtl = new LookAtController(this.view1.camera3D, new Object3D());
this.cameraCtl.distance = 150;
this.cameraCtl.rotationX = 60;
this._egret3DCanvas.start();
this._egret3DCanvas.addEventListener(Event3D.ENTER_FRAME, this.update, this);
var roleLoader: RoleLoader = new RoleLoader();
roleLoader.addEventListener(LoaderEvent3D.LOADER_COMPLETE, this.onLoadComplete, this);
roleLoader.load("resource/0_0122_huanghunshibing/RoleConfig.json");
}
protected onLoadComplete(e: LoaderEvent3D): void {
this.role = e.data.role;
this.view1.addChild3D(this.role);
this.role.skeletonAnimation.play();
}
public update(e: Event3D) {
this.cameraCtl.update();
}
}
}
地形和光照导出
1.将场景中Example_Terrain勾选为为可见,如下图所示:
data:image/s3,"s3://crabby-images/53ae3/53ae319c12d4577f8f7b2ec41fbedd687485f42c" alt=""
2.确认无误后导出,运行至Egret3D引擎,如下所示
data:image/s3,"s3://crabby-images/f640f/f640f516eb086def852896d398d0649910434bba" alt=""
3.注意事项:
a.unity地形中绘制的花草是无法被导出的。
uv动画
1.选中UV动画对象(可以多选),点击工具栏,选取MarkUvAnimation按钮,如图所示。
data:image/s3,"s3://crabby-images/9fecb/9fecb8a63c11dcfae3668b03c33e9616d3a4fe61" alt=""
2.查看修改对应参数:
a. uv_0,不可为空,单张UV。
b. uv_1,暂时不可用。
data:image/s3,"s3://crabby-images/c6c95/c6c95462ee1010020e4c3dbd59c0c8f3fc952efb" alt=""
3.运行效果,可以在场景内运行unity查看效果:
data:image/s3,"s3://crabby-images/834c5/834c50194fc85053f71c573bee882d4f54e13f3d" alt=""
4.注意事项:
a.支持unity中预览滚动效果,以实际在Egret3D效果为准。
shader说明
1."Egret3D/dns" 其中dns分别指的是
a. d=>diffuseTexture
b. n=>normalTexture
c. s=>specularTexture
data:image/s3,"s3://crabby-images/59b8f/59b8fae39bf523c76ef0063a671e01d43cfed930" alt=""
2. 如果需要使用transparent的透明效果,可以调节Egret3D目录下shader的cutAlpha值进行实现。
资源导入
1.将导出资源文件夹放入如图所示位置:
data:image/s3,"s3://crabby-images/cc2b7/cc2b7ec4186de43af529c247defd67d03e03ace7" alt=""
2.使用maploader进行读取使用:
data:image/s3,"s3://crabby-images/4a50d/4a50df799764d28260dcaacd986b486d52f1bb2b" alt=""
Alpha错乱问题
1.点击工具栏,选取InitEgretLayer按钮,如图所示。
data:image/s3,"s3://crabby-images/36cd1/36cd132000b9dff7f4f0960d2185feda22007d16" alt=""
2.设置存在问题对象的layer层次,如图所示,完毕后导出即可。
data:image/s3,"s3://crabby-images/58b31/58b311e702ad11a241c8c529b40a67c8c0ba4fce" alt=""
Shader调节示例
1.选中如图所示mesh。
data:image/s3,"s3://crabby-images/e82db/e82db8da1d82e1c63bfd6889b38a0f8c795bdcf5" alt=""
2.调节颜色值,可以看到显著变化。(当前版本unity显示与Egret3D引擎内,会存在色差问题,建议以Egret3D为准对颜色进行调整)
data:image/s3,"s3://crabby-images/72558/725589feaaad4c9966b191e5597ed3b0edb55f07" alt=""
3.对于如何扣除图片的透明像素的处理方法,我们可以使用cutalpha功能进行实现。
data:image/s3,"s3://crabby-images/08c83/08c83dd8c1ba7c53c7f3c0b2f979e625fc1f91c0" alt=""