Cocos2d 游戏状态机
加cocos2d 是标题党。
事实上跟cocos2d无关。
1.游戏背景介绍
比方有这么一个"记忆"类的比赛游戏。你和电脑对战。轮到谁的回合,谁翻两张牌。假设两张牌一样,就消掉这两张牌,得2分,能够继续翻牌。假设两张牌不一样,就换一个人。
直到最后,看谁的得分高。
先把图画出来会清晰些:
2.先看下不好的设计方式
我们来设计游戏大致架构。用一个圈表示一个状态。
typedef enum{
WaitingPlayer,
CheckPlayer,
AIThink,
AIFirstCard,
AISecondCard,
CheckAI
}MatchGameState;
准备一个_state的变量来记录当前的状态,然后放到update函数里,运行以下的伪代码。
void MatchLayer::update(float dt){
if(allCards.size() == 0){
_state = GameOver;
} switch(_state){
case WaitingPlayer:
if(cardCount == 2){
_state = CheckPlayer;
cardCount = 0;
}
break;
case CheckPlayer:
if(playerCard1 == playerCard2){
玩家得分
_state = WaitingPlayer;
}else{
_state = AIThink;
把玩家点开的卡增加到记忆数组中
}
break;
case AIThink:
从记忆的数组中找两张同样的,找不到就随机准备两种卡
_state = AIFirstCard;
break;
case AIFirstCard:
点开第一张卡
假设之前没找到同样卡。把这卡增加到记忆数组
_state = AISecondCard;
break;
case AISecondCard:
从记忆的数组中找两张同样的:
假设找到跟第一张一样,就点开它,找不到就点刚開始的随机第2张,而且把第2张增加到记忆数组中。 _state = CheckAI;
break;
case CheckAI:
if(AICard1 == AICard2){
_state = AIThink;
电脑得分
}else{
_state = WaitingPlayer;
}
}
}
这样写是能够,可是随着代码行数增加和业务逻辑变得复杂,兴许会比較难维护。
3.使用"设计模式"来重构
我们来看下怎样重构,使用"设计模式"来重构它。我盗了一张图来说明。
不知道这方法是设计模式中的哪种。
我们打算把全部的状态都用一个类来实现,它们都继承一个基类叫MatchState,它很easy。
有一个类来管理全部的状态。
MatchState例如以下:
#ifndef _MATCHSTATE_
#define _MATCHSTATE_ class MatchState{
public:
virtual void Update() = 0; }; #endif
我这里就没加OnEnter和OnExit了。简单起见。
为了简单些。就把Layer作为状态管理类,在Layer中增加一个属性,来表示当前状态:
MatchState* currentState;
在基本的Layer中增加一个方法来切换当前状态:
void changeState(MatchState* state){
delete currentState;
currentState = state;
}
在update中就简单了,一直运行当前状态的Update方法:
void MatchLayer::update(float dt){
if(allCards.size() == 0){
_state = GameOver;
}
currentState->Update();
}
每一个状态的详细业务逻辑都写在自己的类中。
比方WaitingPlayerState类:
#ifndef _WAITINGPLAYERSTATE_H
#define _WAITINGPLAYERSTATE_H #include "MatchState.h" class WaitingPlayerState : public MatchState{
public:
WaitingPlayerState(){
}
void Update(){
if(sGlobal->cardCount == 2){
sGlobal->matchLayer->changeState(new CheckPlayerCardsState());
}
}
}; #endif
这里sGlobal是一个单例。
再比方CheckPlayerCardsState:
#ifndef _CHECKPLAYERCARDSSTATE_H
#define _CHECKPLAYERCARDSSTATE_H #include "MatchState.h" class CheckPlayerCardsState : public MatchState
{
public:
void Update(){
//很复杂的详细业务逻辑写在这里
if(playerCard1 == playerCard2){
玩家得分
sGlobal->matchLayer->changeState(new WaitingPlayerState ());
}else{
sGlobal->matchLayer->changeState(new AIThinkState ());
把玩家点开的卡增加到记忆数组中
} } }; #endif
其它状态类就不写出来了,总之通过这样把一个状态用一个类来表示,大大的使代码简洁些,扩展性强些。
Cocos2d 游戏状态机的更多相关文章
- cocos2d 游戏开发实战
文章转自:http://uliweb.clkg.org/tutorial/read/40 6 cocos2d 游戏开发实战 6.1 创建cocos2d项目 6.2 cocos2d v3 & ...
- 如何在Cocos2D游戏中实现A*寻路算法(六)
大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请告诉我,如果觉得不错请多多支持点赞.谢谢! hopy ;) 免责申明:本博客提供的所有翻译文章原稿均来自互联网,仅供学习交流 ...
- 如何在Cocos2D游戏中实现A*寻路算法(一)
大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请告诉我,如果觉得不错请多多支持点赞.谢谢! hopy ;) 免责申明:本博客提供的所有翻译文章原稿均来自互联网,仅供学习交流 ...
- cocos2d游戏jsc文件格式解密,SpideMonkey大冒险
“ 介绍cocos2d游戏中常用的jsc格式文件的解密.” 01 — 在破解游戏应用中,经常会碰到后缀为jsc的文件,这是基于cocos2d开发的游戏的加密代码,本质上是js文件,只是被加密了. 例如 ...
- iOS cocos2d游戏引擎的了解之一
ios游戏引擎之Cocos2d(一) cocos2d是一个免费开源的ios游戏开发引擎,并且完全采用object-c进行编写,这对于已经用惯object-c进行ios应用开发的童鞋来说非常容易上手.这 ...
- 《黑马程序猿》 cocos2d游戏引擎复习笔记一
/** ----------------------------游戏场景的搭建-------------------------------- 1首先创建一个surfaceview ,它能够在子线程中 ...
- 如何在Cocos2D游戏中实现A*寻路算法(八)
大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请告诉我,如果觉得不错请多多支持点赞.谢谢! hopy ;) 免责申明:本博客提供的所有翻译文章原稿均来自互联网,仅供学习交流 ...
- 如何在Cocos2D游戏中实现A*寻路算法(四)
大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请告诉我,如果觉得不错请多多支持点赞.谢谢! hopy ;) 免责申明:本博客提供的所有翻译文章原稿均来自互联网,仅供学习交流 ...
- 如何在Cocos2D游戏中实现A*寻路算法(二)
大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请告诉我,如果觉得不错请多多支持点赞.谢谢! hopy ;) 免责申明:本博客提供的所有翻译文章原稿均来自互联网,仅供学习交流 ...
随机推荐
- 多线程模式之Master-Worker
一. 介绍 需要使用Master-Worker的场景:主线程开了多个子进程(Worker进程)去执行任务时,主线程希望能收集到每个子进程的执行结果. 所以,Master-Worker模式基本上就是: ...
- HDU4596 Yet another end of the world 扩展欧几里德性质
这题坑了,我真该吃翔啊,竟然一開始方程设错了并且没有去想连列的问题,我真是坑货,做不出就该又一次理一下嘛.操蛋. 题意:给了N组x,y,z然后 问你是否存在两个或者两个以上的id,是的 id%x的值在 ...
- android-开发环境相关概念
Android中IDE.ADT.SDK.JDK.NDK的解释 1. IDE: Intelligent Development Environm的简称.即智能开发环境.是一种开发工具.常用的IDE有ad ...
- .Net强类型视图
1.控制器 Controllers/StoreController.cs using System; using System.Collections.Generic; using System.Li ...
- 2.Brackets安装及常用插件安装
转自:https://blog.csdn.net/autumn20080101/article/details/53171326 Brackets 是一个免费.开源且跨平台的 HTML/CSS/Jav ...
- hadoop集群环境配置成功与否查看方法
1.Hadoop启动jobhistoryserver来实现web查看作业的历史运行情况,由于在启动hdfs和Yarn进程之后,jobhistoryserver进程并没有启动,需要手动启动jobhist ...
- ElasticSearch概述和定义
福利 => 每天都推送 欢迎大家,关注微信扫码并加入我的4个微信公众号: 大数据躺过的坑 Java从入门到架构师 人工智能躺过的坑 Java全栈大联盟 ...
- 网络最大流算法—Dinic算法及优化
前置知识 网络最大流入门 前言 Dinic在信息学奥赛中是一种最常用的求网络最大流的算法. 它凭借着思路直观,代码难度小,性能优越等优势,深受广大oier青睐 思想 $Dinic$算法属于增广路算法. ...
- 如何解决Linux下的软件包依赖问题
650) this.width=650;" border="0" alt="" src="http://img1.51cto.com/att ...
- 在gridview里查找模板里的button控件
这个问题,真是搞了我1天,这次记住他 第一种方法: protected void GridView1_RowCommand(object sender, GridViewCommandEventArg ...