cocos2D插件转3D插件

简介: cocos2D插件转3D插件

cocos2D插件转3D插件

'use strict';
/**
 * 3d插件api映射,兼容2d插件
 * */
let fs = require("fs");
let path = require("path");
let baseDir = '';
const prsPath = (Editor.Project && Editor.Project.path ? Editor.Project.path : Editor.remote.projectPath).replace(/\\/g,'/');
// 2D 映射到 3D编辑器的命令
let MAP_CMD = {
    'scene:enter-prefab-edit-mode'  :'scene:open-scene',
    'scene:open-by-uuid'            :'scene:open-scene',
    'assets:hint'                   : "twinkle", // 3d里高亮资源命令是 ‘twinkle’
    'hint'                          : "hint"           // 高亮选中的节点,未找到映射关系
}
// 模拟creator2d插件的API实现
let Editor2D =
{
    isWin32 : path.sep == '\\',
    appPath : Editor.App.path,
    error : console.error,
    log : console.log,
    warn : console.warn,
    info : console.info,
    _getUrlLast(url_path,head){
        let p_i = url_path.indexOf(head);
        if(p_i!=-1){
            return url_path.substr(head.length+2);
        }
    },
    url(url_path){
        let absPath = Editor._getUrlLast(url_path,'packages:');
        if(absPath){
            return path.join(baseDir,absPath)
        }
        absPath = Editor._getUrlLast(url_path,'db:');
        if(absPath ) {
            return path.join(prsPath,absPath)
        }
        return url_path;
    },
    require(url){
        url = Editor2D.url(url);
        return require(url);
    },
    Ipc : {
        sendToPanel: (head,cmd,...args)=>Editor2D.Ipc._send(head,cmd,...args),
        sendToAll:(cmd,...args)=>Editor2D.Ipc.sendToMain(cmd,...args),
        sendToMain:(cmd,...args)=>
        {
            cmd = MAP_CMD[cmd] || cmd;
            let temp = cmd.split(':')
            if(temp[1]){
                Editor2D.Ipc._send(temp[0],temp[1] || "",...args);
            }else{
                Editor.Message.send(cmd,...args);
            }
        },
        _send(head,cmd,...args)
        {
            let callback = arguments[arguments.length-1]
            Editor.Message.request(head,cmd,...args).then((v)=>{
                if(typeof callback == 'function'){
                    callback(null,v);
                    callback = null;
                }
            },()=>{
                if(typeof callback == 'function'){
                    callback('run _send error');
                    callback = null;
                }
            })
        }
    },
    Scene :{
        callSceneScript:(head,cmd,...args)=>{
            let info = {
                name: 'scene',
                method: cmd,
                args:args,
            }
            let callback = arguments[arguments.length-1]
            Editor2D.Ipc._send('scene','execute-scene-script',info,(callback instanceof Function) ? callback : null);
        },
    },
    assetdb:{
        assetBackupPath : path.join(prsPath,'temp','BackupAssets'),
        async urlToUuid(url){
            return await Editor.Message.request("asset-db",'query-uuid',url);
        },
        async uuidToUrl(uuid){
            return await Editor.Message.request("asset-db",'query-url',uuid);
        },
        async urlToFspath(uuidOrUrl){
            return await Editor.Message.request("asset-db",'query-path',uuidOrUrl);
        },
        async uuidToFspath(uuidOrUrl){
            return await Editor.Message.request("asset-db",'query-path',uuidOrUrl);
        },
        async fspathToUuid(fsPath){
            let url = "db://" + fsPath.replace(/\\/g,'/').replace(prsPath,'').substr(6);
            return await Editor.Message.request("asset-db",'query-uuid',url);
        },
        async existsByUuid(urlOrUUID){
            return await Editor.Message.request("asset-db",'query-asset-info',urlOrUUID);
        },
        async existsByUrl(urlOrUUID){
            return await Editor.Message.request("asset-db",'query-asset-info',urlOrUUID);
        },
        async assetInfoByUuid(urlOrUUID){
            return await Editor.Message.request("asset-db",'query-asset-info',urlOrUUID); // 注意3d返回字段与2d不太一样!
        },
        async assetInfoByUrl(urlOrUUID){
            return await Editor.Message.request("asset-db",'query-asset-info',urlOrUUID); // 注意3d返回字段与2d不太一样!
        },
        deepQuery(callback){
            if(!callback){
                return
            }
            Editor.Message.request("asset-db",'query-assets',{pattern:"db://**"}).then((list)=>{
                // 注意3d返回字段与2d不太一样!
                callback(null,list)
            },()=>{
                callback("run deepQuery error")
            });
        },
        queryInfoByUrl(...args){Editor2D.assetdb.queryInfoByUuid(...args)},
        queryInfoByUuid(urlOrUUID,callback){
            Editor.Message.request("asset-db",'query-asset-info',urlOrUUID).then((list)=>{
                // 注意3d返回字段与2d不太一样!
                callback(null,list)
            },()=>{
                callback("run queryInfoByUuid error")
            });
        },
        saveExists(url,text,callback){
            let promise = Editor.Message.request("asset-db",'save-asset',url,text).then(()=>{
                if(callback) callback()
            },()=>{
                if(callback) callback('save error')
            });
        },
        create(url,text,callback){
            let promise = Editor.Message.request("asset-db",'create-asset',url,text,{}).then((info)=>{
                if(callback) callback(null,info)
            },()=>{
                if(callback) callback('save error')
            });
        },
        delete(urls){
            for (let i = 0; i < urls.length; i++) {
                const url = urls[i];
                Editor.Message.request("asset-db",'delete-asset',url)
            }
        },
        move(source,target){
            Editor.Message.request("asset-db",'move-asset',source,target)
        },
    },
    Selection:{
        curGlobalActivate(){
            let type = Editor.Selection.getLastSelectedType();
            let ids = Editor.Selection.getSelected(type);
            return {type,id:ids[0]};
        },
        curSelection(type){
            return Editor.Selection.getSelected(type);
        },
    }
}
module.exports.analogApi = ()=>
{
    let packageRoot = __dirname.replace(/\\/g,'/')
    packageRoot = packageRoot.substr(0,packageRoot.lastIndexOf('simple-code/')-1)
    baseDir = packageRoot;
    // 插入api
    let copyFunc = (s_obj,t_obj)=>
    {
        for (const key in s_obj)
        {
            const v = s_obj[key];
            if(t_obj[key] == null){
                t_obj[key] = v;
            }else if(t_obj[key] instanceof Object){
                copyFunc(v,t_obj[key]);
            }
        }
    }
    copyFunc(Editor2D,Editor);
}
相关文章
|
7月前
cocos creator+vscode安装及配置介绍
cocos creator+vscode安装及配置介绍
246 0
|
SQL 人工智能 JSON
插件
待确定推荐 • Grazie Professional
112 0
|
Web App开发 JavaScript 前端开发
VsCode 常用好用插件/配置+开发Vue 必装的插件
VsCode 常用好用插件/配置+开发Vue 必装的插件
315 0
[✔️]cocos creator 构建原生插件原理
[✔️]cocos creator 构建原生插件原理
242 0
【3款文献阅读的插件】
【3款文献阅读的插件】
761 0
|
存储 数据可视化 开发工具
flutter 开发中 vscode 插件推荐 3
Better Comments 这是 VS 代码开发人员使用的另一个流行扩展。它有助于创建丰富多彩的评论,这实际上使评论更具可读性。这有助于以更好的方式维护代码注释。评论可以帮助团队中的其他开发人员或我们未来的自己。您可以在评论中写 TODO,这有助于以后不会错过任何重要的作品。在评论中,您只需以 * 或 ! 或者 ?或 TODO,它会自动具有特定的颜色。
179 0
flutter 开发中 vscode 插件推荐 3
|
XML 人工智能 JSON
我个人中意的VS2017/VS2019插件,推荐给大家(#^.^#)(2)
我个人中意的VS2017/VS2019插件,推荐给大家(#^.^#)
1023 0
我个人中意的VS2017/VS2019插件,推荐给大家(#^.^#)(2)
|
Dart C++ Windows
flutter开发中vscode插件推荐2
这是Jeroen Meijer创建的最著名和最常用的扩展之一,许多顶级 Flutter 开发人员都建议使用它。这样可以更轻松地将 pub 添加到pubspec.yaml,而无需离开您的编辑器。这只会添加最新版本,因此它也可以用于更新现有的 pub。提供的一个很好的扩展 ,他从一开始就与 Flutter 联系在一起,并且是 Flutter 社区的主要贡献者。此扩展程序是最新的,没有已知问题,如果有任何问题,您可以直接联系任何帮助。
198 0
|
Dart C++ Windows
flutter开发中vscode插件推荐
vscode开发插件推荐 扩展是完成工作的快捷方式。许多扩展有助于减少重复性工作、减少样板代码等。其他一些扩展有助于协助开发过程,甚至有助于更快、更高效的开发。
234 0