说明:这里是借鉴:晓风残月前辈的博客。他是将泰然网的跑酷教程。用cocos2d-x
2.X 版本号重写的,眼下我正在学习cocos2d-X3.0 于是就用cocos2d-X 3.0重写,并做相关笔记

在这一步。我们主要是把主角增加到游戏场景中来,并且让它跑动,这里的跑动,实际上也就是运行一组动画,让其看起来像是在跑动,并且相对屏幕的位置也不会改变

我们会定义一个主角类:Runner。而这一步就要用到 帧动画 的创建和使用等知识点。

对于Runner,我的设计思路例如以下:

1.主角有一个动作集合。包含跑动,跳起来,以及蹲下。

那么就有不同的帧动画,那么这里借鉴到 晓风残月前辈的方法,将帧动画打包命名。之后依据动作名来运行动作

2.主角须要绑定刚体。而且在不同的动作下的刚体大小不同

3.我们给主角设定一个状态。那么依据状态,就能知道运行动作和刚体

反正在这一步主要是看

那么上马:Runner.h

#ifndef __Runner__H__
#define __Runner__H__ #include "cocos2d.h" enum runnerState{
running,
jumpUp,
jumpDown,
crouch
}; class Runner : public cocos2d::Node{
public:
virtual bool init();
CREATE_FUNC(Runner); //初始化 action 集合
void initActionSet(cocos2d::SpriteFrameCache* frameCache); //依据动作名称运行动作
void doAction(const char* actionName);// void initBody();//初始化物理刚体 runnerState getState(){ return m_state;};//获取当前的状态,后面要用到 cocos2d::Size getRunJumpSize(){ return run_jumpSize;};//获取不同一时候候的SIze
cocos2d::Size getCrouchSize() { return crouchSize;}; void Run();
private:
// 须要一个基本的精灵运行动作
cocos2d::Sprite* m_runner; // 不同的动作须要不同的刚体大小
cocos2d::Size run_jumpSize;//跑和跳的大小一样
cocos2d::Size crouchSize;//蹲下来的大小 runnerState m_state;
};/**/ #endif

这里的刚体Size仅仅有两个。由于跑的时候和跳起来的时候的精灵大小是几乎相同的,那么处于这两个状态的的刚体绑定大小能够一样。然后下蹲的时候的Size就不同

Runner.cpp

#include "Runner.h"

USING_NS_CC;

bool Runner::init(){
//载入图片到缓存池
auto frameCache = SpriteFrameCache::getInstance();
frameCache->addSpriteFramesWithFile("parkour.plist","parkour.png"); m_runner = Sprite::createWithSpriteFrameName("runner0.png"); run_jumpSize = m_runner->getContentSize();
crouchSize = Sprite::createWithSpriteFrameName("runnerCrouch0.png")->getContentSize(); this->addChild(m_runner); initActionSet(frameCache);//初始化动作集合 m_state = running; initBody(); return true;
} void Runner::initActionSet(SpriteFrameCache* frameCache){
SpriteFrame* frame = NULL;
//3.0中改用vector 而不是用Array
Vector<SpriteFrame*>frameVector; /* 1.----------------载入跑动的Animation-----------------*/
for(int i = 0; i <= 7; i ++) {
//从缓存池中载入精灵到Vector
frame = frameCache->spriteFrameByName(String::createWithFormat("runner%d.png",i)->getCString());
frameVector.pushBack(frame);
} //用vector里面的SpriteFrame列表创建Animation 以及设置一些參数
auto run_animation = Animation::createWithSpriteFrames(frameVector,0.1f,-1);
//将跑动的 Animation 取名为 running
AnimationCache::getInstance()->addAnimation(run_animation,"running"); } void Runner::doAction(const char* actionName){
auto animation = AnimationCache::getInstance()->animationByName(actionName);
auto action = Animate::create(animation);
m_runner->runAction(action);
} void Runner::initBody(){
//依据不同状态设置不同刚体大小
Size bodySize;
if(m_state == crouch){
bodySize = crouchSize;
}
else{
bodySize = run_jumpSize;
} //创建runner的刚体
auto runerBody = PhysicsBody::createBox(bodySize,PHYSICSBODY_MATERIAL_DEFAULT); //绑定刚体
this->setPhysicsBody(runerBody);
} void Runner::Run(){
m_state = running;
initBody();
doAction("running");
}

init
函数里面我们做了一些事:

1.先把图片载入到缓存池,初始化主精灵,和两个Size,以及当前状态

这里的图片实际上是一张整合了非常多小图片的集合。不同的图片有不同纹理,那么集合到同一图片中纹理就同样的,那么同一纹理的图片,我们就能够降低渲染批次。3.0中的渲染好像是自己主动处理的。看了一篇文章。说是不推荐使用那个SpriteBachNode啦,然后说得也比較抽象,我这里也不特别解释,有好的教程麻烦推荐,谢谢

2.我们初始化了动作集合,这一步其中,我们仅仅初始化跑动的帧动画

initActionSet函数其中。我都有具体凝视

doAction函数中,我们能够依据传入的參数动作名称来运行动作,也就是在initActionSet 其中给动作取名字的那里

initBody函数其中。依据不同的状态,我们就给主角绑定不同大小的刚体,关于反复setPhysicsBody。你可能会有疑问。本来有一个刚体,换了一个状态。又设定一个刚体能够吗?答案是能够的,我们能够查看源代码

void Node::setPhysicsBody(PhysicsBody* body)
{
/*省略*/ if (_physicsBody != nullptr)
{
PhysicsWorld* world = _physicsBody->getWorld();
_physicsBody->removeFromWorld();
_physicsBody->_node = nullptr;
_physicsBody->release(); if (world != nullptr && body != nullptr)
{
world->addBody(body);
}
} _physicsBody = body;
if (body != nullptr)
{
Node* parent = getParent();
Point pos = parent != nullptr ? parent->convertToWorldSpace(getPosition()) : getPosition();
_physicsBody->setPosition(pos);
_physicsBody->setRotation(getRotation());
}
}

这里我们能够看到,它会推断_physicsBody(也就是Node的刚体)是不是为空。如有已有刚体,会先删除。然后又一次绑定

好啦,到这里主角类以及初步设置完啦,我们在PlayScene.h 中增加一个成员变量  Runner* m_runner;

然后在PlayScene.cpp 的init函数中对 m_runner初始化:

m_runner = Runner::create();
m_runner->setPosition(runner_posX,ground_hight+m_runner->getRunJumpSize().height/2);
m_runner->Run();
this->addChild(m_runner);

那么这里的runner_posX 就是在 ground_hight  以下定义的一个宏,也就是主角的X坐标位置,我这里定义 80

OK执行測试如图:

假设你把那些资源都放在Resouce 文件下了。还能听到背景音乐

这里我也有一个问题,就是有的人能够插入动态的那种图片,比較好的演示了执行结果。用QQ好像不能对这个屏幕进行截取动态图,求方法推荐

以下我们就增加PlayScene的背景,以及地图无限滚动,让主角看起来更像是跑动 ,同一时候也为主角的Jump跳跃动作以及Crouch下蹲动作的运行做准备

个人愚昧观点,欢迎指正与讨论

cocos2d-x 3.0游戏实例学习笔记 《跑酷》 第三步---主角开跑&amp;同一时候带着刚体的更多相关文章

  1. cocos2d-x 3.0游戏实例学习笔记 《跑酷》 完结篇--源代码放送

    说明:这里是借鉴:晓风残月前辈的博客,他是将泰然网的跑酷教程,用cocos2d-x 2.X 版本号重写的,眼下我正在学习cocos2d-X3.0 于是就用cocos2d-X 3.0重写,并做相关笔记 ...

  2. cocos2d-x 3.0游戏实例学习笔记 《跑酷》第一步--- 开始界面

    说明:这里是平局:晓风残月前辈的博客.他是将泰然网的跑酷教程.用cocos2d-x 2.X 版本号重写的,眼下我正在学习cocos2d-X3.0 于是就用cocos2d-X 3.0重写,并做相关笔记 ...

  3. cocos2d-x 3.0游戏实例学习笔记 《跑酷》第七步--物理碰撞检測(1)

    说明:这里是借鉴:晓风残月前辈的博客,他是将泰然网的跑酷教程,用cocos2d-x 2.X 版本号重写的,眼下我正在学习cocos2d-X3.0 于是就用cocos2d-X 3.0重写,并做相关笔记 ...

  4. cocos2d-x 3.0游戏实例学习笔记 《跑酷》 第六步--金币&amp;岩石加入而且管理

    说明:这里是借鉴:晓风残月前辈的博客,他是将泰然网的跑酷教程,用cocos2d-x 2.X 版本号重写的,眼下我正在学习cocos2d-X3.0 于是就用cocos2d-X 3.0重写,并做相关笔记 ...

  5. cocos2d-x 3.0游戏实例学习笔记《卡牌塔防》第二步---编辑器(1)--触摸加入点

    /* 说明: **1.本次游戏实例是<cocos2d-x游戏开发之旅>上的最后一个游戏,这里用3.0重写并做下笔记 **2.我也问过木头本人啦,他说:随便写,第一别全然照搬代码:第二能够说 ...

  6. cocos2d-x 3.0游戏实例学习笔记 《跑酷》移植到android手机

    说明:这里是借鉴:晓风残月前辈的博客.他是将泰然网的跑酷教程.用cocos2d-x 2.X 版本号重写的,眼下我正在学习cocos2d-X3.0 于是就用cocos2d-X 3.0重写,并做相关笔记 ...

  7. coco2d-x 3.0游戏实例学习笔记 《跑酷》 第二步---游戏界面&amp;全新的3.0物理世界

    说明:这里是借鉴:晓风残月前辈的博客,他是将泰然网的跑酷教程.用cocos2d-x 2.X 版本号重写的,眼下我正在学习cocos2d-X3.0 于是就用cocos2d-X 3.0重写.并做相关笔记 ...

  8. cocos2d-x 3.0游戏实例学习笔记 《跑酷》第四步--地图循环&amp;主角加入动作

    说明:这里是借鉴:晓风残月前辈的博客,他是将泰然网的跑酷教程,用cocos2d-x 2.X 版本号重写的,眼下我正在学习cocos2d-X3.0 于是就用cocos2d-X 3.0重写,并做相关笔记 ...

  9. cocos2d-x 3.0游戏实例学习笔记 《跑酷》 第五步--button控制主角Jump&amp;Crouch

    说明:这里是借鉴:晓风残月前辈的博客.他是将泰然网的跑酷教程,用cocos2d-x 2.X 版本号重写的,眼下我正在学习cocos2d-X3.0 于是就用cocos2d-X 3.0重写,并做相关笔记 ...

随机推荐

  1. Python面向对象之常用的特殊方法(5)

    Python面向对象里面有很多特殊方法,例如__init__(构造方法),__del__(析构方法),这些方法对于面向对象编程非常重要,下面列出一些常用的特殊方法 (1)__call__ class ...

  2. 商城商品购买数量增减的完美JS效果

    近期在开发一个地方O2O租书项目,使用ASP.NET MVC技术,其中在图书详情页,用户可以输入借阅的数量,这里使用了js来控制数量的增减和校验. 数量一定是数字 点击增减按钮的时候要能自动加1或减1 ...

  3. Junit单元测试--01

    如何编写单元测试 燕双龙 一 单元测试简介 单元测试是代码正确性验证的最重要的工具,也是系统测试当中最重要的环节.也是唯一需要编写代码才能进行测试的一种测试方法.在标准的开发过程中,单元测试的代码与实 ...

  4. mysql event 学习

    mysql 通过事件可以实现定时任务 : 1. 检查你的MYSQL是否开了这个功能 show variables like "%scheduler" //注意 最后是er 2.   ...

  5. ubuntu 下openoffice安装

    openoffice官网建议的安装步骤:http://www.openoffice.org/download/index.html 前提条件 如果你希望Java集成,你要确保你有安装最新的JRE.它的 ...

  6. 【bzoj2280】[Poi2011]Plot 二分+倍增+二分+最小圆覆盖

    题目描述 给出一系列点p_1, p_2, ... , p_n,将其分成不多余m个连续的段,第i段内求一个点q_i,使得q_i到这段内点的距离的最大值的最大值最小 输入 第一行,n m下面n行,每行两个 ...

  7. Incorrect column count: expected 1, actual 6

    JdbcTemplate使用时出现了一些问题: 解决办法:

  8. KM算法【带权二分图完美匹配】

    先orz litble--KM算法 为什么要用KM算法 因为有的题丧心病狂卡费用流 KM算法相比于费用流来说,具有更高的效率. 算法流程 我们给每一个点设一个期望值[可行顶标] 对于左边的点来说,就是 ...

  9. include和require的区别误区

    面试时总会被问到include和require的区别,回答的时候一般也是有以下几种区别: 1.include引入文件的时候,如果碰到错误,会给出警告,并继续运行下边的代码. require引入文件的时 ...

  10. 使用PropTypes进行类型检测

    PropTypes 是react提供的用于检验数据类型的typechecking,避免应用越来越大的时候出现意料之外的bug class Greeting extends React.Componen ...