Cocos Creator中使用事件中心

Cocos Creator中使用事件中心,第1张

概述export class EventCenter { /** 监听数组 */ private listeners = {}; /** * 注册事件 * @param name 事件名称 * @param callback 回调函数 * @param context 上下文 */ public register(name: string, callback: Function, context: a

export class EventCenter {
/** 监听数组 */
private Listeners = {};

/**
* 注册事件
* @param name 事件名称
* @param callback 回调函数
* @param context 上下文
*/
public register(name: string,callback: Function,context: any) {
let observers: Observer[] = this.Listeners[name];
if (!observers) {
this.Listeners[name] = [];
}
this.Listeners[name].push(new Observer(callback,context));
}

/**
* 移除事件
* @param name 事件名称
* @param callback 回调函数
* @param context 上下文
*/
public remove(name: string,context: any) {
let observers: Observer[] = this.Listeners[name];
if (!observers) return;
let length = observers.length;
for (let i = 0; i < length; i++) {
let observer = observers[i];
if (observer.compar(context)) {
observers.splice(i,1);
break;
}
}
if (observers.length == 0) {
delete this.Listeners[name];
}
}

/**
* 发送事件
* @param name 事件名称
*/
public fire(name: string,...args: any[]) {
let observers: Observer[] = this.Listeners[name];
if (!observers) return;
let length = observers.length;
for (let i = 0; i < length; i++) {
let observer = observers[i];
observer.notify(name,...args);
}
}
}

 

 

 

 

/**
* 观察者
*/
export class Observer {
/** 回调函数 */
private callback: Function = null;
/** 上下文 */
private context: any = null;

constructor(callback: Function,context: any) {
let self = this;
self.callback = callback;
self.context = context;
}

/**
* 发送通知
* @param args 不定参数
*/
notify(...args: any[]): voID {
let self = this;
self.callback.call(self.context,...args);
}

/** * 上下文比较 * @param context 上下文 */ compar(context: any): boolean { return context == this.context; }}

总结

以上是内存溢出为你收集整理的Cocos Creator中使用事件中心全部内容,希望文章能够帮你解决Cocos Creator中使用事件中心所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://www.outofmemory.cn/web/999972.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-21
下一篇 2022-05-21

发表评论

登录后才能评论

评论列表(0条)

保存