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);
}
相关文章
|
9月前
|
SQL 人工智能 JSON
插件
待确定推荐 • Grazie Professional
71 0
|
11月前
|
开发工具
ideaVim插件的使用
ideaVim插件的使用
82 0
【3款文献阅读的插件】
【3款文献阅读的插件】
652 0
|
文字识别 数据安全/隐私保护
大漠插件7.2302
大漠插件是一款文字图片识别的编程插件.能够被大多主流编语言调用
866 0
大漠插件7.2302
|
Rust Java Linux
优秀插件
优秀插件
149 0
优秀插件
|
XML 大数据 数据格式
ExcelDataReader插件的使用
ExcelDataReader插件的使用
292 0
|
JavaScript 前端开发 API
|
XML Java Maven
Jibx插件的使用
Jibx是一款非常优秀的XML文件数据绑定的框架,提供灵活的绑定映射文件,实现数据对象和XML文件之间的转换,并不需要修改既有的Java,另外,它的转换效率是目前很多其他开源项目都无法比拟的。本文来演示下如何使用
Jibx插件的使用
|
数据可视化 JavaScript IDE
我个人中意的VS2017/VS2019插件,推荐给大家(#^.^#)(1)
我个人中意的VS2017/VS2019插件,推荐给大家(#^.^#)
1175 0
我个人中意的VS2017/VS2019插件,推荐给大家(#^.^#)(1)
|
XML 人工智能 JSON
我个人中意的VS2017/VS2019插件,推荐给大家(#^.^#)(2)
我个人中意的VS2017/VS2019插件,推荐给大家(#^.^#)
768 0
我个人中意的VS2017/VS2019插件,推荐给大家(#^.^#)(2)