设计模式在cocos2d-x中的使用--简单工厂模式(Simple Factory)
什么是简单工厂模式?
从设计模式的类型上来说,简单工厂模式是属于创建型模式,又叫做静态工厂方法(Static Factory Method)模式。通过专门定义一个类来负责创建其它类的实例,被创建的实例通常都具有共同的父类。
简单工厂模式在cocos2d-x中怎么用,我们通过以下的小样例来了解一下。
假如我们在开发一款类似魔兽的RPG游戏,在游戏中会出现非常多种族的角色。如:人族、兽族。
这些种族一般都会定义为一个类,假设兽族Orc类,人族Human类。
兽族、人族两个类都相同属于种族。那么我们能够给他们定义一个共同的父类, 名字叫种族Race类。
既然是种族,肯定有种族的名字,还有长什么样子。我们想把名字和样子显示在屏幕上显示出来,那么我们在父类Race中定义两个属性,一个名字name。 一个形象features。
//
// Race.h
// DesignPattern_Factory
//
// Created by cc on 14-6-28.
//
// #ifndef __DesignPattern_Factory__Race__
#define __DesignPattern_Factory__Race__ using namespace std; #include "cocos2d.h"
#include "IRaceConst.h"
#include <string> class Race : public cocos2d::CCSprite { protected: //种族名字
std::string m_name; //种族形象(用图片表示)
std::string m_features; public: #pragma mark <getters && setter>
//
// std::string Name() const { return m_name; }
// void Name(std::string val) { m_name = val; }
//
// std::string Features() const { return m_features; }
// void Features(std::string val) { m_features = val; } #pragma mark <构造 && 析构> /**
* @brief 构造
*
*/
Race(); /**
* @brief 析构
*
*/
virtual ~Race(); }; #endif /* defined(__DesignPattern_Factory__Race__) */
父类“种族类”写好了,我们就能够实现人族。兽族和亡灵族三个子类了。
兽族类:
//
// Orc.h
// DesignPattern_Factory
//
// Created by cc on 14-6-28.
//
// #ifndef __DesignPattern_Factory__Orc__
#define __DesignPattern_Factory__Orc__ #include "Race.h" class Orc : public Race { public: #pragma mark <构造 && 析构> /**
* @brief 构造
*
*/
Orc(); /**
* @brief 析构
*
*/
virtual ~Orc(); #pragma mark <创建 && 初始化> /**
* @brief 创建兽族
*
* @return 兽族
*/
static Orc* create(); /**
* @brief 初始化兽族
*
* @return true: 初始化成功 false: 初始化失败
*/
bool init(); }; #endif /* defined(__DesignPattern_Factory__Orc__) */
<pre name="code" class="cpp">//
// Orc.cpp
// DesignPattern_Factory
//
// Created by cc on 14-6-28.
//
// #include "Orc.h" #pragma mark <构造 && 析构> /**
* @brief 构造
*
*/
Orc::~Orc() { } /**
* @brief 析构
*
*/
Orc::Orc() { } #pragma mark <创建 && 初始化> /**
* @brief 创建兽族
*
* @return 兽族
*/
Orc* Orc::create() { Orc *pRet = new Orc();
if (pRet && pRet->init()) {
pRet->autorelease();
return pRet;
} CC_SAFE_DELETE(pRet);
return NULL; } /**
* @brief 初始化兽族
*
* @return true: 初始化成功 false: 初始化失败
*/
bool Orc::init(){ this->m_features = "orc.png";
this->m_name = "兽族"; if (initWithFile(this->m_features.c_str())) { CCLabelTTF* pLabName = CCLabelTTF::create(this->m_name.c_str(), "Marker Felt", 22.0f);
pLabName->setPosition(ccp(this->getContentSize().width / 2, this->getContentSize().height + 30.0f));
this->addChild(pLabName, 1); return true;
} return false;
}
人族类:
//
// Human.h
// DesignPattern_Factory
//
// Created by cc on 14-6-28.
//
// #ifndef __DesignPattern_Factory__Human__
#define __DesignPattern_Factory__Human__ #include "Race.h" USING_NS_CC; class Human : public Race { public: #pragma mark <构造 && 析构> /**
* @brief 构造
*
*/
Human(); /**
* @brief 析构
*
*/
virtual ~Human(); #pragma mark <创建 && 初始化> /**
* @brief 创建人族
*
* @return 人族
*/
static Human* create(); /**
* @brief 初始化人族
*
* @return true: 初始化成功 false: 初始化失败
*/
bool init(); }; #endif /* defined(__DesignPattern_Factory__Race__) */
//
// Human.cpp
// DesignPattern_Factory
//
// Created by cc on 14-6-28.
//
// #include "Human.h" #pragma mark <构造 && 析构> /**
* @brief 构造
*
*/
Human::~Human() { } /**
* @brief 析构
*
*/
Human::Human(){ } #pragma mark <创建 && 初始化> /**
* @brief 创建人族
*
* @return 人族
*/
Human* Human::create() { Human *pRet = new Human();
if (pRet && pRet->init()) {
pRet->autorelease();
return pRet;
} CC_SAFE_DELETE(pRet);
return NULL; } /**
* @brief 初始化人族
*
* @return true: 初始化成功 false: 初始化失败
*/
bool Human::init(){ this->m_name = "人族";
this->m_features = "hum.png"; if (initWithFile(this->m_features.c_str())) { CCLabelTTF* pLabName = CCLabelTTF::create(this->m_name.c_str(), "Marker Felt", 22.0f);
pLabName->setPosition(ccp(this->getContentSize().width / 2, this->getContentSize().height + 30.0f));
this->addChild(pLabName, 1); return true;
} return false;
}
好了~~~ 兽族和人类两个类写完了。我们想要在兽族和人族这两个子类中分别显示出自己种族的名字。和图片,既然这两个类都属于种族类,那么我们就能够由Race类来统一的管理和创建这两个类的实例,假如我们想创建人族Human类的对象时,仅仅需告诉Race类,我要创建人族类的对象即可了。这时候Race类就是一个对象的生产工厂,仅仅要是他的子类,都有他来统一创建,是不是非常方便,看一下以下一段代码。
//
// IRaceConst.h
// DesignPattern_Factory
//
// Created by ChengChao on 14-6-28.
//
// #ifndef __DesignPattern_Factory__IRaceConst__
#define __DesignPattern_Factory__IRaceConst__ /**
* @brief 保存种族常量的接口
*/
class IRaceConst { public: //种族类型
enum RaceType {
eRaceTypeNone,
eRaceTypeHuman, //人族
eRaceTypeOrc, //兽人
eRaceTypeUd, //亡灵
eRaceTypeNe //精灵
}; }; #endif /* defined(__DesignPattern_Factory__IRaceConst__) */
/**
* @brief 创建种族
*
* @return 种族
*/
Race* Race::createRaceByType(int aRaceType) { Race* pRace = NULL; switch (aRaceType) {
case IRaceConst::eRaceTypeHuman:
//人族
pRace = Human::create();
break;
case IRaceConst::eRaceTypeOrc:
//兽族
pRace = Orc::create();
break;
case IRaceConst::eRaceTypeUd:
//亡灵族
pRace = Ud::create();
break;
default:
break;
} return pRace;
}
这种方法是Race类的一个静态static 工厂方法,通过传入种族的枚举类型。统一由Race类来创建子类的对象,我们想要一个人族,就传一个人族类型,想要一个兽族,就传一个兽族类型,我们把人族和兽族加入到场景里去,我们来看看执行效果。
HelloWorldScene中:
Race* pHumanRace = Race::createRaceByType(IRaceConst::eRaceTypeHuman);
pHumanRace->setPosition(ccp(100, 100));
this->addChild(pHumanRace, 1); Race* pOrcRace = Race::createRaceByType(IRaceConst::eRaceTypeOrc);
pOrcRace->setPosition(ccp(400, 100));
this->addChild(pOrcRace, 1);
执行效果例如以下:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvb2t0ZWFycw==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">
假设我们如今又有了一个新的需求。加了一个亡灵族呢? 仅仅须要再创建一个亡灵族类继承种族类Race,然后给亡灵类指定一个类型加到保存种族常量的接口IRaceConst里去,再通过静态工厂方法Race::createRaceByType()创建亡灵类的实例来,把亡灵加到场景里即可了。把代码贴出来。大家能够自己试试~
最后附上源代码: http://download.csdn.net/detail/oktears/7568355
本文由CC原创总结。如需转载请注明出处:http://blog.csdn.net/oktears/article/details/35780455
设计模式在cocos2d-x中的使用--简单工厂模式(Simple Factory)的更多相关文章
- 设计模式之简单工厂模式Simple Factory(四创建型)
工厂模式简介. 工厂模式专门负责将大量有共同接口的类实例化 工厂模式可以动态决定将哪一个类实例化,不必事先知道每次要实例化哪一个类. 工厂模式有三种形态: 1.简单工厂模式Simple Factory ...
- 【设计模式】简单工厂模式 Simple Factory Pattern
简单工厂模式Simple Factory Pattern[Simple Factory Pattern]是设计模式里最简单的一个模式,又叫静态工厂模式[Static Factory Pattern], ...
- Golang设计模式—简单工厂模式(Simple Factory Pattern)
Golang设计模式--简单工厂模式 背景 假设我们在做一款小型翻译软件,软件可以将德语.英语.日语都翻译成目标中文,并显示在前端. 思路 我们会有三个具体的语言翻译结构体,或许以后还有更多,但现在分 ...
- 创建型模式(前引)简单工厂模式Simple Factory
一引出的原因(解决下面的问题) 简单工厂模式(Simple Factory Pattern):又称为静态工厂方法(Static Factory Method)模式,它属于类创建型模式. 在简单工厂模式 ...
- 大白话简单工厂模式 (Simple Factory Pattern)
大白话简单工厂模式 (Simple Factory Pattern) 从买车经历说起 毕业两年,码农张小两口无法忍受挤公交,凌晨起床抢火车票的痛苦,遂计划买车.逛了多家4S店,最终定下日产某车型的轿车 ...
- Net设计模式实例之简单工厂模式(Simple Factory Pattern)
一.简单工厂模式简介(Bref Introduction) 简单工厂模式(Simple Factory Pattern)的优点是,工厂类中包含了必要的逻辑判断,根据客户端的选择条件动态实例化相关的类, ...
- C#设计模式-1简单工厂模式Simple Factory)
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace 简单的工 ...
- 设计模式之简单工厂模式(Simple Factory Pattern)
一.简单工厂模式的由来 所有设计模式都是为解决某类问题而产生的,那么简单工厂模式是为解决什么问题呢?我们假设有以下业务场景: 在一个学生选课系统中,文科生用户选课时,我们要获得文科生的所有课程列表:理 ...
- Headfirst设计模式的C++实现——简单工厂模式(Simple Factory)之二
为了引出后续的工厂方法,把在简单工厂模式的基础上增加了新功能——加盟店 简而言之就是把原来的单一简单工厂(能生产cheese和greek两种pizza)细分成了纽约地区的和芝加哥地区的(每种地区都能生 ...
随机推荐
- 04、Unity 5--全局光照技术
本文整理自Unity全球官方网站,原文:UNITY 5 - LIGHTING AND RENDERING 简介全局光照,简称GI,是一个用来模拟光的互动和反弹等复杂行为的算法,要精确的仿真全局光照非常 ...
- JZYZOJ1544 [haoi2016T2]放棋子 错排公式 组合数学 高精度
http://172.20.6.3/Problem_Show.asp?ID=1544&a=ProbNF 看了题解才意识到原题有错排的性质(开始根本不知道错排是什么). 十本不同的书放在书架上. ...
- [2018湖南省队集训] 6.28 T2 color
毒瘤计数题2333,(小声)k其实可以出到1e9,不过这样求组合数的时候就要记1000种数的1~1000次下降幂(用到的组合数中第一维在1e9级别的只有1000种左右,第二维都是<=1000), ...
- 初识Tomcat系统架构
俗话说,站在巨人的肩膀上看世界,一般学习的时候也是先总览一下整体,然后逐个部分个个击破,最后形成思路,了解具体细节,Tomcat的结构很复杂,但是 Tomcat 非常的模块化,找到了 Tomcat最核 ...
- Java高级架构师(一)第39节:Nginx的Rewrite模块
- 从co到koa01-co
thunk 他的发展是由函数的求值策略的分歧决定的,两种求值策略 传值调用,在进入函数体之前就直接执行完,把值传进去 传名调用,将表达式传入函数体,只在用到他的时候求值 传名函数的编译器实现,其实就是 ...
- 5 Best Gantt Chart JIRA Plugins
Andrew Stepanov/June 23, 2017/6 minutes Software developers enjoy using JIRA software for their proj ...
- sso 自动化运维平台
单点登录SSO(Single Sign-On)是身份管理中的一部分.本文中作者开发了一个自动化运维平台中的统一认证接口,单点登录平台通过提供统一的认证平台,实现单点登录.因此,应用系统并不需要开发用户 ...
- android非法字符的判定、表情符号的判定
public class EmojiEditText extends EditText {// 输入表情前的光标位置private int cursorPos; // 输入表情前EditText中的文 ...
- java ArrayList源码分析(转载)
1.ArrayList是一个相对来说比较简单的数据结构,最重要的一点就是它的自动扩容,可以认为就是我们常说的“动态数组”. 来看一段简单的代码: 12345 ArrayList<String&g ...