设计模式在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)细分成了纽约地区的和芝加哥地区的(每种地区都能生 ...
随机推荐
- sqlldr load UTF8 error
The default length semantics for all datafiles (except UFT-16) is byte. So in your case you have a C ...
- Xamarin XAML语言教程模板页面TemplatedPage
Xamarin XAML语言教程模板页面TemplatedPage 模板页面TemplatedPage 在上文中我们提到了TemplatedPage,它被称为模板页面,用来显示控件模版.Templat ...
- 调用sort段错误问题
问题:sort的比较函数实现有问题导致进程调用sort时core了. 结论:特别要注意,sort的比较函数必须遵循严格弱排序(strict weak ordering)的规则. 这是最近在工作中遇 ...
- [ARC103F]Distance Sums
题意:有一棵树,对于每个点$i$,给出了它到其他点的距离和$i$,现在要还原这棵树,保证$d_i$两两不同 一个点从$u$移到相邻节点$v$时,若删掉$(u,v)$后$u$这边的连通块大小为$siz_ ...
- 【后缀自动机】【拓扑排序】【动态规划】hihocoder1457 后缀自动机四·重复旋律7
解题方法提示 小Hi:我们已经学习了后缀自动机,今天我们再来看这道有意思的题. 小Ho:好!这道题目让我们求的是若干的数字串所有不同子串的和. 小Hi:你能不能结合后缀自动机的性质来思考如何解决本题? ...
- Navicat无法连接到MySQL
今天新装的linux,装好以后想用Navicat连接一下数据库,发现连接不上 思路,捋一下 第一种:Access denied for user 'root'@'localhost' (using p ...
- TCP协议中的重传、慢启动、SACK、窗口的概念
重传机制 慢启动相关的几个状态说明该 SACK机制 窗口在TCP传输机制中的作用
- 【maven】ecplise新建maven项目 报错Could not calculate build plan: Plugin org.apache.maven.plugins:maven-resources-plugin
在ecplise上新建maven项目 报错: Could not calculate build plan: Plugin org.apache.maven.plugins:maven-resourc ...
- 如何解决weblogic server启动中在IIOP后运行缓慢
WebLogic Server在Linux环境中,有时因为linux OS的安全包没有安装,导致weblogic server 在启动的时候会在长时间的停留在 <2/07/2009 08:54: ...
- julia应用于自动驾驶汽车、机器人、3D 打印、精准医疗、增强现实、基因组学、能源交易、机器学习、金融风控和太空任务设计等多个领域
编程界的新宠 Julia 发布 1.0 正式版本,多种优势集于一身2018-08-14 14:14 公司Julia 的累积下载次数超过 200 万,已被应用于自动驾驶汽车.机器人.3D 打印.精准医疗 ...