UIBase.js 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  1. (function() {
  2. var nodeEnv = typeof require !== 'undefined' && typeof process !== 'undefined';
  3. var __module = nodeEnv ? module : {exports:{}};
  4. var __filename = 'preview-scripts/assets/script/logic/ui/UIBase.js';
  5. var __require = nodeEnv ? function (request) {
  6. return cc.require(request);
  7. } : function (request) {
  8. return __quick_compile_project__.require(request, __filename);
  9. };
  10. function __define (exports, require, module) {
  11. if (!nodeEnv) {__quick_compile_project__.registerModule(__filename, module);}"use strict";
  12. cc._RF.push(module, '76454/+dxNA36XaoEgldO2R', 'UIBase');
  13. // script/logic/ui/UIBase.ts
  14. "use strict";
  15. var __extends = (this && this.__extends) || (function () {
  16. var extendStatics = function (d, b) {
  17. extendStatics = Object.setPrototypeOf ||
  18. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  19. function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
  20. return extendStatics(d, b);
  21. };
  22. return function (d, b) {
  23. extendStatics(d, b);
  24. function __() { this.constructor = d; }
  25. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  26. };
  27. })();
  28. var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
  29. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  30. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  31. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  32. return c > 3 && r && Object.defineProperty(target, key, r), r;
  33. };
  34. Object.defineProperty(exports, "__esModule", { value: true });
  35. exports.BASE_POP = void 0;
  36. var TypeConst_1 = require("../../data/const/TypeConst");
  37. var GameDataCenter_1 = require("../../data/GameDataCenter");
  38. var EventMng_1 = require("../../manager/EventMng");
  39. var UICommon_1 = require("../../utils/UICommon");
  40. // 弹出方式
  41. var BASE_POP;
  42. (function (BASE_POP) {
  43. BASE_POP["MAIN"] = "MAIN";
  44. BASE_POP["UI"] = "UI";
  45. BASE_POP["UI_HALF"] = "UI_HALF";
  46. BASE_POP["FULL"] = "FULL";
  47. BASE_POP["POP"] = "POP";
  48. BASE_POP["MemuBottom"] = "MemuBottom";
  49. BASE_POP["Battle"] = "Battle"; // 战斗弹窗
  50. })(BASE_POP = exports.BASE_POP || (exports.BASE_POP = {}));
  51. var PREFAB_UI_DIR = 'prefab/';
  52. var _a = cc._decorator, ccclass = _a.ccclass, property = _a.property;
  53. var UIBase = /** @class */ (function (_super) {
  54. __extends(UIBase, _super);
  55. function UIBase() {
  56. var _this = _super !== null && _super.apply(this, arguments) || this;
  57. _this.belong = null;
  58. _this.showAnim = true;
  59. _this.bgm = TypeConst_1.AudioConst.empty;
  60. /** 是否注册防穿透事件 */
  61. _this.isRegisterStopEvent = true;
  62. _this.registerCount = 0;
  63. return _this;
  64. }
  65. UIBase.onCollectRes = function () {
  66. };
  67. Object.defineProperty(UIBase.prototype, "tag", {
  68. get: function () {
  69. return this.mTag;
  70. },
  71. set: function (value) {
  72. this.mTag = value;
  73. },
  74. enumerable: false,
  75. configurable: true
  76. });
  77. /**
  78. * 得到prefab的路径,相对于resources目录
  79. */
  80. UIBase.getUrl = function () {
  81. return this.prefabUrl;
  82. //return PREFAB_UI_DIR + this.prefabUrl;
  83. };
  84. /**
  85. * 类名,用于给UI命名
  86. */
  87. UIBase.getName = function () {
  88. return this.className;
  89. };
  90. UIBase.getPop = function () {
  91. return this.pop;
  92. };
  93. UIBase.getZindex = function () {
  94. return this._zindex;
  95. };
  96. /* ----------------------------- 以下方法不能在子类重写 ----------------------------- */
  97. /**初始化函数,在onLoad之前被调用,params为打开ui是传入的不定参数数组 */
  98. UIBase.prototype.init = function (params) {
  99. this.onInit(params);
  100. };
  101. /**onLoad 会在组件被首次加载的时候被回调。且优先于任何start */
  102. UIBase.prototype.onLoad = function () {
  103. this._notifyEventList = new Map();
  104. // this._registerEventList = new Map<string, RegisterEvent>();
  105. this.onUILoad();
  106. };
  107. UIBase.prototype.onDestroy = function () {
  108. this.onUIDestroy();
  109. };
  110. UIBase.prototype.onEnable = function () {
  111. // if (this.isRegisterStopEvent) {
  112. // this.onRegisterEvent(this.node, this.touchEvent, this);
  113. // }
  114. if (this.bgm != TypeConst_1.AudioConst.empty) {
  115. GameDataCenter_1.default.audio.playMusic(this.bgm);
  116. }
  117. this.onShow();
  118. };
  119. UIBase.prototype.onDisable = function () {
  120. if (this.isRegisterStopEvent) {
  121. this.unRegisterEvent(this.node);
  122. }
  123. this.onHide();
  124. try {
  125. var self_1 = this;
  126. this._notifyEventList.forEach(function (f, key) {
  127. // console.log("_notifyEventList key = "+key)
  128. EventMng_1.default.off(key, f, self_1);
  129. }, this);
  130. this._notifyEventList.clear();
  131. }
  132. catch (error) {
  133. console.error("onDisable->" + error);
  134. }
  135. if (this.registerCount > 0) {
  136. console.error(this.name + " 按钮注册后没off掉啊喂 \n(╯-_-)╯╧╧ ");
  137. }
  138. };
  139. /**注册notice事件,disable的时候会自动移除 */
  140. UIBase.prototype.initEvent = function (eventName, cb) {
  141. EventMng_1.default.on(eventName, cb, this);
  142. this._notifyEventList.set(eventName, cb);
  143. };
  144. UIBase.prototype.touchEvent = function (event) {
  145. event.stopPropagation();
  146. };
  147. UIBase.prototype.start = function () {
  148. // this.onStart(); // 改在UiMng中,在init和添加到父节点之后触发
  149. };
  150. UIBase.prototype.update = function (dt) {
  151. this.onUpdate(dt);
  152. };
  153. /* ---------------------------------------------------------------------------------- */
  154. UIBase.prototype.onInit = function (params) {
  155. };
  156. UIBase.prototype.onUILoad = function () {
  157. };
  158. UIBase.prototype.onUIDestroy = function () {
  159. };
  160. UIBase.prototype.onShow = function () {
  161. };
  162. UIBase.prototype.onHide = function () {
  163. };
  164. UIBase.prototype.onStart = function (isFirstTime) {
  165. };
  166. UIBase.prototype.onUpdate = function (dt) {
  167. };
  168. UIBase.prototype.onClose = function () {
  169. };
  170. /**
  171. * 注册touch事件
  172. * @param node
  173. * @param callback
  174. * @param target
  175. * @param playAudio 是否播放音效,默认播放
  176. */
  177. UIBase.prototype.onRegisterEvent = function (node, callback, target, params, audio) {
  178. if (target === void 0) { target = null; }
  179. if (params === void 0) { params = []; }
  180. if (audio === void 0) { audio = TypeConst_1.AudioConst.effect_click; }
  181. this.registerCount++;
  182. UICommon_1.uiCommon.onRegisterEvent(node, callback, target, params, audio);
  183. };
  184. UIBase.prototype.unRegisterEvent = function (node) {
  185. this.registerCount--;
  186. UICommon_1.uiCommon.unRegisterEvent(node);
  187. };
  188. UIBase.pop = BASE_POP.UI;
  189. UIBase = __decorate([
  190. ccclass
  191. ], UIBase);
  192. return UIBase;
  193. }(cc.Component));
  194. exports.default = UIBase;
  195. cc._RF.pop();
  196. }
  197. if (nodeEnv) {
  198. __define(__module.exports, __require, __module);
  199. }
  200. else {
  201. __quick_compile_project__.registerModuleFunc(__filename, function () {
  202. __define(__module.exports, __require, __module);
  203. });
  204. }
  205. })();
  206. //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["assets/script/logic/ui/UIBase.ts"],"names":[],"mappings":"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","file":"","sourceRoot":"/","sourcesContent":["import { AudioConst } from \"../../data/const/TypeConst\";\nimport GameDataCenter from \"../../data/GameDataCenter\";\nimport EventMng from \"../../manager/EventMng\";\nimport { uiCommon } from \"../../utils/UICommon\";\n\nexport interface UIClass<T extends UIBase> {\n    new(): T;\n    getUrl(): string;\n    getName(): string;\n    getPop(): BASE_POP;\n    getZindex(): number;\n    /** 预加载页面所需资源 */\n    onCollectRes(): void;\n}\n// 弹出方式\nexport enum BASE_POP {\n    MAIN = \"MAIN\",//主场景\n    UI = \"UI\",   //除了MAIN以外的其他非弹窗UI\n    UI_HALF = \"UI_HALF\",// 与UI类似,但不展示底部按钮,只显示顶部资源栏\n    FULL = \"FULL\",// 盖住菜单界面的窗口\n    POP = \"POP\", // 弹窗\n    MemuBottom = \"MemuBottom\", // 主界面的底部菜单栏ui\n    Battle = \"Battle\" // 战斗弹窗\n}\n\ninterface RegisterEvent {\n    callback: Function,\n    target?: any,\n    playAudio?: boolean,\n}\n\nconst PREFAB_UI_DIR = 'prefab/';\n\nconst { ccclass, property } = cc._decorator;\n@ccclass\nexport default abstract class UIBase extends cc.Component {\n    protected static prefabUrl;\n    protected static className;\n\n    static onCollectRes() {\n\n    }\n    protected mTag: any;\n    public get tag(): any {\n        return this.mTag;\n    }\n    public set tag(value: any) {\n        this.mTag = value;\n    }\n\n    /**\n     * 得到prefab的路径，相对于resources目录\n     */\n    public static getUrl(): string {\n        return this.prefabUrl;\n        //return PREFAB_UI_DIR + this.prefabUrl;\n    }\n\n    /**\n     * 类名，用于给UI命名\n     */\n    public static getName(): string {\n        return this.className;\n    }\n\n    protected static pop: BASE_POP = BASE_POP.UI\n    public static getPop(): BASE_POP {\n        return this.pop\n    }\n    protected static _zindex: number\n    public static getZindex(): number {\n        return this._zindex\n    }\n\n    public belong: any = null\n\n    public showAnim: boolean = true\n    public bgm: AudioConst = AudioConst.empty\n\n    /** 是否注册防穿透事件 */\n    protected isRegisterStopEvent: boolean = true;\n\n    /**通知事件列表 */\n    private _notifyEventList: Map<string, Function>;\n    /**点击事件列表 */\n    private _registerEventList: Map<string, RegisterEvent>;\n\n    /* ----------------------------- 以下方法不能在子类重写 ----------------------------- */\n    /**初始化函数，在onLoad之前被调用，params为打开ui是传入的不定参数数组 */\n    init(params) {\n        this.onInit(params);\n    }\n\n    /**onLoad 会在组件被首次加载的时候被回调。且优先于任何start */\n    onLoad() {\n        this._notifyEventList = new Map<string, Function>();\n        // this._registerEventList = new Map<string, RegisterEvent>();\n\n        this.onUILoad();\n    }\n\n    onDestroy() {\n        this.onUIDestroy();\n    }\n\n    onEnable() {\n        // if (this.isRegisterStopEvent) {\n        //     this.onRegisterEvent(this.node, this.touchEvent, this);\n        // }\n        if (this.bgm != AudioConst.empty) {\n            GameDataCenter.audio.playMusic(this.bgm)\n        }\n        this.onShow();\n    }\n\n    onDisable() {\n        if (this.isRegisterStopEvent) {\n            this.unRegisterEvent(this.node);\n        }\n\n        this.onHide();\n        try {\n            let self = this;\n            this._notifyEventList.forEach((f, key) => {\n                // console.log(\"_notifyEventList key = \"+key)\n                EventMng.off(key, f, self);\n            }, this);\n            this._notifyEventList.clear();\n        } catch (error) {\n            console.error(\"onDisable->\" + error)\n        }\n\n        if (this.registerCount > 0) {\n            console.error(this.name + \" 按钮注册后没off掉啊喂 \\n（╯－＿－）╯╧╧ \")\n        }\n    }\n\n    /**注册notice事件，disable的时候会自动移除 */\n    initEvent(eventName: string, cb: Function) {\n        EventMng.on(eventName, cb, this);\n        this._notifyEventList.set(eventName, cb);\n    }\n\n    private touchEvent(event) {\n        event.stopPropagation();\n    }\n\n    start() {\n        // this.onStart(); // 改在UiMng中,在init和添加到父节点之后触发\n    }\n\n    update(dt) {\n        this.onUpdate(dt);\n    }\n    /* ---------------------------------------------------------------------------------- */\n\n\n    onInit(params) {\n\n    }\n\n    onUILoad() {\n\n    }\n\n    onUIDestroy() {\n\n    }\n\n    onShow() {\n\n    }\n\n    onHide() {\n\n    }\n\n    onStart(isFirstTime: boolean) {\n\n    }\n\n    onUpdate(dt: number) {\n\n    }\n\n    onClose() {\n\n    }\n\n    registerCount: number = 0\n    /**\n     * 注册touch事件\n     * @param node \n     * @param callback \n     * @param target \n     * @param playAudio 是否播放音效，默认播放\n     */\n    onRegisterEvent(node: cc.Node, callback, target = null, params: any = [], audio: AudioConst = AudioConst.effect_click) {\n        this.registerCount++\n        uiCommon.onRegisterEvent(node, callback, target, params, audio)\n    }\n\n    unRegisterEvent(node: cc.Node) {\n        this.registerCount--\n        uiCommon.unRegisterEvent(node)\n    }\n}"]}