mirror of
https://gitee.com/onvia/ccc-tnt-psd2ui
synced 2025-01-13 22:41:07 +00:00
145 lines
5.1 KiB
JavaScript
145 lines
5.1 KiB
JavaScript
"use strict";
|
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
};
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
exports.unload = exports.load = exports.methods = void 0;
|
|
//@ts-ignore
|
|
const package_json_1 = __importDefault(require("../package.json"));
|
|
const fs_extra_1 = __importDefault(require("fs-extra"));
|
|
const path_1 = __importDefault(require("path"));
|
|
const child_process_1 = __importDefault(require("child_process"));
|
|
let exec = child_process_1.default.exec;
|
|
const ENGINE_VER = "v342"; //
|
|
const projectAssets = path_1.default.join(Editor.Project.path, "assets");
|
|
const cacheFile = path_1.default.join(Editor.Project.path, "local", "psd-to-prefab-cache.json");
|
|
const commandBat = path_1.default.join(Editor.Project.path, `extensions\\${package_json_1.default.name}\\libs\\psd2ui\\command.bat`);
|
|
const configFile = path_1.default.join(Editor.Project.path, `extensions\\${package_json_1.default.name}\\config\\psd.config.json`);
|
|
let uuid2md5 = new Map();
|
|
let cacheFileJson = {};
|
|
/**
|
|
* @en
|
|
* @zh 为扩展的主进程的注册方法
|
|
*/
|
|
exports.methods = {
|
|
openPanel() {
|
|
Editor.Panel.open(package_json_1.default.name);
|
|
},
|
|
onClickPsd2UICache() {
|
|
console.log(`main-> onClickPsd2UICache111 `);
|
|
return new Promise((resolve, reject) => {
|
|
console.log(`main-> onClickPsd2UICache`);
|
|
let options = {
|
|
"project-assets": projectAssets,
|
|
"cache": cacheFile,
|
|
"init": true,
|
|
"engine-version": ENGINE_VER
|
|
};
|
|
Promise.all(_exec(options, [])).then(() => {
|
|
console.log("[psd2prefab] 执行缓存结束");
|
|
resolve();
|
|
});
|
|
});
|
|
},
|
|
async onPsd2UIDropFiles(param) {
|
|
let files = param.files;
|
|
let isForceImg = param.isForceImg;
|
|
let isImgOnly = param.isImgOnly;
|
|
let output = param.output;
|
|
let options = {
|
|
"project-assets": projectAssets,
|
|
"cache": cacheFile,
|
|
"engine-version": ENGINE_VER,
|
|
};
|
|
let tasks = [];
|
|
for (let i = 0; i < files.length; i++) {
|
|
const file = files[i];
|
|
let stat = fs_extra_1.default.statSync(file);
|
|
if (stat.isFile()) {
|
|
let ext = path_1.default.extname(file);
|
|
if (ext != '.psd') {
|
|
continue;
|
|
}
|
|
}
|
|
let args = JSON.parse(JSON.stringify(options));
|
|
args["input"] = file;
|
|
if (output) {
|
|
args["output"] = output;
|
|
}
|
|
if (isImgOnly) {
|
|
// 只导出图片
|
|
args["img-only"] = true;
|
|
}
|
|
else {
|
|
// 强制导出图片
|
|
if (isForceImg) {
|
|
args["force-img"] = true;
|
|
}
|
|
args["config"] = configFile;
|
|
}
|
|
_exec(args, tasks);
|
|
}
|
|
await Promise.all(tasks);
|
|
genUUID2MD5Mapping();
|
|
console.log("[ccc-tnt-psd2ui] psd 导出完成,输出位置为:", output ? output : "psd 同级目录");
|
|
},
|
|
};
|
|
function _exec(options, tasks) {
|
|
let jsonContent = JSON.stringify(options);
|
|
// console.log("[ccc-tnt-psd2ui] 批处理命令参数:" + jsonContent);
|
|
let base64 = Buffer.from(jsonContent).toString("base64");
|
|
// console.log('[ccc-tnt-psd2ui] start ' + commandBat + ' ' + `--json ${base64}`);
|
|
tasks.push(new Promise((rs) => {
|
|
exec('start ' + commandBat + ' ' + `--json ${base64}`, { windowsHide: false }, (err, stdout, stderr) => {
|
|
rs();
|
|
});
|
|
}));
|
|
return tasks;
|
|
}
|
|
/**
|
|
* 资源删除的监听
|
|
*
|
|
* @param {*} event
|
|
*/
|
|
function onAssetDeletedListener(event) {
|
|
if (uuid2md5.has(event)) {
|
|
let md5 = uuid2md5.get(event);
|
|
console.log(`[ccc-tnt-psd2ui] 删除资源 md5: ${md5}, uuid: ${event}`);
|
|
delete cacheFileJson[`${md5}`];
|
|
fs_extra_1.default.writeFileSync(cacheFile, JSON.stringify(cacheFileJson, null, 2));
|
|
}
|
|
}
|
|
/**
|
|
* 生成 uuid 转 MD5 的映射
|
|
*
|
|
*/
|
|
function genUUID2MD5Mapping() {
|
|
if (!fs_extra_1.default.existsSync(cacheFile)) {
|
|
return;
|
|
}
|
|
let content = fs_extra_1.default.readFileSync(cacheFile, 'utf-8');
|
|
let obj = JSON.parse(content);
|
|
cacheFileJson = obj;
|
|
for (const key in obj) {
|
|
const element = obj[key];
|
|
uuid2md5.set(element.textureUuid, key);
|
|
}
|
|
}
|
|
/**
|
|
* @en Hooks triggered after extension loading is complete
|
|
* @zh 扩展加载完成后触发的钩子
|
|
*/
|
|
const load = function () {
|
|
genUUID2MD5Mapping();
|
|
Editor.Message.addBroadcastListener("asset-db:asset-delete", onAssetDeletedListener);
|
|
};
|
|
exports.load = load;
|
|
/**
|
|
* @en Hooks triggered after extension uninstallation is complete
|
|
* @zh 扩展卸载完成后触发的钩子
|
|
*/
|
|
const unload = function () {
|
|
Editor.Message.removeBroadcastListener("asset-db:asset-delete", onAssetDeletedListener);
|
|
};
|
|
exports.unload = unload;
|