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

这一步其中,我们主要完毕下面功能:

1.地图的无限滚动---让主角看起来真的是在跑动

2.给主角加入Jump跳跃和crouch下蹲动作

那么首先来让背景滚动起来,在PlayScene.h中加入:

//初始化背景
void initBG();
//用update函数让地图滚动
virtual void update(float dt); //背景精灵
cocos2d::Sprite* bgSprite1;
cocos2d::Sprite* bgSprite2;
cocos2d::Sprite* groundSprite1;
cocos2d::Sprite* groundSprite2;

然后.Cpp文件里:

void PlayScene::initBG(){
auto visibleSize = Director::getInstance()->getVisibleSize();
//背景1
bgSprite1 = Sprite::create("Map00.png");
bgSprite1->setPosition(visibleSize.width/2,visibleSize.height/2);
this->addChild(bgSprite1); //地面1
groundSprite1 = Sprite::create("Ground00.png");
groundSprite1->setPosition(visibleSize.width/2,groundSprite1->getContentSize().height/2);
this->addChild(groundSprite1); //背景2
bgSprite2 = Sprite::create("Map01.png");
bgSprite2->setPosition(bgSprite1->getContentSize().width+visibleSize.width/2,visibleSize.height/2);
this->addChild(bgSprite2); //地面2
groundSprite2 = Sprite::create("Ground01.png");
groundSprite2->setPosition(bgSprite1->getContentSize().width+visibleSize.width/2,groundSprite2->getContentSize().height/2);
this->addChild(groundSprite2);
} void PlayScene::update(float dt){
int posX1 = bgSprite1->getPositionX();
int posX2 = bgSprite2->getPositionX(); posX1 -= 2;
posX2 -= 2; auto mapSize = bgSprite1->getContentSize(); if(posX1 < -mapSize.width/2){
posX1 = mapSize.width + mapSize.width/2;
posX2 = mapSize.width/2;
}
if(posX2 < -mapSize.width/2){
posX2 = mapSize.width + mapSize.width/2;
posX1 = mapSize.width/2;
} bgSprite1->setPositionX(posX1);
bgSprite2->setPositionX(posX2);
groundSprite1->setPositionX(posX1);
groundSprite2->setPositionX(posX2);
}

完毕这些,我们就在PlayScene中的init函数:

bool PlayScene::init(){
if(!Layer::init()){
return false;
} SimpleAudioEngine::getInstance()->playBackgroundMusic("background.mp3",true); initPhysicWorld(); initBG(); //开启update
this->scheduleUpdate(); m_runner = Runner::create();
m_runner->setPosition(runner_posX,ground_hight+m_runner->getRunJumpSize().height/2);
m_runner->Run(); this->addChild(m_runner); return true;
}

这里要注意:我们应该把背景的初始化放置在主角创建的前面,由于先创建主角,就等于在屏幕上先画出主角,然后再画背景,那么主角就会被挡住。当然,这里也能够设置绘画的层次,那么执行例如以下图:

这里任然不是 动态的截图,所以看不出地图滚动的效果,求指导。。。

以下来为主角加入除开跑动的其它动作:

在Runner的 initActionSet函数中,我们先加入其它的帧动画:

void Runer::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"); /*4------------------载入跳跃过程中上升的动画---------------------------*/
frameVector.clear();
for(int i = 0; i <= 3; i ++){
frame = frameCache->spriteFrameByName(String::createWithFormat("runnerJumpUp%d.png",i)->getCString());
frameVector.pushBack(frame);
}
auto jumpUp_animation = Animation::createWithSpriteFrames(frameVector,0.2);//不设置无限循环
AnimationCache::getInstance()->addAnimation(jumpUp_animation,"jumpUp"); /*------------------载入跳跃过程中下落的动画----------------------------*/
frameVector.clear();
for(int i = 0; i <= 1; i ++){
frame = frameCache->spriteFrameByName(String::createWithFormat("runnerJumpDown%d.png",i)->getCString());
frameVector.pushBack(frame);
}
auto jumpDown_animation = Animation::createWithSpriteFrames(frameVector,0.3);
AnimationCache::getInstance()->addAnimation(jumpDown_animation,"jumpDown"); /*------------------载入下蹲-------------------------------------------*/
frameVector.clear();
frame = frameCache->spriteFrameByName("runnerCrouch0.png");
frameVector.pushBack(frame);
auto crouch_animation = Animation::createWithSpriteFrames(frameVector,0.3);//不设置无限循环
AnimationCache::getInstance()->addAnimation(crouch_animation,"crouch"); }

加入Jump,Crouch函数,以及update函数:

void Jump();

void Crouch();

virtual void update(float dt);

实现:

void Runner::Jump(){
//仅仅有在跑动时才干起跳
if(m_state == running){
m_state = jumpUp; auto mass = this->getPhysicsBody()->getMass()*150;// 力大小 this->getPhysicsBody()->applyImpulse(Vect(0,mass)); m_runner->stopAllActions(); doAction("jumpUp");
}
} void Runner::update(float dt){
auto vel = this->getPhysicsBody()->getVelocity();
if(m_state == jumpUp){
if(vel.y < 0.1){
m_state = jumpDown;
m_runner->stopAllActions();
doAction("jumpDown");
}
} if(m_state == jumpDown){
CCLOG("%f",vel.y);
//不应该是 等于 0
if(vel.y > 0){
m_state = running;
m_runner->stopAllActions();
doAction("running");
}
}
} void Runner::Crouch(){
//仅仅能在跑动的时候蹲下
if(m_state == running){
m_state = crouch;
m_runner->stopAllActions();
initBody();
doAction("crouch");
}
}

这里的Jump 我们就给主角一个向上的力,而且这个力是瞬时力,这样主角就会上升,可是加速度向下,慢慢到达最高点然后 因为重力而下落;

这里的update函数用来做这个事: 当主角向上跳到最高点的时候,就应该下落,切换下落状态,运行下落帧动画,这里是借鉴了前辈的,首先在JumpUp状态下,假设y速度小于 0.1 那么我们觉得它到了最高点,切换下落。在JumpDown状态下,y速度大于0,我们就觉得它到达了地面,切换跑动状态。 前辈的推断中是 vel.y == 0 过程中我调试了,由于速度是float,== 0这样的推断非常不精确,然后我的主角就一直处于下落的那个动作状态啦。。。。。



Ok到这里,我们主角的动作都准备好了,以下就開始加入 button,来控制主角运行这些动作啦!!

个人愚昧观点,欢迎指正与讨论(好像也没人会和我讨论,,哎)

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游戏实例学习笔记 《跑酷》 第三步---主角开跑&amp;同一时候带着刚体

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

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

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

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

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

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

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

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

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

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

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

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

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

随机推荐

  1. datagrid直接编辑保存“设计缺陷”

    当今使用easyUI的datagrid组件的时候,碰到了一些问题,记录下来以便下次高速解决. 需求是在一张表单里会关联有一个列表,能够增删查改 曾经没用easyUI的时候,这个增和改的页面我通常是用一 ...

  2. 【剑指offer】面试题28:弦乐

    def Permutation(data, i): if len( data ) == 0: return # i stand for the start of first part for i in ...

  3. 搭建 Linux 下 GitLab 服务器(转)

    这两天因为项目需求需要搭建一个GitLab服务器,遇到了很多问题,参考了很多网络资料,终于搭建成功,在此把这个过程记录一下,利人利己. 一.最终目的 1,在Linux下创建GitLab服务器,客户端能 ...

  4. paip.jdk1.4 1.5(5.0) 1.6(6.0) 7.0 8.0特点比较与不同

    paip.jdk1.4 1.5(5.0)  1.6(6.0) 7.0   8.0特点比较与不同 作者Attilax ,  EMAIL:1466519819@qq.com 来源:attilax的专栏 地 ...

  5. XCL-Charts绘画面积图(AreaChart) 例1

    样本区域地图,发现区域图的时候把做向上注视位置图更具优势的管理.在改变. 区域图网格和轴是不一样的处理与其它图, 它是用来表示其影响范围的覆盖范围,车桥无段伸出. 在这里下处理. watermark/ ...

  6. 自己动手写CPU之第八阶段(4)——转移指令实现过程2

    将陆续上传本人写的新书<自己动手写CPU>,今天是第36篇,我尽量每周四篇 开展晒书评送书活动,在亚马逊.京东.当当三大图书站点上,发表<自己动手写CPU>书评的前十名读者,均 ...

  7. struts详细解释拦截器

    1.拦截器:Struts2拦截器将一个Action要么Action的方法.之前或截取后场,和Struts2拦截器是可插拔,拦截器AOP一种实现. WebWork:拦截器是动态拦截Action调用的对象 ...

  8. Java线(一个):线程安全的和不安全

    当我们看JDK API什么时候,总是找一些类描述说:,线程安全或线程安全,例如StringBuilder在,么一句,"将StringBuilder 的实例用于多个线程是不安全的.假设须要这种 ...

  9. 我学的是设计模式的视频教程——辛格尔顿,生成器VS工厂方法

    课程视频 单例模式         建造者VS工厂方法                      课程笔记 课程笔记 课程代码 课程代码 新课程火热报名中 课程介绍 版权声明:本文博客原创文章,博客, ...

  10. WWDC 2014 Session 205/217 Extension 注意事项

    基于阅读下面的内容205和217的PDF做笔记.没有深入研究. 205 Creating Extensions for iOS and OS X, Part 1 217 Creating Extens ...