mirror of
https://github.com/smallmain/cocos-enhance-kit.git
synced 2025-01-15 07:21:07 +00:00
371 lines
13 KiB
JavaScript
371 lines
13 KiB
JavaScript
|
/****************************************************************************
|
|||
|
Copyright (c) 2018 Xiamen Yaji Software Co., Ltd.
|
|||
|
|
|||
|
https://www.cocos.com/
|
|||
|
|
|||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|||
|
of this software and associated engine source code (the "Software"), a limited,
|
|||
|
worldwide, royalty-free, non-assignable, revocable and non-exclusive license
|
|||
|
to use Cocos Creator solely to develop games on your target platforms. You shall
|
|||
|
not use Cocos Creator software for developing other software or tools that's
|
|||
|
used for developing games. You are not granted to publish, distribute,
|
|||
|
sublicense, and/or sell copies of Cocos Creator.
|
|||
|
|
|||
|
The software or tools in this License Agreement are licensed, not sold.
|
|||
|
Xiamen Yaji Software Co., Ltd. reserves all rights not expressly granted to you.
|
|||
|
|
|||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|||
|
THE SOFTWARE.
|
|||
|
****************************************************************************/
|
|||
|
|
|||
|
const utils = require('./platform/utils');
|
|||
|
const debugInfos = require('../../DebugInfos') || {};
|
|||
|
const ERROR_MAP_URL = 'https://github.com/cocos-creator/engine/blob/master/EngineErrorMap.md';
|
|||
|
|
|||
|
// the html element displays log in web page (DebugMode.INFO_FOR_WEB_PAGE)
|
|||
|
let logList;
|
|||
|
|
|||
|
/**
|
|||
|
* @module cc
|
|||
|
*/
|
|||
|
|
|||
|
cc.log = cc.warn = cc.error = cc.assert = console.log.bind ? console.log.bind(console) : console.log;
|
|||
|
|
|||
|
let resetDebugSetting = function (mode) {
|
|||
|
// reset
|
|||
|
cc.log = cc.warn = cc.error = cc.assert = function () {};
|
|||
|
|
|||
|
if (mode === DebugMode.NONE)
|
|||
|
return;
|
|||
|
|
|||
|
if (mode > DebugMode.ERROR) {
|
|||
|
//log to web page
|
|||
|
|
|||
|
function logToWebPage (msg) {
|
|||
|
if (!cc.game.canvas)
|
|||
|
return;
|
|||
|
|
|||
|
if (!logList) {
|
|||
|
var logDiv = document.createElement("Div");
|
|||
|
logDiv.setAttribute("id", "logInfoDiv");
|
|||
|
logDiv.setAttribute("width", "200");
|
|||
|
logDiv.setAttribute("height", cc.game.canvas.height);
|
|||
|
var logDivStyle = logDiv.style;
|
|||
|
logDivStyle.zIndex = "99999";
|
|||
|
logDivStyle.position = "absolute";
|
|||
|
logDivStyle.top = logDivStyle.left = "0";
|
|||
|
|
|||
|
logList = document.createElement("textarea");
|
|||
|
logList.setAttribute("rows", "20");
|
|||
|
logList.setAttribute("cols", "30");
|
|||
|
logList.setAttribute("disabled", "true");
|
|||
|
var logListStyle = logList.style;
|
|||
|
logListStyle.backgroundColor = "transparent";
|
|||
|
logListStyle.borderBottom = "1px solid #cccccc";
|
|||
|
logListStyle.borderTopWidth = logListStyle.borderLeftWidth = logListStyle.borderRightWidth = "0px";
|
|||
|
logListStyle.borderTopStyle = logListStyle.borderLeftStyle = logListStyle.borderRightStyle = "none";
|
|||
|
logListStyle.padding = "0px";
|
|||
|
logListStyle.margin = 0;
|
|||
|
|
|||
|
logDiv.appendChild(logList);
|
|||
|
cc.game.canvas.parentNode.appendChild(logDiv);
|
|||
|
}
|
|||
|
|
|||
|
logList.value = logList.value + msg + "\r\n";
|
|||
|
logList.scrollTop = logList.scrollHeight;
|
|||
|
}
|
|||
|
|
|||
|
cc.error = function () {
|
|||
|
logToWebPage("ERROR : " + cc.js.formatStr.apply(null, arguments));
|
|||
|
};
|
|||
|
cc.assert = function (cond, msg) {
|
|||
|
'use strict';
|
|||
|
if (!cond && msg) {
|
|||
|
msg = cc.js.formatStr.apply(null, cc.js.shiftArguments.apply(null, arguments));
|
|||
|
logToWebPage("ASSERT: " + msg);
|
|||
|
}
|
|||
|
};
|
|||
|
if (mode !== DebugMode.ERROR_FOR_WEB_PAGE) {
|
|||
|
cc.warn = function () {
|
|||
|
logToWebPage("WARN : " + cc.js.formatStr.apply(null, arguments));
|
|||
|
};
|
|||
|
}
|
|||
|
if (mode === DebugMode.INFO_FOR_WEB_PAGE) {
|
|||
|
cc.log = function () {
|
|||
|
logToWebPage(cc.js.formatStr.apply(null, arguments));
|
|||
|
};
|
|||
|
}
|
|||
|
}
|
|||
|
else if (console && console.log.apply) {//console is null when user doesn't open dev tool on IE9
|
|||
|
//log to console
|
|||
|
|
|||
|
// For JSB
|
|||
|
if (!console.error) console.error = console.log;
|
|||
|
if (!console.warn) console.warn = console.log;
|
|||
|
|
|||
|
/**
|
|||
|
* !#en
|
|||
|
* Outputs an error message to the Cocos Creator Console (editor) or Web Console (runtime).<br/>
|
|||
|
* - In Cocos Creator, error is red.<br/>
|
|||
|
* - In Chrome, error have a red icon along with red message text.<br/>
|
|||
|
* !#zh
|
|||
|
* 输出错误消息到 Cocos Creator 编辑器的 Console 或运行时页面端的 Console 中。<br/>
|
|||
|
* - 在 Cocos Creator 中,错误信息显示是红色的。<br/>
|
|||
|
* - 在 Chrome 中,错误信息有红色的图标以及红色的消息文本。<br/>
|
|||
|
*
|
|||
|
* @method error
|
|||
|
* @param {any} msg - A JavaScript string containing zero or more substitution strings.
|
|||
|
* @param {any} ...subst - JavaScript objects with which to replace substitution strings within msg. This gives you additional control over the format of the output.
|
|||
|
*/
|
|||
|
if (CC_EDITOR) {
|
|||
|
cc.error = Editor.error;
|
|||
|
}
|
|||
|
else if (console.error.bind) {
|
|||
|
// use bind to avoid pollute call stacks
|
|||
|
cc.error = console.error.bind(console);
|
|||
|
}
|
|||
|
else {
|
|||
|
cc.error = CC_JSB || CC_RUNTIME ? console.error : function () {
|
|||
|
return console.error.apply(console, arguments);
|
|||
|
};
|
|||
|
}
|
|||
|
cc.assert = function (cond, msg) {
|
|||
|
if (!cond) {
|
|||
|
if (msg) {
|
|||
|
msg = cc.js.formatStr.apply(null, cc.js.shiftArguments.apply(null, arguments));
|
|||
|
}
|
|||
|
if (CC_DEV) {
|
|||
|
debugger;
|
|||
|
}
|
|||
|
if (CC_TEST) {
|
|||
|
ok(false, msg);
|
|||
|
}
|
|||
|
else {
|
|||
|
throw new Error(msg);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
if (mode !== DebugMode.ERROR) {
|
|||
|
/**
|
|||
|
* !#en
|
|||
|
* Outputs a warning message to the Cocos Creator Console (editor) or Web Console (runtime).
|
|||
|
* - In Cocos Creator, warning is yellow.
|
|||
|
* - In Chrome, warning have a yellow warning icon with the message text.
|
|||
|
* !#zh
|
|||
|
* 输出警告消息到 Cocos Creator 编辑器的 Console 或运行时 Web 端的 Console 中。<br/>
|
|||
|
* - 在 Cocos Creator 中,警告信息显示是黄色的。<br/>
|
|||
|
* - 在 Chrome 中,警告信息有着黄色的图标以及黄色的消息文本。<br/>
|
|||
|
* @method warn
|
|||
|
* @param {any} msg - A JavaScript string containing zero or more substitution strings.
|
|||
|
* @param {any} ...subst - JavaScript objects with which to replace substitution strings within msg. This gives you additional control over the format of the output.
|
|||
|
*/
|
|||
|
if (CC_EDITOR) {
|
|||
|
cc.warn = Editor.warn;
|
|||
|
}
|
|||
|
else if (console.warn.bind) {
|
|||
|
// use bind to avoid pollute call stacks
|
|||
|
cc.warn = console.warn.bind(console);
|
|||
|
}
|
|||
|
else {
|
|||
|
cc.warn = CC_JSB || CC_RUNTIME ? console.warn : function () {
|
|||
|
return console.warn.apply(console, arguments);
|
|||
|
};
|
|||
|
}
|
|||
|
}
|
|||
|
if (CC_EDITOR) {
|
|||
|
cc.log = Editor.log;
|
|||
|
}
|
|||
|
else if (mode === DebugMode.INFO) {
|
|||
|
/**
|
|||
|
* !#en Outputs a message to the Cocos Creator Console (editor) or Web Console (runtime).
|
|||
|
* !#zh 输出一条消息到 Cocos Creator 编辑器的 Console 或运行时 Web 端的 Console 中。
|
|||
|
* @method log
|
|||
|
* @param {String|any} msg - A JavaScript string containing zero or more substitution strings.
|
|||
|
* @param {any} ...subst - JavaScript objects with which to replace substitution strings within msg. This gives you additional control over the format of the output.
|
|||
|
*/
|
|||
|
if (CC_JSB || CC_RUNTIME) {
|
|||
|
if (scriptEngineType === "JavaScriptCore") {
|
|||
|
// console.log has to use `console` as its context for iOS 8~9. Therefore, apply it.
|
|||
|
cc.log = function () {
|
|||
|
return console.log.apply(console, arguments);
|
|||
|
};
|
|||
|
} else {
|
|||
|
cc.log = console.log;
|
|||
|
}
|
|||
|
}
|
|||
|
else if (console.log.bind) {
|
|||
|
// use bind to avoid pollute call stacks
|
|||
|
cc.log = console.log.bind(console);
|
|||
|
}
|
|||
|
else {
|
|||
|
cc.log = function () {
|
|||
|
return console.log.apply(console, arguments);
|
|||
|
};
|
|||
|
}
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
cc._throw = CC_EDITOR ? Editor.error : function (error) {
|
|||
|
utils.callInNextTick(function () {
|
|||
|
throw error;
|
|||
|
});
|
|||
|
};
|
|||
|
|
|||
|
function getTypedFormatter (type) {
|
|||
|
return function () {
|
|||
|
var id = arguments[0];
|
|||
|
var msg = CC_DEBUG ? (debugInfos[id] || 'unknown id') : `${type} ${id}, please go to ${ERROR_MAP_URL}#${id} to see details.`;
|
|||
|
if (arguments.length === 1) {
|
|||
|
return msg;
|
|||
|
}
|
|||
|
else if (arguments.length === 2) {
|
|||
|
return CC_DEBUG ? cc.js.formatStr(msg, arguments[1]) :
|
|||
|
msg + ' Arguments: ' + arguments[1];
|
|||
|
}
|
|||
|
else {
|
|||
|
var argsArray = cc.js.shiftArguments.apply(null, arguments);
|
|||
|
return CC_DEBUG ? cc.js.formatStr.apply(null, [msg].concat(argsArray)) :
|
|||
|
msg + ' Arguments: ' + argsArray.join(', ');
|
|||
|
}
|
|||
|
};
|
|||
|
}
|
|||
|
|
|||
|
var logFormatter = getTypedFormatter('Log');
|
|||
|
cc.logID = function () {
|
|||
|
cc.log(logFormatter.apply(null, arguments));
|
|||
|
};
|
|||
|
|
|||
|
var warnFormatter = getTypedFormatter('Warning');
|
|||
|
cc.warnID = function () {
|
|||
|
cc.warn(warnFormatter.apply(null, arguments));
|
|||
|
};
|
|||
|
|
|||
|
var errorFormatter = getTypedFormatter('Error');
|
|||
|
cc.errorID = function () {
|
|||
|
cc.error(errorFormatter.apply(null, arguments));
|
|||
|
};
|
|||
|
|
|||
|
var assertFormatter = getTypedFormatter('Assert');
|
|||
|
cc.assertID = function (cond) {
|
|||
|
'use strict';
|
|||
|
if (cond) {
|
|||
|
return;
|
|||
|
}
|
|||
|
cc.assert(false, assertFormatter.apply(null, cc.js.shiftArguments.apply(null, arguments)));
|
|||
|
};
|
|||
|
|
|||
|
/**
|
|||
|
* !#en Enum for debug modes.
|
|||
|
* !#zh 调试模式
|
|||
|
* @enum debug.DebugMode
|
|||
|
* @memberof cc
|
|||
|
*/
|
|||
|
var DebugMode = cc.Enum({
|
|||
|
/**
|
|||
|
* !#en The debug mode none.
|
|||
|
* !#zh 禁止模式,禁止显示任何日志信息。
|
|||
|
* @property NONE
|
|||
|
* @type {Number}
|
|||
|
* @static
|
|||
|
*/
|
|||
|
NONE: 0,
|
|||
|
/**
|
|||
|
* !#en The debug mode info.
|
|||
|
* !#zh 信息模式,在 console 中显示所有日志。
|
|||
|
* @property INFO
|
|||
|
* @type {Number}
|
|||
|
* @static
|
|||
|
*/
|
|||
|
INFO: 1,
|
|||
|
/**
|
|||
|
* !#en The debug mode warn.
|
|||
|
* !#zh 警告模式,在 console 中只显示 warn 级别以上的(包含 error)日志。
|
|||
|
* @property WARN
|
|||
|
* @type {Number}
|
|||
|
* @static
|
|||
|
*/
|
|||
|
WARN: 2,
|
|||
|
/**
|
|||
|
* !#en The debug mode error.
|
|||
|
* !#zh 错误模式,在 console 中只显示 error 日志。
|
|||
|
* @property ERROR
|
|||
|
* @type {Number}
|
|||
|
* @static
|
|||
|
*/
|
|||
|
ERROR: 3,
|
|||
|
/**
|
|||
|
* !#en The debug mode info for web page.
|
|||
|
* !#zh 信息模式(仅 WEB 端有效),在画面上输出所有信息。
|
|||
|
* @property INFO_FOR_WEB_PAGE
|
|||
|
* @type {Number}
|
|||
|
* @static
|
|||
|
*/
|
|||
|
INFO_FOR_WEB_PAGE: 4,
|
|||
|
/**
|
|||
|
* !#en The debug mode warn for web page.
|
|||
|
* !#zh 警告模式(仅 WEB 端有效),在画面上输出 warn 级别以上的(包含 error)信息。
|
|||
|
* @property WARN_FOR_WEB_PAGE
|
|||
|
* @type {Number}
|
|||
|
* @static
|
|||
|
*/
|
|||
|
WARN_FOR_WEB_PAGE: 5,
|
|||
|
/**
|
|||
|
* !#en The debug mode error for web page.
|
|||
|
* !#zh 错误模式(仅 WEB 端有效),在画面上输出 error 信息。
|
|||
|
* @property ERROR_FOR_WEB_PAGE
|
|||
|
* @type {Number}
|
|||
|
* @static
|
|||
|
*/
|
|||
|
ERROR_FOR_WEB_PAGE: 6
|
|||
|
});
|
|||
|
/**
|
|||
|
* !#en An object to boot the game.
|
|||
|
* !#zh 包含游戏主体信息并负责驱动游戏的游戏对象。
|
|||
|
* @class debug
|
|||
|
* @main
|
|||
|
* @static
|
|||
|
*/
|
|||
|
module.exports = cc.debug = {
|
|||
|
DebugMode: DebugMode,
|
|||
|
|
|||
|
_resetDebugSetting: resetDebugSetting,
|
|||
|
|
|||
|
/**
|
|||
|
* !#en Gets error message with the error id and possible parameters.
|
|||
|
* !#zh 通过 error id 和必要的参数来获取错误信息。
|
|||
|
* @method getError
|
|||
|
* @param {Number} errorId
|
|||
|
* @param {any} [param]
|
|||
|
* @return {String}
|
|||
|
*/
|
|||
|
getError: getTypedFormatter('ERROR'),
|
|||
|
|
|||
|
/**
|
|||
|
* !#en Returns whether or not to display the FPS informations.
|
|||
|
* !#zh 是否显示 FPS 信息。
|
|||
|
* @method isDisplayStats
|
|||
|
* @return {Boolean}
|
|||
|
*/
|
|||
|
isDisplayStats: function () {
|
|||
|
return cc.profiler ? cc.profiler.isShowingStats() : false;
|
|||
|
},
|
|||
|
|
|||
|
/**
|
|||
|
* !#en Sets whether display the FPS on the bottom-left corner.
|
|||
|
* !#zh 设置是否在左下角显示 FPS。
|
|||
|
* @method setDisplayStats
|
|||
|
* @param {Boolean} displayStats
|
|||
|
*/
|
|||
|
setDisplayStats: function (displayStats) {
|
|||
|
if (cc.profiler && cc.game.renderType !== cc.game.RENDER_TYPE_CANVAS) {
|
|||
|
displayStats ? cc.profiler.showStats() : cc.profiler.hideStats();
|
|||
|
cc.game.config.showFPS = !!displayStats;
|
|||
|
}
|
|||
|
},
|
|||
|
}
|