设计模式在游戏中的应用--观察者模式(十)

观察者模式看似很陌生,其实可以说观察者模式是游戏中使用最多的一种模式,甚至比单例模式还要使用频繁,而且想要写好游戏的代码必须了解游戏中的那些地方使用了观察者模式,每个观察者的订阅者是谁。

大多数MMORPG游戏主体就是一个while循环,通过这些while循环来更新订阅者,从而来更新观察者。例如我们有个玩家的订阅者,每个玩家就是一个观察者,我只需要更新订阅者来更新每个观察者。我们每个玩家身上有很多的buff,我们玩家就是订阅者,每个buff就是观察者,这样玩家获得更新的时候,我们身上的每个buff都可以获得更新。

我们来了解下观察者模式,观察者模式(有时又被称为发布-订阅Subscribe>模式、模型-视图View>模式、源-收听者Listener>模式或从属者模式)是软件设计模式的一种。在此种模式中,一个目标物件管理所有相依于它的观察者物件,并且在它本身的状态改变时主动发出通知。这通常透过呼叫各观察者所提供的方法来实现。

下图是观察者模式的流程图:

代码如下:

// MVC.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"
#include <iostream>
#include <string>
#include <sstream>
#include <list>
using namespace std;
class Subject;
class Observer;

class Observer
{
public:
    ~Observer(){};
    virtual void Update() = 0;
};

class Buff:public Observer
{
public:
    Buff(Subject* host, int id):m_host(host),m_id(id)
    {

    }
    virtual void Update()
    {
        cout<<m_id<<" Buff Update"<<endl;
    }
    Subject* m_host;
    int      m_id;
};

class Subject
{
public:
    ~Subject(){};

    void Attach(Observer* value )
    {
        observerList.push_back(value);
    }

    void Detach(Observer* value)
    {
        observerList.remove(value);
    }

    void Notify()
    {
        for( list<Observer*>::iterator iter =  observerList.begin(); iter != observerList.end(); ++iter )
        {
            (*iter)->Update();
        }
    }
    list<Observer*> observerList;
};

void main()
{
    auto_ptr<Subject> subject(new Subject());
    auto_ptr<Buff> buff_one(new Buff(subject.get(),1));
    auto_ptr<Buff> buff_two(new Buff(subject.get(),2));

    subject->Attach(buff_one.get());
    subject->Attach(buff_two.get());
    subject->Notify();
}

结果如下:

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-10-05 22:18:47

设计模式在游戏中的应用--观察者模式(十)的相关文章

设计模式在游戏中的应用--建造者模式(九)

建造者模式(Builder Pattern):将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示.建造者模式是一种对象创建型模式.通过这个定义,我们可以得出建造者是一种创建型模式,也就是说建造者模式的输出是一个对象,也就是UML类图中的product. 我们先看看建造者模式的UML类图: UML类图中我们可以看出,建造者模式使用了聚合.继承和依赖三种关系.第一个疑问就是为什么要使用聚合,如果我们不使用聚合的话,我们始终得到的都是稳定的构建过程,例如我们游戏中每个NPC都有2

设计模式在游戏中的应用--模板方法(七)

模板方法这个名字看着很陌生,其实在游戏中大量地使用了模板方法,因为游戏中存在玩家.NPC和静态物体等不同的对象,使用多态特性能很好地进行区分. 模板方法的定义是:模板方法模式:在一个方法中定义一个算法的骨架,而将一些步骤延迟到子类中.模板方法使得子类可以在不改变算法结构的情况下,重新定义算法中的某些步骤. 举个最简单的玩家和NPC死亡时的逻辑: 流程图如下: 代码如下 // MVC.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include

设计模式在游戏中的应用--外观模式(八)

外观模式(Facade),为子系统中的一组接口提供一个一致的界面,定义一个高层接口,这个接口使得这一子系统更加容易使用.外观模式相当于KFC里面的套餐,大多数人去FKC吃中饭,本质其实就是为了填饱肚子,消费者需要主食.饮料和小吃,有了各种套餐之后,消费者去KFC可以选择各种套餐就能满足自己的需要,不至于由于自己不会点餐都点主食而造成口渴和难以下咽的情况.套餐可以满足大多数人的需求. MMORPG游戏中也有着一些外观模式的应用,例如游戏中一种套餐可以让玩家升级到满级,学习和装备了最高的技能和装备.

设计模式在游戏中的应用--原型模式(六)

Prototype原型模式是一种创建型设计模式,Prototype模式允许一个对象再创建另外一个可定制的对象,根本无需知道任何如何创建的细节,工作原理是:通过将一个原型对象传给那个要发动创建的对象,这个要发动创建的对象通过请求原型对象拷贝它们自己来实施创建. 上面是原型模式的UML结构图. 下面是原型模式的代码: #include "stdafx.h" #include <iostream> #include <string> using namespace s

游戏中的设计模式(1)--观察者模式

作为本系列文章的第一篇,笔者在此想表达一下个人对于设计模式的一些理解.因此笔者自问自答几个问题.1,什么是设计模式?2,在软件快速迭代的今天,设计模式是否重要?3,四人帮提出了23个设计模式,是不是设计问题无出其右?4,设计模式和语言是什么关系?5,设计模式和面向对象的关系? 1,什么是设计模式? 拿百度谷歌一下,可以找到各种各样的回答,只是很多的回答实在是会让人找不到北,模式这个词确实很高大上,因此常常出没于学术界.针对设计模式这个问题,笔者对设计模式的理解是,设计模式可以认为是解决某一类问题

ActionScript3游戏中的图像编程(连载二十)

1.4.2 灰度的计算方法 回过头来看RGB,站在科学的角度来解释,它们确实也有更明亮的理由,因为下面一排色彩反射出来的色光总量是上一排色的两倍.      为此,作者曾自作聪明地发明了一条“原创”的灰度公式: Gray=(r+g+b)/3 哈哈,用色光总量来表达颜色的灰度想必就比较准确了吧!沾沾自喜一番以后,我还试着用这条自创的定律来转换这张测试图片,上下色块的灰度果然拉开了,可是很不幸地,左右相邻,边界分明的色块依然粘连在一块(图 1.30). 图 1.30 笔者“自创”的灰度转换 显然此法

ActionScript3游戏中的图像编程(连载十九)

1.4 浅析亮度与灰度/明度的关系 进入正题之前,先来了解一下灰度/明度. 1.4.1 灰度/明度的概念及其与HSB亮度的异同 在很多场合,灰度与明度的概念完全等价. “灰度”最初来源于摄影领域,在彩色显像技术问世以前,拍摄出来的照片只有黑,白,灰三类颜色,在这种黑白照片里,只有白色.黑色以及灰色的点能完好无损地显示出来,其它颜色将根据其亮度呈现出不同深度的灰色.亮度越大灰色越浅,反之越深.把黑与白色之间分成若干级,称为“灰度等级”.能呈现的灰度等级愈多,画面的层次感就愈丰富. 所以,从彩色转黑

[原创]ActionScript3游戏中的图像编程(连载三十二)

2.2.5 投影距离的模拟 Photoshop投影样式面板的下一个属性是距离,它也存在于Flash的投影滤镜选项中.两者初始值一致,经笔者测试,两者在效果实现和数值意义方面基本一致.Flash不需要对默认参数进行更改. 下一项是扩展,乍一看,在Flash中并没有找到对应项.但仔细观察,在Photoshop投影样式的基础选项里,除了alpha以外,就只剩该属性用了百分比. [原创]ActionScript3游戏中的图像编程(连载三十二),布布扣,bubuko.com

[原创]ActionScript3游戏中的图像编程(连载二十九)

2.2.2 Photoshop投影大小的模拟 投影没有之前那么浓了,但是跟Photoshop里的效果差别还挺大,因为在Photoshop里我们还设置了另外一个属性:大小. Flash里似乎找不到它的影子,我们用排除法来进行定位,Photoshop投影样式的大小属性以像素为单位,Flash投影滤镜的选项只有距离和那对被“手铐”扣住的模糊属性符合条件,而Photoshop里也有一个距离,所以我们定位到模糊属性(图 2.15). 图 2.15 Flash投影的模糊属性 分别调整Photoshop的大小