MVC 模式的全称是 Model-View-Controller,即模型-视图-控制器。严格来说,MVC并不是GoF(四人帮)归纳出的一种独立设计模式,而是组合模式(UI界面的构建)、策略模式(VC之间的一对多关系)和观察者模式(MV间的事件触发)的组合。
这种设计模型通常用于用户图形界面的图形/数据/逻辑分离(是不是感觉在某些方面很像 ECS?),因此在游戏领域中常被用于 UI 相关的功能上。那么,什么是 M / V / C 呢?
- M(模型)
模型层(M 层)负责存放数据,类似于 ECS 中的 C(组件)。 - V(视图)
视图层(V 层)负责展示用户图形界面,类似于 ECS 中的 E(实体),是用户与之直接交互的元素。 - C(控制器)
控制层(C 层)负责处理数据逻辑,类似于 ECS 中的 S(系统),包含了所有数据计算的部分,负责更新M层的数据。
使用 MVC 模式的目的是将 M 和 V 的实现代码分离,从而使同一个程序可以使用不同的表现形式。比如一批统计数据可以分别用柱状图、饼图来表示。C 存在的目的则是确保 M 和 V 的同步,一旦 M 改变,V 应该同步更新。
Unity中的MVC
以上述框架为例,假设我们要做一个点击按钮更新金币数量(即点击一次金币数 +1 )和清空当前金币的功能:
M
M 层存放所有数据,包括静态数据、变量、资源(如贴图、游戏对象等)等。在这个例子中,M 层中只有金币数量的数据。
1 | class CoinModel : Monobehavior{ |
V
V 层负责为拿取所有 UI 组件对象,并为它们声明相关的事件:
1 | class CoinView : Monobehavior{ |
C
C 层负责业务逻辑相关功能(在本例中为“金币 +1 ”和“清空金币”两大功能)的实现,获取Model的数据,通知View层更新数据。
1 | public class CoinController{ |
实际上,MVC不仅可以用于UI系统(只是在大部分情况下,它天然地适合于此),也可以拓展引用到其他模块上,例如这个仓库所展示的玩家系统。
参考资料
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 几/何/冰/川!
评论