在编写获取路径方法前,我们先把角色须要的动画文件载入进来,角色的文件为png 和 plist格式。

player1_anim.png.plist             player1_anim.png

player2_anim.png.plist             player2_anim.png

plist分别记录了每张图在整张png图中的位置 大小,我们仅仅要知道每张小图名称就可以从整张png图中截取出想要的小图。

player1_anim.png图片为

player2_anim.png图片为

图片表示方法同样,每四张表示一个方向

我们在GameBaseScene中加入角色:

1、 首先定义addPlayerAnimation()方法。这种方法主要是载入动画文件到内存 并创建角色须要的上下左右四个方向的动画

void GameBaseScene::addPlayerAnimation()
{
//创建player1的帧缓存,并载入player1的动绘图片到缓存
player1_spriteFrameCache = SpriteFrameCache::getInstance();
player1_spriteFrameCache->addSpriteFramesWithFile("map/player1_anim.plist","map/player1_anim.png"); //创建player2的帧缓存,并载入player2的动绘图片到缓存
player2_spriteFrameCache = SpriteFrameCache::getInstance();
player2_spriteFrameCache->addSpriteFramesWithFile("map/player2_anim.plist","map/player2_anim.png"); //创建player1的上下左右四个方向的Vector
Vector<SpriteFrame*> player1_anim_left_vector ;
Vector<SpriteFrame*> player1_anim_right_vector;
Vector<SpriteFrame*> player1_anim_down_vector;
Vector<SpriteFrame*> player1_anim_up_vector; //创建player2的上下左右四个方向的Vector
Vector<SpriteFrame*> player2_anim_left_vector;
Vector<SpriteFrame*> player2_anim_right_vector;
Vector<SpriteFrame*> player2_anim_down_vector;
Vector<SpriteFrame*> player2_anim_up_vector;}
//定义name数组
char name[20];
memset(name, 0, 20); //第1-4张图片是表示向左的动画,把这四张图片从缓存中取出。分别保存到对应角色的vector中
for (int i=1; i<=4; i++)
{
sprintf(name, "player1_anim_%02d.png",i);
player1_anim_left_vector.pushBack(player1_spriteFrameCache->getSpriteFrameByName(name)); sprintf(name, "player2_anim_%02d.png",i);
player2_anim_left_vector.pushBack(player2_spriteFrameCache->getSpriteFrameByName(name));
}
//第5-8张图片是表示向右的动画
for (int i=5; i<=8; i++)
{
sprintf(name, "player1_anim_%02d.png",i);
player1_anim_right_vector.pushBack(player1_spriteFrameCache->getSpriteFrameByName(name)); sprintf(name, "player2_anim_%02d.png",i);
player2_anim_right_vector.pushBack(player2_spriteFrameCache->getSpriteFrameByName(name));
}
//第9-12张图片是表示向下的动画
for (int i=9; i<=12; i++)
{
sprintf(name, "player1_anim_%02d.png",i);
player1_anim_down_vector.pushBack(player1_spriteFrameCache->getSpriteFrameByName(name));
sprintf(name, "player2_anim_%02d.png",i);
player2_anim_down_vector.pushBack(player2_spriteFrameCache->getSpriteFrameByName(name));
}
//第13-16张图片是表示向上的动画
for (int i=13; i<=16; i++)
{
sprintf(name, "player1_anim_%02d.png",i);
player1_anim_up_vector.pushBack(player1_spriteFrameCache->getSpriteFrameByName(name));
sprintf(name, "player2_anim_%02d.png",i);
} <span style="white-space:pre"> </span>//依据角色的上下左右四个vector 创建四个方向的动作
Animation * player1_animation_left = Animation::createWithSpriteFrames(player1_anim_left_vector,0.1f);
Animation * player1_animation_right = Animation::createWithSpriteFrames(player1_anim_right_vector,0.1f);
Animation * player1_animation_down = Animation::createWithSpriteFrames(player1_anim_down_vector,0.1f);
Animation * player1_animation_up = Animation::createWithSpriteFrames(player1_anim_up_vector,0.1f); Animation * player2_animation_left = Animation::createWithSpriteFrames(player2_anim_left_vector,0.1f);
Animation * player2_animation_right = Animation::createWithSpriteFrames(player2_anim_right_vector,0.1f);
Animation * player2_animation_down = Animation::createWithSpriteFrames(player2_anim_down_vector,0.1f);
Animation * player2_animation_up = Animation::createWithSpriteFrames(player2_anim_up_vector,0.1f); ///依据角色的上下左右四个动作 创建四个方向的动画
player1_animate_left = Animate::create(player1_animation_left);
player1_animate_right = Animate::create(player1_animation_right);
player1_animate_down = Animate::create(player1_animation_down);
player1_animate_up = Animate::create(player1_animation_up); player2_animate_left = Animate::create(player2_animation_left);
player2_animate_right = Animate::create(player2_animation_right);
player2_animate_down = Animate::create(player2_animation_down);
player2_animate_up = Animate::create(player2_animation_up); }

2、 创建完角色须要的文件后,还须要角色在地图的位置,因为能走的路径都在way图层中,在setWayPassToGrid()方法中。我们把way图层中sprite的坐标保存到wayLayerPass_vector中。这样就能够依据当中的坐标设置角色的位置了

void  GameBaseScene::setWayPassToGrid()
{
TMXLayer* wayLayer = _map->layerNamed("way"); Size _mapSize = wayLayer->getLayerSize();
for (int j = 0; j < _mapSize.width; j++) {
for (int i = 0; i < _mapSize.height; i++) {
Sprite* _sp = wayLayer->tileAt(Point(j, i));
if (_sp)
{
float x = _sp->getPositionX();
float y = _sp->getPositionY();
int col = x/tiledWidth;
int row = y/tiledHeight;
canPassGrid[row][col] = true;
//取得该位置的坐标,保存到对象wayLayerPass_vector中
Vec2 p = _sp->getPosition();
wayLayerPass_vector.push_back(p);
log("canPassGrid row= %d ,col =%d ,canpass = %d" ,row,col,canPassGrid[row][col]);
} }
}
log("setWayPassToGrid finished");
}

3、 加入的角色我们先封装成一个RicherPlayer类。该类记录角色的信息。包含角色名称、资金、体力、敌友

RicherPlayer* RicherPlayer::create(char* name,SpriteFrame* spriteFrame,bool enemy,int money,int strength)
{
RicherPlayer* player = new RicherPlayer();
player->init(name,spriteFrame, enemy,money,strength);
player->autorelease();
return player; } bool RicherPlayer::init(char* name,SpriteFrame* spriteFrame,bool enemy,int money,int strength)
{ Sprite::initWithSpriteFrame(spriteFrame);
_name = name;
_enemy = enemy;
_money = money;
_strength = strength;
return true;
}

4、接下来在addPlayer()方法中,从容器wayLayerPass_vector中随机取出坐标,进行角色的加入。

void GameBaseScene:: addPlayer()
{
//指定随机数种子,随机数依据这个种子产生 採用当前时间生成随机种子:
struct timeval now;
gettimeofday(&now, NULL); //计算时间种子
unsigned rand_seed = (unsigned)(now.tv_sec*1000 + now.tv_usec/1000); // 初始化随机数
srand(rand_seed); //从帧缓存图片中取第一张。做为角色的初始图片
SpriteFrame* spf1 = player1_spriteFrameCache->getSpriteFrameByName("player1_anim_01.png");
player1 = RicherPlayer::create("player1",spf1,false);
//依据wayLayerPass_vector的坐标数量,取得随机的一个id
int _rand1 = rand()%(wayLayerPass_vector.size());
log("rand %d" ,_rand1);
//依据id,取出当中的坐标
Vec2 vec2ForPlayer1 = wayLayerPass_vector.at(_rand1);
//这个我们给纵向位置加入一个tiledHeight高度,目的是为了让角色居中显示在道路中
vec2ForPlayer1.y +=tiledHeight;
//设置角色的位置,以及锚点
player1->setPosition(vec2ForPlayer1);
player1->setAnchorPoint(ccp(0,0.5));
//log 相关
int col = vec2ForPlayer1.x/tiledWidth;
int row = vec2ForPlayer1.y/tiledHeight;
log("player1 position row= %d ,col = %d" ,row,col);
log("player1 position x= %f ,y = %f" , vec2ForPlayer1.x, vec2ForPlayer1.y);
//加入角色到地图场景
addChild(player1); 角色2的加入同角色1方法同样。不再累述
………………… }

測试ok 已经能够看到2个角色了

未完待续.......................

差点忘了代码

点击下载代码     http://download.csdn.net/detail/lideguo1979/8281909

Cocos2d-x 3.2 大富翁游戏项目开发-第七部分 获取角色路径_2的更多相关文章

  1. Cocos2d-x 3.2 大富翁游戏项目开发-第七部分 获取角色路径_3

    点击下载代码   http://download.csdn.net/detail/lideguo1979/8291803 新建一个类RouteNavigation,定义getPath()方法.用来获取 ...

  2. Cocos2d-x 3.2 大富翁游戏项目开发-第七部分 获取角色路径_1

    以下是一些设计略显繁琐,有必要清除思维. 下一个主要的成就,当我们点击Gobutton后,得到一个随机数骰子,是走了几步,它是基于以下步骤行走路径的数目,然后移动位置的基于角色的路径. 流程如图普遍认 ...

  3. Cocos2d-x 3.2 大富翁游戏项目开发-第八部分 角色的散步路径

    获得所述路径之后.我们将能够使根据的步行路径的作用,当您点击gobutton什么时候.我们呼吁player的startGo()办法.传入的参数是保存路径2一维数组 void GameBaseScene ...

  4. Cocos2d-x 3.2 大富翁游戏项目开发-第五部分 单机游戏-级别选择ScrollView

    于MenuScene.cpp 点击单机游戏后会调用 Director::getInstance()->pushScene(MapChooseScene::createScene()); 进入到关 ...

  5. 微信小程序开发(七)获取手机网络类型

    // succ.wxml <view>手机网络状态:{{netWorkType}}</view> // succ.js var app = getApp() Page({ da ...

  6. C#微信公众号开发 -- (七)自定义菜单事件之VIEW及网页(OAuth2.0)授权

    通俗来讲VIEW其实就是我们在C#中常用的a标签,可以直接在自定义菜单URL的属性里面写上需要跳转的链接,也即为单纯的跳转. 但更多的情况下,我们是想通过VIEW来进入指定的页面并进行操作. 举一个简 ...

  7. 云平台编程与开发(七)-使用X5Cloud云平台开发网络彩讯

    云平台编程与开发(七)-使用X5Cloud云平台开发网络彩讯 博客分类: 云平台 云计算 Java Android Android 云平台 Java 网络彩讯定义以及工作大概流程  下载试用地址:ap ...

  8. C#的百度地图开发(三)依据坐标获取位置、商圈及周边信息

    原文:C#的百度地图开发(三)依据坐标获取位置.商圈及周边信息 我们得到了百度坐标,现在依据这一坐标来获取相应的信息.下面是相应的代码 public class BaiduMap { /// < ...

  9. 转:微信开发之使用java获取签名signature(贴源码,附工程)

    微信开发之使用java获取签名signature(贴源码,附工程) 标签: 微信signature获取签名 2015-12-29 22:15 6954人阅读 评论(3) 收藏 举报  分类: 微信开发 ...

随机推荐

  1. Unicode字符集和多字节字符集关系

      在计算机中字符通常并不是保存为图像,每个字符都是使用一个编码来表示的,而每个字符究竟使用哪个编码代表,要取决于使用哪个字符集(charset). 在最初的时候,Internet上只有一种字符集—— ...

  2. [字符串] StartWith和EndWith效率比较低

    之前无意中看到有人提到StartWith和EndWith效率比较低,今天恰好有用到这样的场景,于是写了个测试验证一下. 该示例仅在比较字符串首尾单个字符,用途有限. var str = "\ ...

  3. cocos2d Programming Guide

    http://python.cocos2d.org/doc/programming_guide/index.html The cocos2d Programming Guide provides in ...

  4. linux内核分析之缺页中断【转】

    转自:http://blog.csdn.net/bullbat/article/details/7108402 linux缺页异常程序必须能够区分由编程引起的异常以及由引用属于进程地址空间但还尚未分配 ...

  5. html控件使用

    <html> <head> <title>登录页面</title> </head> <body> <form action ...

  6. Vue v-for嵌套数据渲染问题

    Vue v-for嵌套数据渲染问题 问题描述: 由于在获取商品子分类的时候,同时需要获取子分类下的商品,那么多层的列表渲染就只能是第一层好用 问题原因: vue在处理多层的渲染的时候,不能直接用等号赋 ...

  7. POJ 1833 排列【STL/next_permutation】

    题目描述: 大家知道,给出正整数n,则1到n这n个数可以构成n!种排列,把这些排列按照从小到大的顺序(字典顺序)列出,如n=3时,列出1 2 3,1 3 2,2 1 3,2 3 1,3 1 2,3 2 ...

  8. Python的网络编程[6] -> Modbus 协议 -> Modbus 的基本理论与 Python 实现

    Modbus协议 / Modbus Protocol 目录 Modbus 协议简介 Modbus RTU协议 Modbus TCP协议与 Python 实现 Modbus 功能码 Modbus TCP ...

  9. hdu6053

    hdu6053 题意 给出 \(A\) 数组,问有多少种 \(B\) 数组满足下面条件. \(1≤ B_i ≤ A_i\) For each pair \(( l , r ) \ (1≤l≤r≤n) ...

  10. spring线程并发处理(ThreadLocal)

    我们知道Spring通过各种DAO模板类降低了开发者使用各种数据持久技术的难度.这些模板类都是线程安全的,也就是说,多个DAO可以复用同一个模板实例而不会发生冲突. 我们使用模板类访问底层数据,根据持 ...