ccc-devtools/preview.js

202 lines
7.0 KiB
JavaScript
Raw Normal View History

2020-04-03 20:34:13 +08:00
const app = new Vue({
el: '#app',
vuetify: new Vuetify({
theme: { dark: true }
}),
data: {
isShowTop: true,
2020-04-03 20:34:13 +08:00
drawer: false,
2020-04-12 16:56:00 +08:00
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,
2020-04-07 00:51:08 +08:00
treeData: [],
selectedNodes: [],
2020-04-03 20:34:13 +08:00
intervalId: -1,
2020-04-07 00:51:08 +08:00
treeSearchText: null,
2020-04-03 20:34:13 +08:00
nodeSchema: {},
componentsSchema: [],
},
created() {
if (window.innerHeight === window.outerHeight) { // 手机端chrome device模式
this.isShowTop = false;
}
2020-04-07 20:45:38 +08:00
this.waitCCInit().then(() => {
if (this.isShowTop) {
this.startUpdateTree();
}
2020-04-07 20:45:38 +08:00
initConsoleUtil();
});
2020-04-03 20:34:13 +08:00
},
2020-04-12 16:56:00 +08:00
watch: {
cacheOnlyTexture() {
this.updateCacheData();
}
},
2020-04-03 20:34:13 +08:00
computed: {
2020-04-07 00:51:08 +08:00
treeFilter() {
2020-04-03 20:34:13 +08:00
return (item, search, textKey) => item[textKey].indexOf(search) > -1;
},
2020-04-07 00:51:08 +08:00
selectedNode() {
if (!this.selectedNodes.length) return undefined
let node = getNodeById(this.selectedNodes[0]);
2020-04-03 20:34:13 +08:00
if (node) {
let superPreLoad = node._onPreDestroy;
node._onPreDestroy = () => {
superPreLoad.apply(node);
2020-04-07 00:51:08 +08:00
if (this.selectedNodes.length > 0 && this.selectedNodes[0] === node._id) {
this.selectedNodes.pop();
2020-04-03 20:34:13 +08:00
}
}
2020-10-29 21:54:54 +08:00
this.nodeSchema = NEX_CONFIG.nodeSchema.node;
2020-04-03 20:34:13 +08:00
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++) {
2020-04-07 00:51:08 +08:00
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);
2020-04-03 20:34:13 +08:00
}
}
}
} else {
schema = {
title: component.__classname__,
key: component.__classname__
};
node[schema.key] = node.getComponent(schema.key);
}
componentsSchema.push(schema);
}
2020-04-07 00:51:08 +08:00
this.componentsSchema = componentsSchema;
2020-04-03 20:34:13 +08:00
}
2020-04-07 00:51:08 +08:00
return node;
},
},
methods: {
2020-04-07 20:45:38 +08:00
waitCCInit() {
return new Promise((resolve, reject) => {
let id = setInterval(() => {
if (window.cc) {
resolve();
clearInterval(id);
}
}, 500);
});
},
2020-04-07 00:51:08 +08:00
refreshTree: function () {
2020-10-29 21:54:54 +08:00
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);
2020-04-07 00:51:08 +08:00
},
startUpdateTree: function () {
this.$data.intervalId = setInterval(() => {
this.refreshTree();
}, 200);
},
stopUpdateTree: function () {
clearInterval(this.$data.intervalId);
2020-04-03 20:34:13 +08:00
},
2020-10-29 21:54:54 +08:00
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]);
}
}
},
2020-04-07 20:45:38 +08:00
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);
},
2020-04-12 16:56:00 +08:00
updateCacheData() {
if (this.$data.cacheOnlyTexture) {
2020-12-01 16:56:32 +08:00
this.$data.cacheData = this.$data.cacheRawData.filter(item => item.type === 'cc.Texture2D');
2020-04-12 16:56:00 +08:00
} else {
this.$data.cacheData = this.$data.cacheRawData;
}
},
openCacheDialog() {
[this.$data.cacheRawData, this.$data.cacheTitle] = cc.cache();
this.updateCacheData();
this.$data.cacheDialog = true;
},
2020-04-07 20:45:38 +08:00
openGithub() {
window.open('https://github.com/potato47/ccc-devtools');
},
2020-04-10 20:45:25 +08:00
openCocosForum() {
window.open('https://forum.cocos.com/');
},
openCocosDocs() {
window.open('https://docs.cocos.com/');
}
2020-04-03 20:34:13 +08:00
}
});
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 };
});
}
2020-04-07 00:51:08 +08:00
function getNodeById(id) {
let target;
const search = function (node) {
if (node._id === id) {
target = node;
return;
}
2020-10-29 21:54:54 +08:00
if (node.children.length) {
for (let i = 0; i < node.children.length; i++) {
2020-04-07 00:51:08 +08:00
if (!target) {
search(node.children[i]);
}
}
}
}
const scene = cc.director.getScene();
search(scene);
return target;
}