发布Laya项目时自动建立动画Ani与atlas的关联(JSON

2018-09-07  本文已影响0人  ritei

每次我们加载ani文件需先加载对应的图集文件,由于项目比较大资源较多,所以首先想到的是建立一个ani到图集的对应文件。
这种关系的建立有两种方法{
1)建表导出JSON
2)用工具自动生成对应表。
显然第二种比较适合实际项目,研究了一下Laya编辑器的实现,其实Laya编辑器就像是一个chrome浏览器,编辑器里面的多数功能都是用JS实现的。


捕获.PNG

首先把Laya切换到编辑模式,点开发人员工具,熟悉的chrome调试界面出来了。


捕获2.PNG 捕获3.PNG

一步步跟找到打包的入口函数
需要修改代码的文件路径是:\LayaAirIDE_beta\resources\app\out\vs\layaEditor\h5\layabuilder.max.js
代码的主要功能是:
先收集所有ani文件的图集。

    /**收集Ani引用的图集 by ritei*/
    CodeManager.collectAniAtlas=function(obj,atlasDic){
        if(obj.animations){
            var a=0,n=0,k=0,s=0,alen=0,nlen=0,slen=0;
            var animations=obj.animations;
            alen=animations.length;
            for(a=0;a<alen;a++){
                var nodes = animations[a].nodes;
                if(nodes&&nodes.length>0){
                    nlen = nodes.length;
                    for(n=0;n<nlen;n++){
                        var keyframes = nodes[n].keyframes;
                        if (keyframes){
                            var skin = keyframes.skin;
                            if (skin&&skin.length>0){
                                slen = skin.length;
                                for(s=0;s<slen;s++){
                                    var skinStr = skin[s].value;
                                    var path = FileTools.getFileDir(skinStr);
                                    atlasDic[path] = 1;
                                }
                            }
                        }
                    }
                }
            }
        }
    }

最后输出到json文件

        // 输出动画图集映射文件 by ritei
        var tarPath;
        tarPath = FileManager.getPath(FileManager.getWorkPath(ProjectSetting.asynResExportPath),"atlasMap.json");
        FileManager.createJSONFile(tarPath,aniAtlasDic);

回到编辑器
我的资源目录是这样的:


捕获5.PNG

点发布,会在bin目录下生成atlasMap.json文件
里面的内容:


捕获4.PNG
上一篇 下一篇

猜你喜欢

热点阅读