mirror of
https://github.com/potato47/ccc-devtools.git
synced 2025-01-13 22:41:44 +00:00
202 lines
7.0 KiB
JavaScript
202 lines
7.0 KiB
JavaScript
const app = new Vue({
|
||
el: '#app',
|
||
vuetify: new Vuetify({
|
||
theme: { dark: true }
|
||
}),
|
||
data: {
|
||
isShowTop: true,
|
||
drawer: false,
|
||
cacheDialog: false,
|
||
cacheTitle: '',
|
||
cacheHeaders: [
|
||
{ text: 'Type', value: 'type' },
|
||
{ text: 'Preivew', value: 'preview' },
|
||
{ text: 'ID', value: 'id' },
|
||
{ text: 'Size', value: 'size' },
|
||
],
|
||
cacheRawData: [],
|
||
cacheData: [],
|
||
cacheSearchText: null,
|
||
cacheOnlyTexture: true,
|
||
treeData: [],
|
||
selectedNodes: [],
|
||
intervalId: -1,
|
||
treeSearchText: null,
|
||
nodeSchema: {},
|
||
componentsSchema: [],
|
||
},
|
||
created() {
|
||
if (window.innerHeight === window.outerHeight) { // 手机端,chrome device模式
|
||
this.isShowTop = false;
|
||
}
|
||
this.waitCCInit().then(() => {
|
||
if (this.isShowTop) {
|
||
this.startUpdateTree();
|
||
}
|
||
initConsoleUtil();
|
||
});
|
||
},
|
||
watch: {
|
||
cacheOnlyTexture() {
|
||
this.updateCacheData();
|
||
}
|
||
},
|
||
computed: {
|
||
treeFilter() {
|
||
return (item, search, textKey) => item[textKey].indexOf(search) > -1;
|
||
},
|
||
selectedNode() {
|
||
if (!this.selectedNodes.length) return undefined
|
||
let node = getNodeById(this.selectedNodes[0]);
|
||
if (node) {
|
||
let superPreLoad = node._onPreDestroy;
|
||
node._onPreDestroy = () => {
|
||
superPreLoad.apply(node);
|
||
if (this.selectedNodes.length > 0 && this.selectedNodes[0] === node._id) {
|
||
this.selectedNodes.pop();
|
||
}
|
||
}
|
||
this.nodeSchema = NEX_CONFIG.nodeSchema.node;
|
||
let componentsSchema = [];
|
||
for (let component of node._components) {
|
||
let schema = NEX_CONFIG.componentsSchema[component.__classname__];
|
||
if (schema) {
|
||
node[schema.key] = node.getComponent(schema.key);
|
||
for (let i = 0; i < schema.rows.length; i++) {
|
||
if (schema.rows[i].type === 'color') {
|
||
if (!node[schema.key][schema.rows[i].key]) {
|
||
cc.js.getset(node[schema.key], schema.rows[i].key, () => {
|
||
return '#' + node.getComponent(schema.key)[schema.rows[i].rawKey].toHEX('#rrggbb');
|
||
}, (hex) => {
|
||
node.getComponent(schema.key)[schema.rows[i].rawKey] = new cc.Color().fromHEX(hex);
|
||
}, false, true);
|
||
}
|
||
}
|
||
}
|
||
} else {
|
||
schema = {
|
||
title: component.__classname__,
|
||
key: component.__classname__
|
||
};
|
||
node[schema.key] = node.getComponent(schema.key);
|
||
}
|
||
componentsSchema.push(schema);
|
||
}
|
||
this.componentsSchema = componentsSchema;
|
||
}
|
||
return node;
|
||
},
|
||
},
|
||
methods: {
|
||
waitCCInit() {
|
||
return new Promise((resolve, reject) => {
|
||
let id = setInterval(() => {
|
||
if (window.cc) {
|
||
resolve();
|
||
clearInterval(id);
|
||
}
|
||
}, 500);
|
||
});
|
||
},
|
||
refreshTree: function () {
|
||
if (!this.$data.drawer || !window.cc) {
|
||
return;
|
||
}
|
||
let currentScene = cc.director.getScene();
|
||
if (!currentScene || !currentScene.children) {
|
||
return;
|
||
}
|
||
// 包含场景根节点
|
||
// this.$data.treeData = [{ id: currentScene._id, name: 'Scene', active: currentScene.activeInHierarchy, open: true, children: getChildren(currentScene) }];
|
||
this.$data.treeData = getChildren(currentScene);
|
||
},
|
||
startUpdateTree: function () {
|
||
this.$data.intervalId = setInterval(() => {
|
||
this.refreshTree();
|
||
}, 200);
|
||
},
|
||
stopUpdateTree: function () {
|
||
clearInterval(this.$data.intervalId);
|
||
},
|
||
onSubPropInput: function (target, row) {
|
||
let value = target[row.parentKey][row.key];
|
||
if (typeof value === 'number' && !isNaN(value)) {
|
||
if (row.method === 'setRotationFromEuler') {
|
||
target.setRotationFromEuler(target.eulerAngles.x, target.eulerAngles.y, target.eulerAngles.z);
|
||
} else {
|
||
target[row.method](target[row.parentKey]);
|
||
}
|
||
}
|
||
},
|
||
outputNodeHandler(id) {
|
||
let i = 1;
|
||
while (window['temp' + i] !== undefined) {
|
||
i++;
|
||
}
|
||
window['temp' + i] = this.selectedNode;
|
||
console.log('temp' + i);
|
||
console.log(window['temp' + i]);
|
||
},
|
||
outputComponentHandler(component) {
|
||
let i = 1;
|
||
while (window['temp' + i] !== undefined) {
|
||
i++;
|
||
}
|
||
window['temp' + i] = this.selectedNode.getComponent(component);
|
||
console.log('temp' + i);
|
||
console.log(window['temp' + i]);
|
||
},
|
||
drawNodeRect() {
|
||
cc.where(this.selectedNode);
|
||
},
|
||
updateCacheData() {
|
||
if (this.$data.cacheOnlyTexture) {
|
||
this.$data.cacheData = this.$data.cacheRawData.filter(item => item.type === 'cc.Texture2D');
|
||
} else {
|
||
this.$data.cacheData = this.$data.cacheRawData;
|
||
}
|
||
},
|
||
openCacheDialog() {
|
||
[this.$data.cacheRawData, this.$data.cacheTitle] = cc.cache();
|
||
this.updateCacheData();
|
||
this.$data.cacheDialog = true;
|
||
},
|
||
openGithub() {
|
||
window.open('https://github.com/potato47/ccc-devtools');
|
||
},
|
||
openCocosForum() {
|
||
window.open('https://forum.cocos.com/');
|
||
},
|
||
openCocosDocs() {
|
||
window.open('https://docs.cocos.com/');
|
||
}
|
||
}
|
||
});
|
||
|
||
function getChildren(node) {
|
||
return node.children.map(child => {
|
||
let children = (child.children && child.children.length > 0) ? getChildren(child) : [];
|
||
return { id: child._id, name: child.name, active: child.activeInHierarchy, children };
|
||
});
|
||
}
|
||
|
||
function getNodeById(id) {
|
||
let target;
|
||
const search = function (node) {
|
||
if (node._id === id) {
|
||
target = node;
|
||
return;
|
||
}
|
||
if (node.children.length) {
|
||
for (let i = 0; i < node.children.length; i++) {
|
||
if (!target) {
|
||
search(node.children[i]);
|
||
}
|
||
}
|
||
}
|
||
}
|
||
const scene = cc.director.getScene();
|
||
search(scene);
|
||
return target;
|
||
}
|