04.事件中心模块

一、事件中心模块的作用:

降低程序耦合性,减小程序复杂度。

二、什么是观察者设计模式

观察者设计模式(Observer Design Pattern)是一种行为型设计模式,它定义了对象之间的一对多依赖关系:当一个对象(被观察者)的状态发生变化时,所有依赖它的对象(观察者)会自动收到通知并更新。

这种模式的核心思想是解耦被观察者和观察者,让它们可以独立变化,同时保持联动。

三、简单的事件中心模块代码

cs 复制代码
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.Events;
/// <summary>
/// 事件中心 单例模式对象
/// </summary>
public class EventCenter : BaseManager<EventCenter>
{
    private Dictionary<string, UnityAction<object>> eventDic = new Dictionary<string, UnityAction<object>>();
    //key :事件的名字
    //value: 监听这个事件的对应的委托函数们

    /// <summary>
    /// 添加事件监听
    /// </summary>
    /// <param name="name">事件的名字</param>
    /// <param name="action">准备用来处理事件的委托函数</param>
    public void AddEventLisner(string name,UnityAction<object> action)
    {
        if(eventDic.ContainsKey (name))
        {
            eventDic[name] += action;//委托的基本用法
        }
        else
        {
            eventDic.Add(name, action);
        }
    }
    /// <summary>
    /// 移除对应的事件监听,若监听事件的对象被销毁而没有移除事件监听
    /// 会导致内存泄露(无法触发垃圾回收)
    /// </summary>
    /// <param name="name">事件的名字</param>
    /// <param name="action">对应之前添加的委托函数</param>
    public void RemovaEventLisner(string name,UnityAction<object> action)//在 OnDestroy()生命周期函数中调用
    {
        if(eventDic.ContainsKey (name))
        {
            eventDic[name] -= action;
        }
    }

    /// <summary>
    /// 事件触发
    /// </summary>
    /// <param name="name">哪个事件触发了(名字)</param>
    public void EventTrigger(string name,object info)
    {
        if(eventDic.ContainsKey (name))
        {
            //eventDic[name]();//另一种写法
            eventDic[name].Invoke(info);//执行这个委托监听的所有委托函数
        }
    }

    /// <summary>
    /// 清空事件中心,主要用在场景切换时
    /// 防止有监听函数没有被移除
    /// </summary>
    public void Clear()
    {
        eventDic.Clear();
    }
}
相关推荐
GIS之路1 小时前
ArcGIS Pro 中的 notebook 初识
前端
JavaGuide1 小时前
7 道 RAG 基础概念知识点/面试题总结
前端·后端
ssshooter2 小时前
看完就懂 useSyncExternalStore
前端·javascript·react.js
格砸2 小时前
从入门到辞职|从ChatGPT到OpenClaw,跟上智能时代的进化
前端·人工智能·后端
Live000003 小时前
在鸿蒙中使用 Repeat 渲染嵌套列表,修改内层列表的一个元素,页面不会更新
前端·javascript·react native
柳杉3 小时前
使用Ai从零开发智慧水利态势感知大屏(开源)
前端·javascript·数据可视化
兆子龙3 小时前
从高阶函数到 Hooks:React 如何减轻开发者的心智负担(含 Demo + ahooks 推荐)
前端
狗胜3 小时前
测试文章 - API抓取
前端
三小河3 小时前
VS Code 集成 claude-code 教程:告别海外限制,无缝对接国内大模型
前端·程序员